如果你需要禁止所有中断如何? 在 2.6 内核, 可能关闭在当前处理器上所有中断处理, 使用任一个下面 2 个函数(定义在 <asm/system.h>):
void local_irq_save(unsigned long flags); void local_irq_disable(void);
一个对 local_irq_save 的调用在当前处理器上禁止中断递交, 在保存当前中断状态到 flags 之后. 注意, flags 是直接传递, 不是通过指针. local_irq_disable 关闭本地中 断递交而不保存状态; 你应当使用这个版本只在你知道中断没有在别处被禁止.
完成打开中断, 使用:
void local_irq_restore(unsigned long flags); void local_irq_enable(void);
第一个版本恢复由 local_irq_save 存储于 flags 的状态, 而 local_irq_enable 无条 件打开中断. 不象 disable_irq, local_irq_disable 不跟踪多次调用. 如果调用链中有 多于一个函数可能需要禁止中断, 应该使用 local_irq_save.
在 2.6 内核, 没有方法全局性地跨整个系统禁止所有的中断. 内核开发者决定, 关闭所 有中断的开销太高, 并且在任何情况下没有必要有这个能力. 如果你在使用一个旧版本驱 动, 它调用诸如 cli 和 sti, 你需要在它在 2.6 下工作前更新它为使用正确的加锁
[37] 尽管, 一些大系统明确使用中断平衡机制来在系统间分散中断负载.
[38] 这个 shortint 设备完成它的任务, 通过交替地写入 0x00 和 0xff 到并口.