xref: /DragonOS/docs/kernel/locking/locks.md (revision f049d1af01da7b92f312245ed411b22475b76065)
1# 锁的类型及其规则
2
3## 简介
4
5  DragonOS内核实现了一些锁,大致可以分为两类:
6
7- 休眠锁
8- 自旋锁
9
10## 锁的类型
11
12### 休眠锁
13
14  休眠锁只能在可抢占的上下文之中被获取。
15
16  在DragonOS之中,实现了以下的休眠锁:
17
18- semaphore
19- mutex_t
20
21### 自旋锁
22
23- spinlock_t
24- {ref}`RawSpinLock <_spinlock_doc_rawspinlock>`(Rust版本的spinlock_t,但与spinlock_t不兼容)
25- {ref}`SpinLock <_spinlock_doc_spinlock>` —— 在RawSpinLock的基础上,封装了一层守卫(Guard), 将锁及其要保护到的数据绑定在一个结构体内,并能在编译期避免未加锁就访问数据的问题。
26
27&emsp;&emsp;进程在获取自旋锁后,将改变pcb中的锁变量持有计数,从而隐式地禁止了抢占。为了获得更多灵活的操作,spinlock还提供了以下的方法:
28
29
30| 后缀                     | 说明                                                |
31| ------------------------ | --------------------------------------------------- |
32| _irq()                   | 在加锁时关闭中断/在放锁时开启中断                   |
33| _irqsave()/_irqrestore() | 在加锁时保存中断状态,并关中断/在放锁时恢复中断状态 |
34
35
36## 详细介绍
37
38### 自旋锁的详细介绍
39
40&emsp;&emsp;关于自旋锁的详细介绍,请见文档:{ref}`自旋锁 <_spinlock_doc>`
41
42### semaphore信号量
43
44&emsp;&emsp;semaphore信号量是基于计数实现的。
45
46&emsp;&emsp;当可用资源不足时,尝试对semaphore执行down操作的进程将会被休眠,直到资源可用。
47
48### mutex互斥量
49
50&emsp;&emsp;请见{ref}`Mutex文档 <_mutex_doc>`
51