博客
关于我
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/

你可能感兴趣的文章
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
Mysql8 数据库安装及主从配置 | Spring Cloud 2
查看>>
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>
Mysql8.0以上重置初始密码的方法
查看>>
mysql8.0新特性-自增变量的持久化
查看>>
Mysql8.0注意url变更写法
查看>>
Mysql8.0的特性
查看>>
MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
查看>>
MySQL8修改密码的方法
查看>>
Mysql8在Centos上安装后忘记root密码如何重新设置
查看>>
Mysql8在Windows上离线安装时忘记root密码
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>