自旋锁
版权声明:本文为博主原创文章,未经博主允许不得转载。
https://blog.****.net/huangweiqing80/article/details/83031018
1.定义和初始化自旋锁
一个自旋锁必须初始化才能被使用,对自旋锁的初始化可以在编译阶段通过宏来实现,初始化自旋锁可以使用宏SPIN_LOCK_UNLOCKED,这个宏表示一个没有锁定的自旋锁。在Linux中,申明定义一个自旋锁:
spinlock_t spinlock = SPIN_LOCK_UNLOCKED; /*初始化一个未使用的自旋锁*/
在运行阶段,可以使用spin_lock_init函数动态的初始化一个自旋锁,这个函数的原型如下
void spin_lock_init(spinlock_t lock)
所以初始化自旋锁有两种方式。但一般使用spin_lock_init
2. 锁定(获得)自旋锁
在进入临界区前,需要使用spin_lock宏来获得自旋锁。spin_lock宏的代码如下
# define spin_lock(lock) _spin_lock(lock)
这个宏用来获得lock自旋锁,如果能够立即获得自旋锁,则宏立刻返回;否则,这个锁会一直自旋在那里,直到该锁被其他线程释放为止。
3. 释放自旋锁
当不再使用临界区时,需要使用spin_unlock宏释放自旋锁。spin_lock宏的代码如下:
# define spin_unlock(lock) _spin_unlock(lock)
这个宏用来释放lock自旋锁,当调用该宏之后,锁立刻被释放。
4. 使用自旋锁
我们要使用一个自旋锁应该有哪些步骤呢?首先是定义自旋锁,然后初始化,获得自旋锁合释放自旋锁。流程如下
spinlock_t lock;
spin_lock_init(&lock);
spin_lock(&lock);
处理临界资源
spin_unlock(&lock);
下面再来看一下在驱动代码中自旋锁是如何来使用的:
函数的具体解析可以参考下面这篇文章早期spin_lock浅析
其实都是对raw_spinlock_t->lock变量的值为0还是1进行操作
较新spin_lock
比较owner和next的值