linux驱动36:工作队列——共享队列

在很多情况下,设备驱动程序不需要有自己的工作队列。向队列提交任务,可以使用内核提供的共享的工作队列。共享队列不能长期独占,即不能长时间休眠。

头文件:

#include <linux/workqueue.h>

接口:

INIT_WORK(struct workqueue_struct *, void (func) (struct work_struct *));

int schedule_work(struct work_struct *);//提交任务到队列进行调度

int schedule_delayed_work(struct delayed_work *work, unsigned long delay);//以延迟的方式提交任务

int cancel_delayed_work(struct delayed_work *work);//取消某个挂起的工作队列入口项

void flush_scheduled_work(void);//刷新共享工作队列

#include <linux/init.h>
#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/time.h>
#include <linux/workqueue.h>

typedef struct
{
	char data[32];
	struct work_struct test_work;
}MY_WORK_S;

static struct timeval lastTime;
static MY_WORK_S myWork;
static int cnt = 0;

void my_work_func(struct work_struct *work)
{
	struct timeval curTime;
	MY_WORK_S *p = container_of(work, MY_WORK_S, test_work); 
	printk("%s:%s\n", __func__, p->data);

	do_gettimeofday(&curTime);
	printk("interval: %ld s, %ld us\n",
		curTime.tv_sec - lastTime.tv_sec, curTime.tv_usec - lastTime.tv_usec);

	if (cnt <= 5)
	{
		schedule_work(work);
		cnt++;
	}
}

static int __init hello_init(void)
{
	printk("hello_init. \n");
	strcpy(myWork.data, "hello");
	INIT_WORK(&myWork.test_work, my_work_func);
	schedule_work(&myWork.test_work);
	do_gettimeofday(&lastTime);
	return 0;
}

static void __exit hello_exit(void)
{
	printk("hello_exit. \n");
	flush_scheduled_work();
}

MODULE_LICENSE("GPL");
module_init(hello_init);
module_exit(hello_exit);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值