工作队列、tasklet、软中断的用法总结

原创 2013年12月10日 15:11:07

下面把API罗列一下,每个函数的解释可参考之前版本的介绍或者之后的实作:

1
2
3
4
5
6
7
8
9
10
11
INIT_WORK(struct work_struct *work, work_func_t func);
INIT_DELAYED_WORK(struct delayed_work *work, work_func_t func);
int schedule_work(struct work_struct *work);
int schedule_delayed_work(struct delayed_work *work, unsigned long delay);
struct workqueue_struct *create_workqueue(const char *name);
int queue_work(struct workqueue_struct *wq, struct work_struct *work);
int queue_delayed_work(struct workqueue_struct *wq, struct delayed_work *work, unsigned long delay);
void flush_scheduled_work(void);
void flush_workqueue(struct workqueue_struct *wq);
int cancel_delayed_work(struct delayed_work *work);
void destroy_workqueue(struct workqueue_struct *wq);

其中,1、2、4、7和以前略有区别,其他用法完全一样。



在对实时要求比较高的情况下,我们才会考虑在中断中采用tasklet、软中断;

而在一般的情况下,我们都是采用工作队列的方式来处理中断下半部,我们重点就来探讨一下工作队列的用法。

1.采用cpu自带的工作队列

  1)静态创建工作

#define DECLARE_WORK(n, f)
#define DECLARE_DELAYED_WORK(n, f) n
表示name,f表示func

2)代码执行时动态创建

INIT_WORK(struct work_struct *work, work_func_t func);
INIT_DELAYED_WORK(struct delayed_work *work, work_func_t func);
3)调度工作队列
int schedule_work(struct work_struct *work);
int schedule_delayed_work(struct delayed_work *work, unsigned long delay);


2.自己创建工作队列
1)静态创建工作

#define DECLARE_WORK(n, f)
#define DECLARE_DELAYED_WORK(n, f) n
表示name,f表示func

例子: static void ft5316_work(struct work_struct *work);

static DECLARE_DELAYED_WORK(tp_work,ft5316_work);

2)代码执行时动态创建

INIT_WORK(struct work_struct *work, work_func_t func);
INIT_DELAYED_WORK(struct delayed_work *work, work_func_t func);
3)创建自己的工作队列
static struct workqueue_struct *ft5316_wq; 
ft5316_wq = create_workqueue("ft5316_wq");  

4)调度自己的工作队列
int queue_work(struct workqueue_struct *wq, struct work_struct *work);
int queue_delayed_work(struct workqueue_struct *wq, struct delayed_work *work, unsigned long delay);
例子:
queue_delayed_work(ft5316_wq ,&tp_work,msecs_to_jiffies(0));  








linux input输入子系统分析《二》:s3c2440的ADC简单驱动实例分析

主要讲述本人在学习Linux内核input子系统的全部过程,如有分析不当,多谢指正。以下交流方式,文章欢迎转载,保留联系信息,以便交流。 邮箱:eabi010@gmail.com 主页:w...
  • ielife
  • ielife
  • 2012年07月29日 14:43
  • 7733

面试珠玑 tasklet和工作队列 区别

tasklet tasklet  vs  内核定时器 相同:始终在中断期间运行,始终会在调度他们的同一CPU上运行,而且都接收一个unsigned long参数不同:不可以要求tasklet在某一...
  • skdkjxy
  • skdkjxy
  • 2014年10月28日 15:52
  • 518

Linux内核中的软中断、tasklet和工作队列详解

[TOC] 本文基于Linux2.6.32内核版本。引言软中断、tasklet和工作队列并不是Linux内核中一直存在的机制,而是由更早版本的内核中的“下半部”(bottom half)演变而来。下...

底半部机制分析:软中断,tasklet,工作队列

一般在有中断的系统中,中断ISR的设计应该尽可能的小,并且在处理中断时,不允许中断ISR再被其他后来的中断打断,也就是避免中断嵌套。现在大多数系统都是不支持中断嵌套的,Linux的实现就是个典型。防止...

【转】软中断/tasklet/工作队列

软中断、tasklet和工作队列并不是Linux内核中一直存在的机制,而是由更早版本的内核中的“下半部”(bottom half)演变而来。下半部的机制实际上包括五种,但2.6版本的内核中,下半部和任...

《深入理解Linux内核》软中断/tasklet/工作队列

《深入理解Linux内核》软中断/tasklet/工作队列 软中断、tasklet和工作队列并不是Linux内核中一直存在的机制,而是由更早版本的内核中的“下半部”(bottom h...

《深入理解Linux内核》软中断/tasklet/工作队列

http://www.cnblogs.com/li-hao/archive/2012/01/12/2321084.html 软中断、tasklet和工作队列并不是Linux内核中一直存在...

《深入理解Linux内核》软中断/tasklet/工作队列

《深入理解Linux内核》软中断/tasklet/工作队列 软中断、tasklet和工作队列并不是Linux内核中一直存在的机制,而是由更早版本的内核中的“下半部”(bottom...
  • wdsfup
  • wdsfup
  • 2017年11月10日 11:24
  • 37

软中断&tasklet&工作队列

队列

软中断/tasklet/工作队列

软中断、tasklet和工作队列并不是Linux内核中一直存在的机制,而是由更早版本的内核中的“下半部”(bottom half)演变而来。下半部的机制实际上包括五种,但2.6版本的内核中,下半部和任...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:工作队列、tasklet、软中断的用法总结
举报原因:
原因补充:

(最多只允许输入30个字)