内核---自旋锁

来源:互联网 发布:软件开发生命周期模型 编辑:程序博客网 时间: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);



原创粉丝点击