并发与竞态

linux是一个多任务的操作系统,在多个进程同时运行时,就有可能为了竞争同一个资源发生堵塞。以下是解决的几种方法

1:信号量

DECLARE_MUTEX(sem);
if(down_interruptible(&sem))
{
return –ERESTARTSYS;
}
//critical section
up(&sem);

2:完成量

DECLARE_COMPLETION(xxx_comp);
ssize_tcomplete_read(structfile *filp,
char __user *buf,size_tcount,
loff_t *pos)
{
wait_for_completion(&xxx_comp);
return 0; 
}
ssize_tcomplete_write(structfile *filp,
const char __user *buf,size_tcount,
loff_t *pos)
{
complete(&xxx_comp);
return count;
}

3:自选锁

spinlock_tlock;
spin_lock_init(&lock);
spin_lock(&lock);
//critical section
spin_unlock(&lock);


4:中断屏蔽

local_irq_disable();
//critical section
local_irq_enable();


其他还有原子操作等。这几种方法用法很简单,信号量用的最多,但有些场合不适用,具体我也不是很懂

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值