cancel _delayed_work 和 flush_delayed_work

ps aux 时看到的event线程(如果有多个cpu可能就有多event0~x)就是内核的大work_list, 通常是用schedule_work()之类的函数就是把job hang到这个list上面去。

而cancel_delayed_work实际是用来取消挂到执行队列上的job, 一般在调用这个函数后都会继续调用flush_delayed_work这个是用来等到正在执行的队列执行完。实际上后者是为了解决cancel时的死锁问题。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用 `cancel_delayed_work()` 函数来取消一个已经被延迟的工作。这个函数可以在工作的执行之前调用,以取消该工作。以下是一个示例代码片段,演示如何使用 `cancel_delayed_work()` 函数来取消一个延迟的工作: ``` #include <linux/kernel.h> #include <linux/module.h> #include <linux/workqueue.h> static struct workqueue_struct *my_workqueue; static struct delayed_work my_work; // 工作处理函数 static void my_work_handler(struct work_struct *work) { printk("Delayed work executed\n"); } // 模块加载函数 int init_module(void) { // 创建工作队列 my_workqueue = create_workqueue("my_workqueue"); // 初始化延迟工作 INIT_DELAYED_WORK(&my_work, my_work_handler); // 延迟 5 秒执行工作 queue_delayed_work(my_workqueue, &my_work, 5 * HZ); // 取消延迟工作 cancel_delayed_work(&my_work); return 0; } // 模块卸载函数 void cleanup_module(void) { // 销毁工作队列 flush_workqueue(my_workqueue); destroy_workqueue(my_workqueue); } MODULE_LICENSE("GPL"); ``` 在上面的示例中,我们首先在模块加载函数中创建了一个工作队列 `my_workqueue`,然后初始化了一个延迟工作 `my_work`,并将其添加到工作队列中以延迟 5 秒执行。接着,我们调用 `cancel_delayed_work()` 函数来取消这个延迟工作。最后,在模块卸载函数中销毁了工作队列。 请注意,`cancel_delayed_work()` 函数只能取消还未执行的延迟工作。如果延迟工作已经开始执行或已经执行完毕,则无法取消。因此,在调用 `cancel_delayed_work()` 函数之前,需要确保工作还没有开始执行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值