RT-Thread的workqueue功能跟linux上的workqueue是类似的。我们知道在中断中,不能休眠阻塞,不宜做大运算等等,中断要尽可能的快,中断中我们一般只是用来做一些标志等,将业务逻辑处理放到其他地方,Linux中提供了tasklet和workqueue,RTT中只有workqueue。我们可以将不是很紧急处理的事情放到workqueue中处理,等待系统空闲时就会去执行workqueue里的事情。实际上就是开一条线程去处理,所以workqueue的消耗也是比较大的。
work queue的作用就是将工作往后延迟, work queue是一种bottom half,中断处理的后半程。
代码示例
下面就直接看代码了。
#include <ipc/workqueue.h>
//struct rt_workqueue *rt_workqueue_create(const char *name, rt_uint16_t stack_size, rt_uint8_t priority);
struct rt_workqueue *wq = RT_NULL;
struct rt_work work;
int work_data = 0xaa;
//回调函数。系统空闲时就会执行,只会执行一次,允许delay。
void work_func(struct rt_work *work, void *param)
{
rt_kprintf("hello wq! param : %#x, tick : %ld\n", *(int *)param, rt_tick_get());
}
int workqueue_test(void)
{
int res;
wq = rt_workqueue_create("my_wq", 256, 15)
if (wq == RT_NULL)
goto ERR
rt_work_init(&work, work_func, &work_data)
rt_kprintf("dowork tick : %ld\n", rt_tick_get())
res = rt_workqueue_dowork(wq, &work)
return res
ERR:
return -1;
}
原作者:上发条
|