spin_lock_bh使用

spin_lock_bh作用:

1.保护临界区

2.禁止抢占

3.禁止软中断

在软中执行函数_do_softirq()中已经使用__local_bh_disable_ip(_RET_IP_, SOFTIRQ_OFFSET)来禁止软中断了,所以CPU上执行软中断是串行执行的。

软中断的执行:

1.irq_exit()退出时可能会执行softirq

2.softirq的内核线程

软中断和进程B共享链表A,软中断修改链表A,进程B读链表A。

情况1 未使用spin_lock保护链表A:

进程B读链表A的数据。硬件中断来的时候会中断进程B,当进程B正在读取链表A的时候,硬件中断来了,此时硬件中断退出时执行irq_exit,并调用了_do_softirq()执行软中断,修改了链表A,执行完成返回进程B,进程B再次读取链表A,可能访问到NULL的数据,出现崩溃。

情况2 使用spin_lock保护链表A:

spin_lock()无法禁止软中断执行。进程B先执行spin_lock(),进入临界区,读链表A,在临界区硬件中断到来,硬件中断执行完成,执行irq_exit(),然后执行_do_softirq()进入软中断执行,软中断处理函数也去执行spin_lock(),出现死锁。

情况3 使用spin_lock_bh保护链表A:

进程B先执行spin_lock_bh(),进入临界区,读链表A,在临界区硬件中断到来,硬件中断执行完成,执行irq_exit(), 然后执行in_interrupt()判断是否禁止了软中断,由于spin_lock_bh()禁止了软中断,所有不会去执行软中断函数,返回到进程B继续执行,正常。

总结:

1、spin_lock_bh()主要用于保护其他进程上下文访问软中断函数共享的变量。

2、在软中断中其实可以用spin_lock即可,可以不用spin_lock_bh

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
spin_lock() 和 spin_lock_irqsave() 都是 Linux 内核中用于保护共享资源的自旋锁函数,它们的区别在于是否对中断进行处理。 spin_lock() 函数会获取自旋锁,并禁用本地 CPU 的中断。这意味着,如果在获取自旋锁的过程中发生了中断,中断处理程序将无法运行,直到自旋锁被释放。因此,spin_lock() 主要用于在中断被禁用的情况下保护共享资源,以防止其他 CPU 并发访问。 而 spin_lock_irqsave() 函数则会获取自旋锁,并保存本地 CPU 的中断状态。这意味着,在获取自旋锁的过程中,中断可以被触发,但是中断处理程序不能访问被保护的共享资源,因为它们也会尝试获取自旋锁。因此,spin_lock_irqsave() 主要用于在中断被启用的情况下保护共享资源。 在使用 spin_lock_irqsave() 函数时,需要在获取自旋锁的同时保存中断状态,并在释放自旋锁的同时恢复中断状态,以避免出现中断状态被篡改的情况。常见的用法是: ```c spinlock_t my_lock; unsigned long flags; spin_lock_irqsave(&my_lock, flags); // 获取自旋锁并保存中断状态 // 在这里进行对共享资源的访问 spin_unlock_irqrestore(&my_lock, flags); // 释放自旋锁并恢复中断状态 ``` 总之,spin_lock() 适用于在禁用中断的情况下保护共享资源,而 spin_lock_irqsave() 适用于在启用中断的情况下保护共享资源,它们的使用方式略有不同,需要根据具体情况选择合适的函数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

byd yes

你的鼓励是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值