Linux内核:Spinlock SMP:为​​什么spin_lock_irq SMP版本中有preempt_disable()?

前端之家收集整理的这篇文章主要介绍了Linux内核:Spinlock SMP:为​​什么spin_lock_irq SMP版本中有preempt_disable()?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
linux内核中的原始代码是:
static inline void __raw_spin_lock_irq(raw_spinlock_t *lock)
{
    local_irq_disable();
    preempt_disable();
    spin_acquire(&lock->dep_map,_RET_IP_);
    LOCK_CONTENDED(lock,do_raw_spin_trylock,do_raw_spin_lock);
}

我认为在禁用本地IRQ之后,没有执行路径可以抢占当前路径.

因为所有常见的硬IRQ都被禁用,所以不应该出现softirq,也没有勾选计划轮.我认为当前的道路是安全的.那么为什么会有preempt_disable()?

谢谢.

解决方法

据我所知,preempt_disable()调用在2002年12月4日被Dave Miller添加到了很多锁定原语中,包括spin_lock_irq,并在2.5.51中发布.提交消息没有帮助;它只是说“[SPINLOCK]:修复非SMP nopping spin / rwlock宏.”

我相信Proper Locking Under a Preemptible Kernel文档很好地解释了这一点.最后一节标题为“预防使用中断禁用的预防”开始,

It is possible to prevent a preemption event using local_irq_disable and
local_irq_save.  Note,when doing so,you must be very careful ...

猜你在找的Linux相关文章