flush_workqueue

Name

flush_workqueue — ensure that any scheduled work has run to completion.

Synopsis

void fastcall flush_workqueue ( struct workqueue_struct *   wq);

Arguments

wq

workqueue to flush

Description

Forces execution of the workqueue and blocks until its completion. This is typically used in driver shutdown handlers.

This function will sample each workqueue's current insert_sequence number and will sleep until the head sequence is greater than or equal to that. This means that we sleep until all works which were queued on entry have been handled, but we are not livelocked by new incoming ones.

This function used to run the workqueues itself. Now we just wait for the helper threads to do it.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Linux 中,可以使用 `create_singlethread_workqueue()` 函数来创建一个单线程工作队列。 该函数的原型如下: ```c struct workqueue_struct *create_singlethread_workqueue(const char *name); ``` 其中,`name` 参数是工作队列的名称。该函数返回一个指向 `workqueue_struct` 结构体的指针,该结构体表示创建的工作队列。 下面是一个简单的示例,展示了如何使用 `create_singlethread_workqueue()` 函数创建一个单线程工作队列: ```c #include <linux/module.h> #include <linux/kernel.h> #include <linux/workqueue.h> static struct workqueue_struct *workqueue; static void work_handler(struct work_struct *work) { printk(KERN_INFO "Hello, world!\n"); } static DECLARE_WORK(work, work_handler); static int __init my_module_init(void) { workqueue = create_singlethread_workqueue("my_workqueue"); if (!workqueue) { printk(KERN_ERR "Failed to create workqueue\n"); return -ENOMEM; } schedule_work(&work); return 0; } static void __exit my_module_exit(void) { flush_work(&work); destroy_workqueue(workqueue); } module_init(my_module_init); module_exit(my_module_exit); MODULE_LICENSE("GPL"); ``` 在这个示例中,我们首先定义了一个工作处理函数 `work_handler`,它将打印一条消息。然后,我们使用 `DECLARE_WORK` 宏定义了一个工作项 `work`,并将其与 `work_handler` 函数关联起来。 在 `my_module_init` 函数中,我们调用 `create_singlethread_workqueue` 函数来创建一个名为 `my_workqueue` 的工作队列。然后,我们调用 `schedule_work` 函数将 `work` 工作项添加到工作队列中。 在 `my_module_exit` 函数中,我们使用 `flush_work` 函数等待工作项完成,并使用 `destroy_workqueue` 函数销毁工作队列。 需要注意的是,工作队列中的工作项是在内核线程中执行的,而不是在进程上下文中执行的。因此,在工作队列中执行的函数应该是内核级别的函数,而不是用户空间的函数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值