xref: /DragonOS/docs/kernel/locking/locks.md (revision 6352836902fac25f1709a1479d732b0736947163)
1*63528369Sfslongjin# 锁的类型及其规则
2*63528369Sfslongjin
3*63528369Sfslongjin## 简介
4*63528369Sfslongjin
5*63528369Sfslongjin  DragonOS内核实现了一些锁,大致可以分为两类:
6*63528369Sfslongjin
7*63528369Sfslongjin- 休眠锁
8*63528369Sfslongjin- 自旋锁
9*63528369Sfslongjin
10*63528369Sfslongjin## 锁的类型
11*63528369Sfslongjin
12*63528369Sfslongjin### 休眠锁
13*63528369Sfslongjin
14*63528369Sfslongjin  休眠锁只能在可抢占的上下文之中被获取。
15*63528369Sfslongjin
16*63528369Sfslongjin  在DragonOS之中,实现了以下的休眠锁:
17*63528369Sfslongjin
18*63528369Sfslongjin- semaphore
19*63528369Sfslongjin
20*63528369Sfslongjin### 自旋锁
21*63528369Sfslongjin
22*63528369Sfslongjin- spinlock_t
23*63528369Sfslongjin
24*63528369Sfslongjin  进程在获取自旋锁后,将改变pcb中的锁变量持有计数,从而隐式地禁止了抢占。为了获得更多灵活的操作,spinlock还提供了以下的方法:
25*63528369Sfslongjin
26*63528369Sfslongjin| 后缀                       | 说明                         |
27*63528369Sfslongjin| ------------------------ | -------------------------- |
28*63528369Sfslongjin| _irq()                   | 在加锁时关闭中断/在放锁时开启中断          |
29*63528369Sfslongjin| _irqsave()/_irqrestore() | 在加锁时保存中断状态,并关中断/在放锁时恢复中断状态 |
30*63528369Sfslongjin
31*63528369Sfslongjin
32*63528369Sfslongjin### semaphore信号量
33*63528369Sfslongjin
34*63528369Sfslongjin  semaphore信号量是基于计数实现的。
35*63528369Sfslongjin
36*63528369Sfslongjin  当可用资源不足时,尝试对semaphore执行down操作的进程将会被休眠,直到资源可用。