《Linux设备驱动开发详解》-- 互斥体(mutex)
尽 管 信号 量 已经 可 以实现互斥 的 功 能 , 而 且 包含 DECLARE_MUTEX() 、init_MUTEX ()等定义信号量的宏或函数, 从名字上看就体现出了互斥体的概念, 但是mutex 在 Linux 内核中还是真实地存在的。下面代码定义名为 my_mutex 的互斥体并初始化它。struct mutex my_mutex;
·
尽管信号量已经可以实现互斥的功能,而且包含 DECLARE_MUTEX() 、init_MUTEX ()等定义信号量的宏或函数, 从名字上看就体现出了互斥体的概念, 但是mutex 在 Linux 内核中还是真实地存在的。
下面代码定义名为 my_mutex 的互斥体并初始化它。
下面代码定义名为 my_mutex 的互斥体并初始化它。
struct mutex my_mutex;
mutex_init(&my_mutex);
下面的两个函数用于获取互斥体。
void fastcall mutex_lock(struct mutex *lock);
int fastcall mutex_lock_interruptible(struct mutex *lock);
int fastcall mutex_trylock(struct mutex *lock);
mutex_lock()与 mutex_lock_interruptible()的区别和 down()与 down_trylock()的区别完全一致,前者引起的睡眠不能被信号打断,而后者可以。mutex_trylock()用于尝试获得 mutex,获取不到 mutex 时不会引起进程睡眠。
下列函数用于释放互斥体。
void fastcall mutex_unlock(struct mutex *lock);
mutex 的使用方法和信号量用于互斥的场合完全一样,如下所示:
struct mutex my_mutex; //定义 mutex
mutex_init(&my_mutex); //初始化 mutex
mutex_lock(&my_mutex); //获取 mutex
...//临界资源
mutex_unlock(&my_mutex); //释放 mutex
更多推荐
已为社区贡献1条内容
所有评论(0)