7.3 中断屏蔽
在单核CPU范围内避免竞态的方法是在进入临界区之前屏蔽系统的中断,但在驱动编程中不值得推荐,驱动通常需要考虑跨平台特点而不假定自己在单核上运行。CPU一般都具备屏蔽中断和打开中断的功能,这项功能可以保证正在执行的内核执行路径不被中断处理程序所抢占,防止某些竞态条件的发生。具体而言,中断屏蔽将使得中断与进程之间的并发不再发生,而且,由于Linux内核的进程调度等操作都依赖中断来实现,内核抢占进程之间的并发也得以避免。
中断屏蔽的使用方法为:
<linux/irqflags.h>
local_irq_disable() /* 屏蔽中断 */
. . .
critical section /* 临界区 */
. . .
local_irq_enable() /* 开中断 */
其底层的实现原理是让CPU本身不响应中断,比如,对于ARM处理器而言,其底层的实现是屏蔽ARM CPSR的I位:
arch/arm/include/asm/irqflags.h
static inline void arch_local_irq_disable(void){
asm volatile(
" cpsid i @ arch_local_irq_disable"
:
:
: "memory", "cc");
}
由于Linux的异步I/O、进程调度等很多

最低0.47元/天 解锁文章
1605

被折叠的 条评论
为什么被折叠?



