i.MX6ULL终结者Linux并发与竞争中断屏蔽

在单CPU的情况下避免竞争的一种简单有效的方法就是在进入临界区之前屏蔽系统的中断,CPU一般都具有屏蔽中断和打开中断的功能,这项功能可以保证正在被执行的单元不被中断处理程序多抢占,防止某些竞争条件的发生。具体而言,中断屏蔽是的中断和进程之间的并发不在发生,由于Linux内核的进程调度等操作都依赖中断实现,内核抢占进程之间的并发也能够避免。
与中断屏蔽相关的函数:

local_irq_disable();		//屏蔽中断
local_irq_enable();		//打开中断	
local_irq_save(flags);		//禁止中断并保存当前CPU中断信息
local_irq_restore(flags)//打开中断并回复之前保存的CPU中断信息

上面两组函数都是成对使用的,local_irq_disable和local_irq_enable是一对函数,local_irq_save和local_irq_restore是一对函数。函数定义在include/linux/irqflags.h文件中。
由于Linux的异步I/O、进程调度等很多重要操作都依赖于中断,中断对于内核的运行非常重要,在屏蔽中断期间所有的中断都无法得到处理,因此长时间屏蔽中断是很危险的,这有可能造成数据丢失乃至系统崩溃等后果。这就要求在屏蔽了中断之后,当前的内核执行路径应当尽快地执行完临界区的代码。
local_irq_disable()和local_irq_enable()都只能禁止和使能本CPU内的中断,因此,并不能解决SMP多CPU引发的竞态。因此,单独使用中断屏蔽通常不是一种值得推荐的避免竞态的方法(换句话说,驱动中使用local_irq_disable/enable()通常意味着一个bug),它适合与下文将要介绍的自旋锁联合使用。
与local_irq_disable()不同的是,local_irq_save(flags)除了进行禁止中断的操作以外,还保存目前CPU的中断位信息,local_irq_restore(flags)进行的是与local_irq_save(flags)相反的操作。

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值