这段代码仍然处于 lock1 的临界区,如果此时硬件中断也需要申请 lock1 锁会导致死锁,这是因为 spin_unlock_irq 在解锁时一定会将本地 CPU 的中断打开,从而导致硬件中断可以重新强制抢占 CPU,所以最好的方式就是 lock2 在锁之前保存当前的中断状态,在解锁时恢复当前的中断状态,这也就是 spin_lock_irqsave 需要...
releases the lock. 2.3 spin_lock_irqsave i. 在关cpu preempt 和irq 基础之上保存irq 之前的状态,这样恢复临界区之前的中断状态。 ii. 如果存在嵌套地 disable 中断,就需要使用spin_lock_irqsave接口 spin_lock_irq(&lock1);/*---临界区1*/spin_lock_irq(&lock2);/*---临界区2*/.../*---临界区...
但是spin_lock_irq则不管之前的开还是关,返回时都是开的。 spin_lock_irq 和 spin_unlock_irq, 如果你确定在获取锁之前本地中断是开启的,那么就不需要保存中断状态,解锁的时候直接将本地中断启用就可以了。 spin_lock和spin_lock_irq在特殊情况下会导致死锁,spin_lock_irqsave是最安全的。 5、自旋锁的使用场...
内核编程中常常需要用到自旋锁,请简述spin_lock(),spin_lock_irq()和spin_lock_irqsaveO之间的区别,并说明它们的使用场合。
在任何情况下使用spin_lock_irq都是安全的。因为它既禁止本地中断,又禁止内核抢占。 spin_lock比spin_lock_irq速度快,但是它并不是任何情况下都是安全的。 spin_lock_irqsave spin_lock_irqsave--->__raw_spin_lock_irqsave 1staticinlineunsignedlong__raw_spin_lock_irqsave(raw_spinlock_t*lock) ...
spin_lock_irq--->raw_spin_lock_irq spin_lock_irq 和 spin_unlock_irq, 如果你确定在获取锁之前本地中断是开启的,那么就不需要保存中断状态,解锁的时候直接将本地中断启用就可以啦 3. spin_lock_irqsave/spin_unlock_irqrestore 使用spin_lock_irqsave在于你不期望在离开临界区后,改变中断的开启/关闭状态!
1、spin_lock与spin_lock_irq区别 在Linux内核中何时使用spin_lock,何时使用spin_lock_irqsave很容易混淆。首先看一下代码是如何实现的。 spin_lock的调用关系 spin_lock | + ---> raw_spin_lock | +---> _raw_spin_lock | +---> __raw_spin_lock 1. 2. 3. 4...
spin_lock_irq--->raw_spin_lock_irq spin_lock_irq 和 spin_unlock_irq, 如果你确定在获取锁之前本地中断是开启的,那么就不需要保存中断状态,解锁的时候直接将本地中断启用就可以啦 3. spin_lock_irqsave/spin_unlock_irqrestore 使用spin_lock_irqsave在于你不期望在离开临界区后,改变中断的开启/关闭状态!
spin_lock_irqsave在进入临界区前,保存当前中断寄存器flag状态,关中断,进入临界区,在退出临界区时,把保存的中断状态写回到中断寄存器。 spin_lock_irq在进入临界区前不保存中断状态,关中断,进入临界区,在退出临界区时,开中断。 spin_lock_irqsave锁返回时,中断状态不会被改变,调用spin_lock_irqsave前是开中断返回...
linux-kernel之spin_lock_irqsave和spin_lock_irq 在SMP机器上,我们必须使用spin_lock_irqsave而不是来自中断上下文的spin_lock_irq。 为什么我们要保存标志(包含IF)? 是否有另一个中断例程可以中断我们? 请您参考如下方法: 我是内核的新手,但是从我从罗伯特·洛夫(Robert Love)的书“Linux Kernel Development”(...