Linux系统中的自旋锁(两幅图清晰说明)

在这里插入图片描述
在这里插入图片描述
总结:
多CPU下的自旋锁采取的是忙等待(原地打转)机制,虽然忙等待的线程占用了它所在的cpu,但其他线程仍可放到其他CPU上执行。所以自旋锁上锁和解锁之间的临界区代码要尽量的短,最好不要超过5行,否则采取忙等待的线程会浪费过多的cpu资源。

单cpu下的自旋锁采用的是睡眠机制,因为忙等待会使仅有可怜的一个cpu被其占用,而拥有自旋锁的线程得不到执行无法释放锁,会引起死锁。


关于自旋锁的一些函数接口

spin_lock函数在内核文件include\linux\spinlock.h中声明,如下表:

函数名 作用
spin_lock_init(_lock) 初始化自旋锁为unlock状态
void spin_lock(spinlock_t *lock) 获取自旋锁(加锁),返回后肯定获得了锁
int spin_trylock(spinlock_t *lock) 尝试获得自旋锁,成功获得锁则返回1,否则返回0
void spin_unlock(spinlock_t *lock) 释放自旋锁,或称解锁
int spin_is_locked(spinlock_t *lock) 返回自旋锁的状态,已加锁返回1,否则返回0

自旋锁的加锁、解锁函数是:spin_lockspin_unlock,还可以加上各种后缀,这表示在加锁或解锁的同时,还会做额外的事情:

后缀 描述
_bh() 加锁时禁止下半部(软中断),解锁时使能下半部(软中断)
_irq() 加锁时禁止中断,解锁时使能中断
_irqsave/restore() 加锁时禁止并中断并记录状态,解锁时恢复中断为所记录的状态

猜你喜欢

转载自blog.csdn.net/HuangChen666/article/details/132199903