spinlock的设计和实现


在Linux的内核中,spin lock用在多处理器环境中。当一个CPU访问一个临界资源
(critical section)的时候,需要预先取得spin lock,如果取不到的话,它就在空循环
等待,直到另外的CPU释放spin lock。由于涉及到多个处理器,spin lock的效率非常重要。
因为在等待spin lock的过程,处理器只是不停的循环检查,并不执行其他指令。但即使这样
一般来说,spn lock的开销还是比进程调度(context switch)少得多。这就是spin lock
被广泛应用在多处理器环境的原因。

1. spin lock的数据结构

/* include/asm-i386/spinlock.h */

typedef struct {
volatile unsigned int lock;
} spinlock_t;

spin lock的数据结构很简单,只是一个整数变量lock, 如果lock等于1的话,表示
这个spin lock是自由的;如果lock小于等于0的话,则表示spin lock已经被其他CPU所
获取。

2. spin lock的实现

#define spin_lock_string
"n1:t"
"lock ; decb %0nt"
"js 2fn"
".section .text.lock,"ax"n"
"2:t"
"cmpb $0,%0nt"
"rep;nopnt"
"jle 2bnt"
"jmp 1bn"
".previous"


#define spin_unlock_string
"movb $1,%0"
:"=m" (lock->lock) : : "memory"

static inline void spin_lock(spinlock_t *lock)
{
__asm__ __volatile__(
spin_lock_string
:"=m" (lock->lock) : : "memory");
}

static inline void spin_unlock(spinlock_t *lock)
{
char oldval = 1;

__asm__ __volatile__(
spin_unlock_string
);
}

如果将上面的语句转化成纯汇编的话,则是这样:

spin_lock(lock)

1:
lock ; decb %0
js 2f

.section .text.lock, "ax"
2: cmpb $0,%0
rep;nop
jle 2b
jmp 1b
.previous

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值