Android深度探索:HAL与驱动开发学习笔记--并发控制之信号量&完成量

本文深入探讨了Android驱动开发中并发控制的两种方法:信号量和完成量。通过示例代码,展示了如何使用信号量进行设备打开的同步,并解释了完成量作为更优的同步手段。同时,文中还包含了读写信号量的实践应用。
摘要由CSDN通过智能技术生成
semaphore
使用方法和自旋锁类似,与自旋锁相同,只有得到信号量的进程才能执行临界区代码,但是与自旋锁不同的是当获取不到信号量时,进程不原地打转而是进入休眠等待状态。

1. 函数:

声明变量
struct semaphore sem;
快捷方式:
DECLARE_MUTEX(name) /* 定义一个名为name的信号量并初始化为1 */
DECLARE_MUTEX_LOCKED(name) /* 定义一个名为name的信号量并初始化为0 */
信号量的初始化
void sema_init(struct semaphore *sem,int val);
参数:
sem,信号量
val,信号量的数量
信号量的获取 : --相当于PV操作中的 P 操作
void down(struct semaphore *sem);  -->深度睡眠(没有资源时深度睡眠,无法被唤醒,只有资源来时才醒,是睡眠等待)
int down_interruptible(struct semaphore *sem);  -->可以被唤醒(浅睡)
int down_trylock(struct semaphore *sem); --> 如果能获得,获得,并返回0,否则,返回非0
if(down_interruptible(&sem))
return -ERESTARTSYS;

信号量的释放 : --相当于PV操作中的 V 操作
void up(struct semaphore *sem);

2. 使用格式:

/* 定义信号量 */
DECLARE_MUTEX(mount_sem);
down(&mount_sem); /* 获取信号量,保护临界区 */
...
critical section /* 临界区 */
...
up(&mount_sem); /* 释放信号量 */

3. 例子:

使用信号量实现只能被一个进程打开:

[cpp]  view plain  copy
 
 
  1. static DECLARE_MUTEX(xxx_lock); /* 定义互斥锁 */  
  2. static int xxx_open(struct inode *inode, struct file *filp)  
  3. {  
  4.     ...  
  5.     if(down_trylock(&xxx_lock)) /* 获取打开锁 */  
  6.         return -EBUSY; /* 设备忙 */  
  7.     ...  
  8.     return 0; /* 成功 */  
  9. }  
  10.   
  11. static int xxx_release(struct inode *inode, struct file *filp)  
  12. {  
  13.     up(&xxx_lock); /* 释放打开锁 */  
  14.     return 0;  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值