博客
关于我
linux 等待队列
阅读量:761 次
发布时间:2019-03-23

本文共 1434 字,大约阅读时间需要 4 分钟。

Linux内核的等待队列是内核设计中的重要组成部分,它采用双循环链表的结构与进程调度机制深度结合,以实现异步事件通知的核心机制。本文将从等待队列的结构、初始化过程、等待队列的操作以及相关函数入手,对其进行详细阐述。

首先,等待队列的基本结构是多个等待队列项(wait_queue_t)通过列表头(list_head)连接而成,每个等待队列项都包含一个标志位和一个指向任务的指针。其核心数据结构包括wait_queue_head_t作为队列头,且队列头和队列项都由list_head构成,即将等待队列的头和各个项都用双链表连接起来。这种结构不仅支持同步操作,还能高效地管理等待状态。

在实现等待队列时,首先需要初始化队列头。通过调用init_waitqueue_head函数,可以将队列头的自旋锁初始化为未锁状态,并将等待队列初始化为空的双向循环链表。实际操作中,使用DECLARE_WAIT_QUEUE_HEAD宏来完成此类初始化。此外,定义等待队列项需要使用DECLARE_WAITQUEUE宏,这一步将初始化队列项的相关指针为空,确保队列的连接性。

接下来,进程进入等待队列的具体操作:首先要调用add_wait_queue函数,将当前进程加入队列中。建议在进程进入等待之前,将其状态设置为TASK_INTERRUPTIBLE或TASK_UNINTERRUPTIBLE,以便于控制进程的睡眠状态。如果选择设置为TASK_INTERRUPTIBLE,则在信号事件触发时,进程会被唤醒并进行响应;而TASK_UNINTERRUPTIBLE则会完全阻塞信号传递,直到条件满足为止。

在等待过程中,使用wait_event、wait_event_timeout等宏将进程置于等待状态。wait_event宏允许进程在条件满足时退出等待;而wait_event_timeout则附加了对最大睡眠时间的控制。如果条件在指定时间内满足,函数会返回剩余的睡眠时间;否则,继续等待。与之相对应的wait_event_interruptible和wait_event_interruptible_timeout宏则在睡眠期间响应信号传递,允许进程在信号事件下重新评估条件。

进程唤醒时,可以通过wake_up、wake_up_interruptible等函数将其从等待队列中移出。这两个函数根据不同的唤醒条件,将被唤醒的进程从队列中移除。需要注意的是,TASK_INTERRUPTIBLE状态的进程更易接受信号触发唤醒,而TASK_UNINTERRUPTIBLE状态的进程则完全不响应信号,直到条件满足时自行 唤醒。

在资源 competition 的场景中, 进程可能需要无条件睡眠。sleep_on和sleep_on_timeout等函数可用于将进程挂起,sleep_on将进程置于TASK_UNINTERRUPTIBLE状态并添加至队列中,而sleep_on_timeout则加入了对最大睡眠时间的控制。对于更高级的需求,使用interruptible_sleep_on和interruptible_sleep_on_timeout将进程状态设置为TASK_INTERRUPTIBLE,使得在信号触发时可以立即被唤醒。

以上就是 Linux 内核等待队列的核心实现方式与操作方法,通过合理搭配这些工具函数,开发者可以轻松管理进程的异步事件通知和 resources 的竞争等待。

转载地址:http://liuzk.baihongyu.com/

你可能感兴趣的文章
mysql 字段区分大小写
查看>>
mysql 字段合并问题(group_concat)
查看>>
mysql 字段类型类型
查看>>
MySQL 字符串截取函数,字段截取,字符串截取
查看>>
MySQL 存储引擎
查看>>
mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
查看>>
MySQL 存储过程参数:in、out、inout
查看>>
mysql 存储过程每隔一段时间执行一次
查看>>
mysql 存在update不存在insert
查看>>
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>
Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
查看>>
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 实现主从复制/主从同步
查看>>
mysql 审核_审核MySQL数据库上的登录
查看>>
mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
查看>>
mysql 导入导出大文件
查看>>
MySQL 导出数据
查看>>
mysql 将null转代为0
查看>>
mysql 常用
查看>>