注意:下文中的所有定义已去掉调试和统计相关的信息
spinlock_types.h (include\linux)
typedef struct spinlock {
union {
struct raw_spinlock rlock;
};
} spinlock_t;
typedef struct raw_spinlock {
arch_spinlock_t raw_lock;
} raw_spinlock_t;
spinlock_types.h (arch\arm\include\asm)
typedef struct {
volatile unsigned int lock;
} arch_spinlock_t;
代码中的spinlock_t,就是在多处理器之间共享的自旋锁在现实源码中的具体体现,透过层层定义,会发现它实际上就是个volatile unsigned int型变量
下面是Linux源码中提供给设备驱动程序等内核模块使用的spin_lock接口函数的定义:
spinlock.h (include\linux)
static inline void spin_lock(spinlock_t *lock)
{
raw_spin_lock(&lock->rlock);
}
spin_lock函数中调用的raw_spin_lock是个宏,其实现十处理器相关的,对于ARM处理器而言,最终展开为:
static inline void raw_spin_lock(raw_spinlock_t *lock)
{
preempt_disable();
do_raw_spin_lock(lock);
}
与spin_lock相对的是spin_unlock函数,这是一个应该在离开临界区时调用的函数,用来释放此前获得的自旋锁,其外部接口定义如下:
spinlock.h (include\linux)
static inline void spin_unlock(spinlock_t *lock)
{
raw_spin_unlock(&lock->rlock);
}
static inline raw_spin_unlock(raw_spinlock_t *lock)
{
do_raw_spin_unlock(lock);
preempt_enable();
}