自旋锁

版权声明:本文为博主原创文章,未经博主允许不得转载。
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的值