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