Linux驱动并发处理---互斥体(用处最多)

互斥体

尽管信号量已经可以实现互斥的功能,而且包含 DECLARE_MUTEX() 、init_MUTEX ()等定义信号量的宏或函数,从名字上看就体现出了互斥体的概念,但是mutex 在 Linux 内核中还是真实地存在的。 

下面代码定义名为 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 的使用方法和信号量用于互斥的场合完全一样,如下所示: 

[html]  view plain  copy
  1. struct mutex my_mutex; //定义 mutex   
  2. mutex_init(&my_mutex); //初始化 mutex   
  3.   
  4. mutex_lock(&my_mutex); //获取 mutex   
  5. ...//临界资源   
  6. mutex_unlock(&my_mutex); //释放 mutex 

你可能感兴趣的:(Linux驱动并发处理---互斥体(用处最多))