spinlock_t定義

注意:下文中的所有定義已去掉調試和統計相關的信息

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

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章