在驱动中经常需要使用自旋锁来确保一个固定序列操作不被打断。
/* 初始化锁x为,非锁定状态 */
spin_lock_init(x);
/* 可以用在中断中的,锁的处理 */
/* 如下不会改变中断当前状态 */
int flags;
spin_lock_irqsave(&x, flags);
spin_unlock_irqrestore(&x, flags);
/* 如下会改变中断当前状态 */
spin_lock_irq(&x);
spin_unlock_irq(&x);
/* 不会用在中断中的,锁的处理,*/
/* 比可能用在中断中的锁速度更快,少了开关中断的操作 */
spin_lock(&x, flags);
spin_unlock(&x, flags);
/* 以上是对于多core处理器来说的,对于单core,可以用直接关闭或打开中断就行。 */

本文介绍了自旋锁的基本概念及其在不同场景下的应用方法。详细解释了如何初始化自旋锁,并展示了在多核处理器环境中如何使用自旋锁进行同步操作。此外,还对比了在中断上下文中使用自旋锁的不同方式及其性能差异。
167

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



