内核---自旋锁
来源:互联网 发布:软件开发生命周期模型 编辑:程序博客网 时间:2024/05/22 12:28
自旋锁用于多处理器环境下保护数据。
如果内核发现数据未锁,就获取锁并运行;如果数据被锁,就一直旋转【反复执行一条指令】。
自旋锁在单处理器环境下(非抢占式内核)下,不起作用 ;单处理器抢占式内核的情况下,自旋锁起到禁止抢占的作用。
注释:
内核抢占(可抢占式内核):
即当进程位于内核空间时,有一个更高优先级的任务出现时,如果当前内核允许抢占,则可以将当前任务挂起,执行优先级更高的进程。
非抢占式内核:
高优先级的进程不能中止正在内核中运行的低优先级的进程,抢占CPU运行。
进程一旦处于核心态【eg用户进程执行系统调用】,除非进程自愿放弃CPU,否则该进程将一直运行下去,直至完成或者退出内核
q抢占式内核的意义:
Linux应用于实时操作系统,实时操作系统对响应时间有严格的规定。 当一个实时进程被实时设备的硬件中断唤醒后,应在限定的时间内被调度执行。
而Linux不能满足这一要求,因为Linux的内核是不可抢占的,不能确定系统在内核中的停留时间。事实上当内核执行长的系统调用时,实时进程要等到内核中运行的进程退出内核才能被调度,由此产生的响应延迟,在如今的硬件条件下,会长达100ms级。这对于那些要求高实时响应的系统是不能接受的。而可抢占的内核不仅对Linux的实时应用至关重要,而且能解决Linux对多媒体(video, audio)等要求低延迟的应用支持不够好的缺陷。
被自旋锁锁着的进程一直旋转,不是睡眠,所以自旋锁可以用在中断等禁止睡眠的场景。
自旋锁的使用很简单,参看一下代码
spin_lock(shost->host_lock);
shost->host_busy++;
spin_unlock(shost->host_lock);
- 内核自旋锁
- Linux内核自旋锁
- 内核自旋锁API
- 内核自旋锁spin_lock
- Linux内核自旋锁
- 内核---自旋锁
- 内核同步方法-自旋锁
- linux内核自旋锁API
- linux内核自旋锁总结
- imx6q内核之自旋锁
- Linux 内核的排队自旋锁
- 内核同步方法之自旋锁
- 内核同步方法之读写自旋锁
- 自旋锁在内核中的实现
- 内核同步之自旋锁和信号量
- 内核同步之自旋锁和信号量
- 内核同步之自旋锁和信号量
- linux内核进程调度(自旋锁)
- Python中的range函数
- 利用startActivity启动其他应用
- 2017-09-08 LeetCode_007 Reverse Integer
- C#语言和doNet框架
- HDR+bloom
- 内核---自旋锁
- 安卓系统下生成QR码(一)——自定义生成图片大小
- 使用Keras动手实践深度学习(上)
- HDU 1527 取石子游戏 威佐夫博弈 Wythoff
- javawebday03(js和html结合 基本数据类型及方法 全局函数 重载)
- jstl的c标签应用
- 海量数据处理系列之(一)Java线程池使用
- error in ./src/main.js ✘ http://eslint.org/docs/rules/quotes Strings must use singlequote
- 使用Keras动手实践深度学习(下)