linux的poll_wait函数,等待队列和poll机制

在Linux驱动程序中可以用等待队列来实现阻塞进程的唤醒,并能用等待队列来是实现内核中的异步事件通知机制。初始化等待队列:

利用宏:DECLARE_WAIT_QUEUE_HEAD(button_queue);//定义并初始化一个名为button_queue的等待队列(等待队列的定义和初始化有具体的函数,这个宏也是替换成或调用哪些函数)。

等待事件:

wait_event(queue);

wait_event_interruptile(queue,condition);//queue是等待被唤醒的队列,condition是唤醒的条件,不满足就继续阻塞。

唤醒队列:

wake_up_interruptible(&queue);//唤醒queue等待队列中的进程

wait_event_interruptile和wake_up_interruptible一般成对使用。

例子:

16f169145b67a2b2d34a9dbf12576a55.png

51e0b4499db85c1df4071716f643be15.png

在应用程序中有一个poll和select系统调用实现对设备查询无阻塞访问,而这样的函数会引发设备驱动中的poll函数被执行。

poll机制:通过对内核代码的分析,可以将poll机制总结如下(参照韦东山第一期文档)

511de893bc544e0a8ef7cf48011908d9.png

了解了poll机制之后,在驱动程序中实现它还是挺容易的,只通过poll_wait函数将当前进程添加到指定的等待队列中。

设备驱动中的poll()函数原型:

unsigned int (*poll) (struct file *, struct poll_table_struct *);

在这个函数中,应该实现两项工作:

1.用poll_wait()函数将相应的等待队列注册到poll_table.

void poll_wait(struct file * filp, wait_queue_head_t * wait_address, poll_table *p)

//wait_address:是等待队列头

2.返回表示是否能对设备进行读、写访问的掩码

例如:

441e78049887a646be8867acac53a8ff.png

值得说明的一点是poll_wait并不是立马堵塞,而是将当前进程添加到指定的等待队列之后,由其他函数条件堵塞。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值