悟空学Linux专栏----第48篇

  (Linux内核同步机制之自旋锁)

  我们已经分析了Linux内核同步机制的信号量,发现信号量其实是基于自旋锁来实现的,现在我们就来看看Linux内核中的自旋锁吧!

  那么自旋锁有什么特性呢?

  自旋锁最多只能够被一个可执行线程持有,如果一个执行线程试图获得一个已经被持有的自旋锁,那么该线程就会一直进行忙等待,直到自旋锁被释放重新可用;如果锁没有被持有,请求自旋锁的线程便能立刻得到它,继续执行。那么何为线程呢?线程也就是CPU调度执行的最小单位,一个单独的执行流。 在任意时间,自旋锁都可以防止多于一个的执行线程同事进入临界区,同时,同一个锁可以用在多个位置上。

  自旋锁数据结构如下:

  1 typedef struct {

  2 raw_spinlock_t raw_lock;

  3 #ifdef CONFIG_GENERIC_LOCKBREAK

  4 unsigned int break_lock;

  5 #endif

  6 #ifdef CONFIG_DEBUG_SPINLOCK

  7 unsigned int magic, owner_cpu;

  8 void *owner;

  9 #endif

  10 #ifdef CONFIG_DEBUG_LOCK_ALLOC

  11 struct lockdep_map dep_map;

  12 #endif

  13 } spinlock_t;

  自旋锁定义也提供静态和动态方式。

  DEFINE_SPINLOCK(x)

  该宏声明一个自旋锁x并初始化它。

  SPIN_LOCK_UNLOCKED

  这个宏也用于初始化一个自旋锁。

  DEFINE_SPINLOCK(x)等同于spinlock_t x = SPIN_LOCK_UNLOCKED

  下一篇继续讲解自旋锁的操作API。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值