现在的位置: 首页 > 综合 > 正文

spinlock_t定义

2013年06月18日 ⁄ 综合 ⁄ 共 1001字 ⁄ 字号 评论关闭

注意:下文中的所有定义已去掉调试和统计相关的信息

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();
}

 

【上篇】
【下篇】

抱歉!评论已关闭.