在Linux的内核态和用户态都有信号量,使用也不同,简单记录一下。
1> 内核信号量,由内核控制路径使用。
内核信号量是struct semaphore类型的对象,它在中定义
struct semaphore {
atomic_t count;
int sleepers;
wait_queue_head_t wait;
}
内核信号量的相关函数
初始化:
void sema_init (struct semaphore *sem, int val);
申请内核信号量所保护的资源:
void down(struct semaphore * sem); // 可引起睡眠
释放内核信号量所保护的资源:
void up(struct semaphore * sem);
2> 用户态信号量分为两种,一种为POSIX,另一种为 SYSTEM V
POSIX信号量的引用头文件是,而SYSTEM V信号量的引用头文件是从使用的角度,System V信号量是复杂的,而Posix信号量是简单。比如,POSIX信号量的创建和初始化或PV操作就很非常方便。
这里只是简单列举POSIX信号量
int sem_init(sem_t *sem, int pshared, unsigned int value); // 其中sem是要初始化的信号量;pshared为0,表示线程间共享。为非零值,表示在进程间共享;value是信号量的初始值。
int sem_wait(sem_t *sem); // 如果信号量大于1,该函数对信号量减1,然后立即返回;如果信号量是0,就会阻塞,直到信号量大于0。该函数返回0,表示成功;返回-1,表示失败,且sem值不会被改变。
int sem_post(sem_t *sem); //把指定的信号量sem的值加1; 呼醒正在等待该信号量的任意线程。该函数成功时,返回0;失败时,返回-1,且sem值不会被改变
以上内容均摘录博客:inux 内核信号量 用户态信号量 详解
https://blog.csdn.net/weed_hz/article/details/8965733?utm_source=blogxgwz1
相关文章:
Linux用户态的信号量
https://blog.csdn.net/zhang_shuai_2011/article/details/7653750
linux内核态和用户态之间相互通信
https://www.cnblogs.com/charlesblc/p/6261918.html