unsigned int flag;
local_irq_save(&flag);
... ... ... ...
local_irq_restore(&flag);
spin_loc_irqsave 禁止中断(只在本地处理器)在获得自旋锁之前; 之前的中断状态保存在 flags 里. 如果你绝对确定在你的处理器上没有禁止中断的(或者, 换句话说, 你确信你应当在你释放你的自旋锁时打开中断), 你可以使用 spin_lock_irq 代替, 并且不必保持跟踪 flags. 最后, spin_lock_bh 在获取锁之前禁止软件中断, 但是硬件中断留作打开的。感觉现在自己对互斥和中断的关系给搞糊涂了......例如出现这样的情况,在进入临界区后,发生了一个中断在进入中断处理函数中,也需要临界区的资源,但是它获得不了,是不是这个中断处理函数被挂起到等待队列中呢?还是产生了死锁呢?
