相对于自旋锁,信号量的最大特点是允许调用它的线程可以进入休眠,这意味着试图获得某一信号量的进程会导致处理器拥有权的丧失,也即出现进程的切换。
驱动程序中定义了一个信号量,不是直接对其赋值,而是应该使用 sema_init(struct semaphore *sema, int val )进行初始化,初始化吧信号量的自旋锁设置为unlock, count = val,同事初始化表头。
信号量结构体:
struct semaphore {
spinlock_t lock;
unsighned int count;
struct list_head wait_list;
}
down操作:判断是否可以进入临界区,count>0,可以进入,count --,
内核中down操作函数有
void down(struct semaphore *sem);//除非必要,一般不使用
void down_interrputable(struct semaphore *sem);//一般使用这个
void down_killable(struct semaphore *sem);
void down_trylock(struct semaphore *sem);//获得信号量返回0;无法获得信号量,返回1
void down_timeout(struct semaphore *sem);
up操作
进行up(),如果信号量sem的wait_list为空,则没有其他的进程在等待该信号量,count++;如果wait_list 不为空,说明有其他的进程在等待信号量,此时调用_up()唤醒进程。
即使不是信号量的拥有者也可以UP操作。