LINUX系統有大量的資源,內核在使用這些資源時會發生競爭,在內核開發的時候為避免競爭的發生,通常用信號量來解決.
在LINUX2.6內核中提供了一些信號量的操作,信號量的操作包含在#include<asm/semaphore.h>頭文件中
DECLARE_MUTEX(name);
#申明一個名為name信號量 并該信號量被初始化為1.
DECLARE_MUTEX_LOCKED(name);
#申明一個名為name信號量 并該信號量被初始化為0.
#對于一個動態分配的信號量用下面兩個函數對信號量進行初始化
void init_MUTED(struct semaphore *sem);
void init_MUTED_LOCKED(struct semaphore *sem);
對于信號量的操作一般采用原語操作,或者稱為P操作和V操作.在LINUX中用down函數來完成P操作.對信號量減1,如果信號量小于1,說明申請資源被占用,調用者則進入睡眠,相反資源可以利用,占用資源.up函數完成相應的V操作.信號量被使用結束后要釋放信號量,釋放信號量由up函數完成,一但調用up函數,資源的使用者不在持有信號量,退出資源.up函數對信號量加一.對于down函數有三個不同的函數,第一個在調用down函數期間不可中斷,第二個則允許在down函數調用期間被中斷,down_trylock則不睡眠,如果在調用期間沒有信號量個可以獲得,則立即返回一個非零值.
void down(struct semaphore *sem );
int down_interruptible(struct semaphore *sem);
int down_trylock(struct semaphore *sem);
void up(struct semaphore *sem)
LIUNX中還提供了信號量的讀寫函數,用這些函數必須包含 <linux/rwsem.h>頭文件.
struct rw_semaphore;
在讀寫信號量時必須先初始化,init_rwsem為初始化函數.
init_rwsem(struct rw_semaphore *sem);
down_read函數提供對被保護的資源只讀操作,
void down_read(struct rw_semaphore *sem)
int down_read_trylock(struct rw_semaphore *sem)
void up_read(struct rw_semaphore *sem);
int down_write(struct rw_semaphore *sem)
int down_write_trylock(struct rw_semaphore *sem);
void downgrade_write(struct rw_semaphore *sem);