在内核中唯一允许睡眠的锁是信号量。信号量适用于那些比较复杂的,未名情况下的互斥访问。
为了找到一个更简单的睡眠锁,内核开发者们引入了互斥体(mutex)。
mutex这个称谓是指的是任何可以睡眠的强制互斥锁。
mutex简洁和高效源自于相比使用信号量更多的受限性。
1、任何时刻中只有一个任务有持有mutex,也就是mutex的使用计数永远是1;
2、给mutex上锁者必须负责给其再解锁。这个限制使得mutex不适合内核同用户控件复杂的同步场景
3、递归的上锁和解锁是不允许的;
4、当持有一个mutex时,进程不可以退出;
5、mutex不能中断或下半部中使用,即使使用mutex_trylock()也不行;
6、mutex只能通过官方的API管理;
信号量和互斥体的关系:
除非mutex的某个约束妨碍你使用,否则相比信号量要优先使用mutex。
自旋锁和互斥体:
在中断上下文中只能使用自旋锁,而在任务睡眠时只能使用mutex。