自旋锁用于多处理器环境下保护数据。
如果内核发现数据未锁,就获取锁并运行;如果数据被锁,就一直旋转【反复执行一条指令】。
自旋锁在单处理器环境下(非抢占式内核)下,不起作用 ;单处理器抢占式内核的情况下,自旋锁起到禁止抢占的作用。
注释:
内核抢占(可抢占式内核):
即当进程位于内核空间时,有一个更高优先级的任务出现时,如果当前内核允许抢占,则可以将当前任务挂起,执行优先级更高的进程。
非抢占式内核:
高优先级的进程不能中止正在内核中运行的低优先级的进程,抢占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);