Linux原子操作

并发问题

现代操作系统支持多任务的并发,并发在提高计算资源利用率的同时也带来了资源竞争的问题。假如一个任务正在读取文件一的情况下,此时又有另一个任务想要读取文件一,会造成读取混乱问题。可以使用原子操作实现资源互斥。

原子操作

原子操作指的是在执行过程中不会被别的代码路径所中断的操作。

1.设置原子变量的值
void atomic_set(atomic_t *v, int i); //设置原子变量的值为 i 

atomic_t v = ATOMIC_INIT(0); //定义原子变量 v 并初始化为 0 
2.获取原子变量的值
atomic_read(atomic_t *v); //返回原子变量的值
3.原子变量加/减
void atomic_add(int i, atomic_t *v); //原子变量增加 i 

void atomic_sub(int i, atomic_t *v); //原子变量减少 i 
4.原子变量自增/自减
void atomic_inc(atomic_t *v); //原子变量增加 1 

void atomic_dec(atomic_t *v); //原子变量减少 1 
5.操作并测试
int atomic_inc_and_test(atomic_t *v); 

int atomic_dec_and_test(atomic_t *v); 

int atomic_sub_and_test(int i, atomic_t *v); 

上述操作对原子变量执行自增、自减和减操作后测试其是否为 0, 为 0 则返回 true,否则返回 false。

修改代码

定义原子变量

static atomic_t demo_avaliable = ATOMIC_INIT(1);

修改open函数:如果没有进程在使用该驱动 ,原子变量值 为 1 ,将原子变量减 一 为 0 ,函数返回 true ,再 !true 为 假 ,if 里面的代码不执行;这样打开了、并使用该驱动, 原子变量变为 0;

如果再有进程来打开驱动程序,0-1 = 负1,返回 false ,if 条件成立,运行里面的代码,将原子变量加一恢复到 0,程序返回;

static int demo_open(struct inode *node, struct file *file){
    
    printk(KERN_INFO"Enter:%s\n",__func__);
    if(!atomic_dec_and_test(&demo_avaliable)){
        printk(KERN_ERR"already open\n");
        atomic_inc(&demo_avaliable);
        return -EBUSY;
    }

    file->private_data =(void*) demo_dev; 
    return 0;
}

修改release函数

static int demo_release(struct inode *node, struct file *file){
    printk(KERN_INFO"Enter:%s\n",__func__);
    atomic_inc(&demo_avaliable);
    return 0;
}

在应用程序退出时 close 函数, 自增 恢复原子变量值为 1。

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值