工作队列类似 tasklets,允许内核代码请求在将来某个时间调用一个函数,不同在于:
(1)tasklet 在软件中断上下文中运行,所以 tasklet 代码必须是原子的。而工作队列函数在一个特殊内核进程上下文运行,有更多的灵活性,且能够休眠。
(2)tasklet 只能在最初被提交的处理器上运行,这只是工作队列默认工作方式。
(3)内核代码可以请求工作队列函数被延后一个给定的时间间隔。
(4)tasklet 执行的很快, 短时期, 并且在原子态, 而工作队列函数可能是长周期且不需要是原子的,两个机制有它适合的情形。
#include <linux/init.h>
#include <linux/module.h>
#include <linux/moduleparam.h>
#include <linux/fs.h>
#include <linux/kdev_t.h>
#include <linux/cdev.h>
#include <linux/kernel.h>
#include <linux/interrupt.h>
void work_function(unsigned long sign);
static struct work_struct my_work;
void work_function(unsigned long sign)
{
printk(KERN_EMERG"work out %ld\n",sign);
}
static void work_init(void)
{
INIT_WORK(&my_work,(void(*)(void*))work_function,4);
schedule_work(&my_work);
}
static void work_exit(void)
{
printk(KERN_EMERG"GOOBYE,WORLD\t\n");
}
module_init(work_init);
module_exit(work_exit);
MODULE_LICENSE("Dual BSD/GPL");
测试结果如下:
[root@localhost work_queue]# insmod work.ko
[root@localhost work_queue]#
Message from syslogd@ at Mon Aug 13 14:52:36 2012 ...
localhost kernel: work out 4
[root@localhost work_queue]#