Linux 并发与竞争(九)

文章介绍了Linux内核中用于多线程同步的两种机制:原子操作和自旋锁。在原子操作部分,详细列出了如atomic_set、atomic_inc等函数的使用,这些函数用于无中断地修改变量值。自旋锁则通过spin_lock_irqsave和spin_unlock_irqrestore进行锁定和解锁,确保在锁住期间其他线程不会执行相关代码段。
摘要由CSDN通过智能技术生成

1.原子操作

1.定义一个原子变量

atomic_t lock; /* 原子变量

2.初始化原子变量

atomic_set(&gpioled.lock, 1); /* 原子变量初始值为 1 */

3.使用的时候判断原子变量的值

函数描述
ATOMIC_INIT(int i)定义原子变量的时候对其初始化。
int atomic_read(atomic_t *v)读取 v 的值,并且返回。
void atomic_set(atomic_t *v, int i)向 v 写入 i 值。
void atomic_add(int i, atomic_t *v)给 v 加上 i 值。
void atomic_sub(int i, atomic_t *v)从 v 减去 i 值。
void atomic_inc(atomic_t *v)给 v 加 1,也就是自增。
void atomic_dec(atomic_t *v)从 v 减 1,也就是自减
int atomic_dec_return(atomic_t *v)从 v 减 1,并且返回 v 的值。
int atomic_inc_return(atomic_t *v)给 v 加 1,并且返回 v 的值。
int atomic_sub_and_test(int i, atomic_t *v)从 v 减 i,如果结果为 0 就返回真,否则返回假
int atomic_dec_and_test(atomic_t *v)从 v 减 1,如果结果为 0 就返回真,否则返回假
int atomic_inc_and_test(atomic_t *v)给 v 加 1,如果结果为 0 就返回真,否则返回假
int atomic_add_negative(int i, atomic_t *v)给 v 加 i,如果结果为负就返回真,否则返回假

4.用完释放

atomic_inc(&dev->lock);

2.自旋锁

1.初始化

spinlock_t lock; /* 自旋锁 */

2.使用 

spin_lock_irqsave(&gpioled.lock, flags); /* 上锁 */
//上锁过程中其他试图加锁的都在等待
spin_unlock_irqrestore(&gpioled.lock, flags);/* 解锁 */

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值