博客
关于我
Linux驱动之 内核最常见的自旋锁及死锁产生
阅读量:398 次
发布时间:2019-03-05

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

Linux 内核中最常见的锁就是 Spinlock 自旋锁,自旋锁是“原地等待”的方式解决资源冲突的,即一个线程获取了一个自旋锁后,另外一个线程期望获取该自旋锁,获取不到,只能够原地“打转”(忙等待)。

自旋锁的主要优点在于不会使线程状态发生切换,始终保持在线程—直状态,减少了不必要的上下文切换,执行速度更快。与非自旋锁相比,非自旋锁在获取不到锁的时候会进入阻塞状态,从而进入内核态,当获取到锁的时候需要从内核态恢复,需要线程上下文切换,这会导致系统在用户态与内核态之间来回切换,严重影响锁的性能。

自旋锁的使用场景也有一些需要注意的事项:进程拥有自旋锁的时候,该cpu上是禁止抢占的。自旋锁通常用于多cpu之间的资源竞争,由于自旋锁的这个忙等待的特性,注定了它使用场景上的限制。自旋锁不应该被长时间的持有(消耗 CPU资源),一般应用在中断上下文。

自旋锁死锁的2种情况:

  • 拥有自旋锁的进程A在内核态阻塞了,内核调度B进程,碰巧B进程也要获得自旋锁,此时B只能自旋转。而此时抢占已经关闭,不会调度A进程了,B永远自旋产生死锁。
  • 进程A拥有自旋锁,中断到来,CPU执行中断函数,中断处理函数需要获得自旋锁,访问共享资源,此时无法获得锁,也只能自旋,产生死锁。
    这种情况下只会在单CPU系统中出现死锁现象。
  • 要避免自旋锁死锁,可以采取以下措施:

  • 如果中断处理函数中也要获得自旋锁,那么驱动程序需要在拥有自旋锁时禁止中断。
  • 自旋锁必须在可能的最短时间内拥有。
  • 避免某个获得锁的函数调用其他同样试图获取这个锁的函数,否则代码就会死锁。不论是信号量还是自旋锁,都不允许锁拥有者第二次获得这个锁,如果试图这么做,系统将挂起。
  • 锁的顺序规则:
    a) 按同样的顺序获得锁;
    b) 如果必须获得一个局部锁和一个属于内核更中心位置的锁,则应该首先获取自己的局部锁;
    c) 如果我们拥有信号量和自旋锁的组合,则必须首先获得信号量;在拥有自旋锁时调用 down(可导致休眠)是个严重的错误。
  • 信号量和自旋锁的选择问题:

    信号量是进程级的,用于多个进程之间对资源的互斥。如果竞争失败,会发生进程上下文切换,因为进程上下文切换的开销比较大,因此,只有当进程占用资源时间较长时,选用信号量才是较好的选择。
    如果访问临界资源的时间较短,用自旋锁是非常方便的,它不会引起进程睡眠而导致上下文切换。
    如果访问临界资源的时间较长,则选用信号量,否则选用自旋锁。
    信号量所保护的临界资源区可包含可能引起阻塞的代码,而自旋锁则绝对要避免这样的代码,阻塞意味着需要进程上下文切换,如果进程被切换出去,这个时候如果另外一个进程想获得自旋锁的话,会引起死锁。
    信号量存在于进程上下文,因此,如果被保护的资源需要在中断或者软终端情况下使用,则只能选择自旋锁。

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

    你可能感兴趣的文章
    OSPF在什么情况下会进行Router ID的重新选取?
    查看>>
    OSPF在大型网络中的应用:高效路由与可扩展性
    查看>>
    OSPF太难了,这份OSPF综合实验请每位网络工程师查收,周末弯道超车!
    查看>>
    OSPF技术入门(第三十四课)
    查看>>
    OSPF技术连载10:OSPF 缺省路由
    查看>>
    OSPF技术连载11:OSPF 8种 LSA 类型,6000字总结!
    查看>>
    OSPF技术连载12:OSPF LSA泛洪——维护网络拓扑的关键
    查看>>
    OSPF技术连载13:OSPF Hello 间隔和 Dead 间隔
    查看>>
    OSPF技术连载14:OSPF路由器唯一标识符——Router ID
    查看>>
    OSPF技术连载15:OSPF 数据包的类型、格式和邻居发现的过程
    查看>>
    OSPF技术连载16:DR和BDR选举机制,一篇文章搞定!
    查看>>
    OSPF技术连载17:优化OSPF网络性能利器——被动接口!
    查看>>
    OSPF技术连载18:OSPF网络类型:非广播、广播、点对多点、点对多点非广播、点对点
    查看>>
    OSPF技术连载19:深入解析OSPF特殊区域
    查看>>
    SQL Server 复制 订阅与发布
    查看>>
    OSPF技术连载20:OSPF 十大LSA类型,太详细了!
    查看>>
    OSPF技术连载21:OSPF虚链路,现代网络逻辑连接的利器!
    查看>>
    OSPF技术连载22:OSPF 路径选择 O > O IA > N1 > E1 > N2 > E2
    查看>>
    OSPF技术连载2:OSPF工作原理、建立邻接关系、路由计算
    查看>>
    OSPF技术连载5:OSPF 基本配置,含思科、华为、Junifer三厂商配置
    查看>>