# 第2章 操作系统的硬件基础

# 月出皓兮 苏曙光老师的课堂笔记

## 2022年3月5日

支持操作系统最基本的硬件结构为 CPU, 内存, 中断和时钟。

## 目录

| 1 | 计算机三总线硬件结构 |                                                |   |  |  |  |  |
|---|------------|------------------------------------------------|---|--|--|--|--|
|   | 1.1        | 计算机主要部件                                        | 3 |  |  |  |  |
|   | 1.2        | 三总线                                            | 3 |  |  |  |  |
|   | 1.3        | CPU 的结构                                        | 3 |  |  |  |  |
| 2 | CPU 的态系统 3 |                                                |   |  |  |  |  |
|   | 2.1        | 目的                                             | 3 |  |  |  |  |
|   | 2.2        | CPU 态的定义                                       | 4 |  |  |  |  |
|   | 2.3        | 态的分类                                           | 4 |  |  |  |  |
|   |            | 2.3.1 核态 (Kernel mode)                         | 4 |  |  |  |  |
|   |            | 2.3.2 用户态 (User mode, 目态)                      | 4 |  |  |  |  |
|   |            | 2.3.3 管态 (Supervisor mode)                     | 4 |  |  |  |  |
|   | 2.4        | 态的转换                                           | 4 |  |  |  |  |
|   |            | 2.4.1 用户态向核态转换                                 | 4 |  |  |  |  |
|   |            | 2.4.2 核态向用户态转换                                 | 4 |  |  |  |  |
|   | 2.5        | 硬件支持                                           | 5 |  |  |  |  |
|   | 2.6        | Intel CPU 的态                                   | 5 |  |  |  |  |
|   |            | 2.6.1 PL(Privilege Level)                      | 5 |  |  |  |  |
|   |            | 2.6.2 DPL: 描述符特权级 (Descriptor Privilege Level) | 5 |  |  |  |  |
|   |            | 2.6.3 当前特权级 CPL: Current Privilege Level       | 5 |  |  |  |  |

目录 Haofei Hou

|   |                          | 2.6.4 | 请求特权级 RPL: Requested Privilege Level  | 5  |  |  |  |  |
|---|--------------------------|-------|---------------------------------------|----|--|--|--|--|
|   |                          | 2.6.5 | 程序段 A 访问程序段 B 时的权限检查(态)               | 5  |  |  |  |  |
| 3 | 中断                       | 断机制 5 |                                       |    |  |  |  |  |
|   | 3.1                      | 中断的   | 定义                                    | 5  |  |  |  |  |
|   | 3.2                      | 目的 .  | · · · · · · · · · · · · · · · · · · · | 6  |  |  |  |  |
|   | 3.3                      |       | 念                                     | 6  |  |  |  |  |
|   |                          | 3.3.1 | 中断源                                   | 6  |  |  |  |  |
|   |                          | 3.3.2 | 中断类型                                  | 6  |  |  |  |  |
|   |                          | 3.3.3 | 断点                                    | 6  |  |  |  |  |
|   |                          | 3.3.4 | 现场                                    | 6  |  |  |  |  |
|   |                          | 3.3.5 | 中断处理程序                                | 7  |  |  |  |  |
|   |                          | 3.3.6 | 中断向量表                                 | 7  |  |  |  |  |
|   | 3.4                      | 中断响   | 应过程                                   | 7  |  |  |  |  |
|   | 3.5                      | 中断嵌   | 套                                     | 8  |  |  |  |  |
|   | 3.6                      | 中断系   | 统重要的指令                                | 8  |  |  |  |  |
|   |                          | 3.6.1 | INT n                                 | 8  |  |  |  |  |
|   |                          | 3.6.2 | IRET                                  | 8  |  |  |  |  |
|   | 3.7                      | 中断响   | 应的实质                                  | 8  |  |  |  |  |
| 4 | 基本输入输出系统 BIOS 8          |       |                                       |    |  |  |  |  |
|   | 4.1                      | 位置 .  |                                       | 8  |  |  |  |  |
|   | 4.2                      | 常见类   | 型                                     | 9  |  |  |  |  |
|   | 4.3                      | 基本功   | 能                                     | 9  |  |  |  |  |
|   |                          | 4.3.1 | 加电自检及初始化 (POST)                       | 9  |  |  |  |  |
|   |                          | 4.3.2 | CMOS 设置                               | 9  |  |  |  |  |
|   |                          | 4.3.3 | 系统自举/加载 OS                            | 9  |  |  |  |  |
|   |                          | 4.3.4 | 基本 I/O 服务(BIOS 中断)                    | 9  |  |  |  |  |
| 5 | 操作系统是如何启动的?           10 |       |                                       |    |  |  |  |  |
|   | 5.1                      |       | · · · · · · · · · · · · · · · · · · · | 10 |  |  |  |  |
|   |                          | 5.1.1 | 初始引导                                  | 10 |  |  |  |  |
|   |                          | 5.1.2 | 核心初始化                                 | 10 |  |  |  |  |
|   |                          | 5.1.3 | 系统初始化                                 | 11 |  |  |  |  |

## 1 计算机三总线硬件结构

## 1.1 计算机主要部件

CPU、内存和外设。外设往往需要通过 IO 接口才能连接到总线上。

## 1.2 三总线

地址总线,数据总线和控制总线。

## 1.3 CPU 的结构

CPU 由控制单元,运算单元,寄存器单元组成。其功能是按一定逻辑流程分析和执行指令流。(指令流已存放至内存中)



图 1: CPU 的结构与内存的连接

## 2 CPU 的态系统

#### 2.1 目的

为 CPU 设定态的根本目的在于为系统建立安全机制,禁止程序在非授权情况下非法访问或越权访问不属手于自己的数据或资源。

通过态来支持对可信程序和非可信程序的区分。可信程序能对系统的 安全机制进行设置和修改,使用普通指令集和特权指令集。非可信程序只能 使用普通指令集。其中特权指令包括涉及外部设备的输入/输出指令,修改特殊寄存器的指令,改变机器状态的指令。

态也为计算机系统的资源访问设置了访问屏障。

## 2.2 CPU 态的定义

即 CPU 的工作状态,对资源和指令使用权限的描述。

### 2.3 态的分类

## 2.3.1 核态 (Kernel mode)

能够访问所有资源和执行所有指令,具有最高的特权级别,管理程序/OS 内核一般为核态程序。

#### 2.3.2 用户态 (User mode, 目态)

仅能访问部分资源,其它资源受限。用户程序为用户态程序。

#### 2.3.3 管态 (Supervisor mode)

介于核态和用户态之间

#### 2.4 态的转换

#### 2.4.1 用户态向核态转换

- 用户请求 OS 提供服务。
- 用户进程产生错误(内部中断。
- 外部设备的中断。
- 用户态企图执行特权指令。

可以总结说,从用户态向核态转变的唯一方法就是中断。

#### 2.4.2 核态向用户态转换

一般是中断返回: IRET.

2.5 硬件支持 Haofei Hou

## 2.5 硬件支持

CPU 设置模式位,表明当前的状态。

指令执行前增加"权限状态是否满足"的条件判断。

Intel CPU 的相关机制

- 1. 保护模式 (CR0 的 PE 位,PG 位)
- 2. CPL(当前特权级)
- 3. 地址映射机制
- 4. 权限核验 (DPL+RPL+CPL)

## 2.6 Intel CPU 的态

#### 2.6.1 PL(Privilege Level)

Ring 0 – Ring 3 (Ring 0 最核心, Ring 3 最外层) Unix/Linux/Windows OS: 仅用到了 Ring 0 和 Ring 3

#### 2.6.2 DPL: 描述符特权级 (Descriptor Privilege Level)

段描述符 Descriptor, 8 个字节, 其中包括段基址, 段界限, 段属性(段类型, 访问该段所需最小特权级, 是否在内存)

- 2.6.3 当前特权级 CPL: Current Privilege Level
- 2.6.4 请求特权级 RPL: Requested Privilege Level
- 2.6.5 程序段 A 访问程序段 B 时的权限检查(态)

一致代码段: CPL >= DPL

非一致代码段: CPL = DPL 并且 RPL <= DPL

## 3 中断机制

## 3.1 中断的定义

指 CPU 对突发的外部事件的反应过程或机制。

CPU 收到外部信号(中断信号)后,停止当前工作,转去处理该外部事件,处理完毕后回到原来工作的中断处(断点)继续原来的工作。

3.2 目的 Haofei Hou

## 3.2 目的

实现并发活动 实现实时处理 故障自动处理

### 3.3 相关概念

#### 3.3.1 中断源

引起系统中断的事件称为中断源

#### 3.3.2 中断类型

强迫中断和自愿中断

• 强迫中断:程序没有预期:例:I/O、外部中断

• 自愿中断:程序有预期。例:执行访管指令

外中断(中断)和内中断(俘获)

• 外中断: 由 CPU 外部事件引起。例: I/O, 外部事件。

• 内中断:由 CPU 内部事件引起。例:访管中断、程序中断 外中断又可分为不可屏蔽中断和可屏蔽中断。

- 不可屏蔽中断: 中断的原因很紧要, CPU 必须响应
- 可屏蔽中断: 中断原因不很紧要, CPU 可以不响应

#### 3.3.3 断点

程序中断的地方,将要执行的下一指令的地址 包含 CS:IP (FLAGS、SS、SP)

#### 3.3.4 现场

程序正确运行所依赖的信息集合。

包含 PSW (程序状态字)、相关寄存器、断点 现场保护: 进入中断服务程序之前:  $CPU \rightarrow \xi$  现场恢复: 退出中断服务程序之后:  $\xi \rightarrow CPU$ 

### 3.3.5 中断处理程序

处理中断源中断事件的程序称为中断服务程序。中断服务程序是事先 已准备好的一个特殊函数,该函数的调用由系统自动完成。

#### 3.3.6 中断向量表

中断服务程序的入口地址用段基址 (Segment) 和段偏移 (Offset) 两个参数记录, 称之为中断向量。

## 3.4 中断响应过程

- 1. 识别中断源
- 2. 保护断点
- 3. 保护现场
- 4. 进入中断服务程序
- 5. 恢复现场
- 6. 中断返回

其中现场入栈和中断服务在内容可能会有重叠。

编写中断服务程序的关键:保护现场,实现特定功能,还原现场,IRET。



图 2: 中断响应过程

在保护模式下发生中断的时候可能涉及特权级的变化。中断发生时,如果代码在相同特权级间跳转时,则堆栈不变(则只需入栈 FLAGS, CS,

3.5 中断嵌套 Haofei Hou

IP);若在不同特权级间跳转,则会用到两个不同的堆栈(需要压入 SS, SP, FLAGS, CS, IP)。压栈的过程地址由低到高(SP 不断变小)。

### 3.5 中断嵌套

而堆栈机制也是中断嵌套处理的关键所在,允许我们从一个低优先级的中断处理中跳出,去处理一个高优先级的中断。

## 3.6 中断系统重要的指令

#### 3.6.1 INT n

压栈(SS, SP, FLAGS, CS, IP),按照中断向量表跳转。

#### 3.6.2 IRET

可通过 IRET 指令进入特定的代码段与任务, 其常用于由高优先级(内核态)到低内核态的跳转。

## 3.7 中断响应的实质

交换指令执行地址。

交换 CPU 的态。

实现了现场保护和恢复与参数传递 (通信)。

## 4 基本输入输出系统 BIOS

Basic I/O System (BIOS, Firmware, 以固件形式存在的软件)。

## 4.1 位置

内存中的 C0000-FFFFF 部分。其中:

C0000 - C7FFF: 显示卡 BIOS

C8000 - CBFFF: IDE 控制器 BIOS

F0000 - FFFFF: 系统 BIOS。大小为 64K, 是每一个计算机必须的。

4.2 常见类型 Haofei Hou

#### 4.2 常见类型

Award BIOS, AMI BIOS, Phoenix BIOS.

#### 4.3 基本功能

## 4.3.1 加电自检及初始化 (POST)

• 按下 PowerOn 键

CS:IP 复位 FFFF:0000, 开始执行 FFFF0 单元的指令 JUMP POST

• Power On Slef-Test (POST, 加电自检)

初始化基本硬件,如 CPU,内存,显卡…

自检正常不提示,错误则通过喇叭提示。

#### 4.3.2 CMOS 设置

Complementary Metal-Oxide Semiconductor 互补金属氧化物半导体芯片。芯片保存着系统的重要参数,要随时保持供电。

CMOS RAM 只是一块存储芯片,只有数据保存功能,因而需要使用专门的 CMOS 设置程序去设置其中的各项参数。在计算机加电引导过程中,可以通过特殊热键启动 CMOS 设置程序,参数设置好后保存在 CMOS RAM 中。

#### 4.3.3 系统自举/加载 OS

开机时将 OS 载入内存并运行为用户建立用户环境。

#### 4.3.4 基本 I/O 服务 (BIOS 中断)

BIOS 直接与计算机的 IO 设备打交道,它通过端口向发出 OUT 或 IN 等命令,向各种外部设备传送数据或从它们那里接收数据,使操作系统或应用程序能够脱离具体的硬件操作细节。

基本输入输出处理程序是通过中断服务指令的形式来实现的。BIOS 使用的中断类型号为 10H——1FH。每一组服务又根据具体功能或使用方式细分为不同的子功能,并用子功能编号加以标识。在汇编程序中, 通过 AH 寄存器指定子功能编号以调用不同的子功能。

其中需要了解磁盘的 CHS(Cylinder/Head/Sector) 定位方案。磁头数 (Heads) 表示硬盘总共有几个磁头,也就是有几面盘片,最大为 256 (用 8 个二进制位存储);柱面数 (Cylinders) 表示硬盘每一面盘片上有几条磁道,最大为 1024(用 10 个二进制位存储);扇区数 (Sectors per track) 表示每一条磁道上有几个扇区,最大为 63 (用 6 个二进制位存储)。

## 5 操作系统是如何启动的?

### 5.1 概述

操作系统的启动过程是指从加电开始到操作系统的控制台或桌面准备好的过程。整个启动过程分为3个阶段:初始引导、核心初始化和系统初始化。

#### 5.1.1 初始引导

其目的是把 OS 内核装入内存并使之开始工作接管计算机系统。 过程如下:

- 1. 加电, 主板发出 RESET 信号, CPU 恢复初始状态
- 2. 电源稳定后, 撤去 RESET 信号, CPU 执行 FFFF0H 处指令 (这个地址实际上位于 RAM-BIOS)
  - 3. 进行加电自检
- 4. 跳入 BIOS 的启动程序,读取 0 面 0 道第 1 扇区内容,即主启动记录(Master Boot Record, MBR)。其中包含特定操作系统的引导程序。
- 5. 运行引导程序,根据相关参数,读取硬盘指定位置的 OS 内核到内存,并初始化相关参数。
- 6. OS 内核获得 CPU 控制权,逐步加载 OS 剩余部分,直到最后完全控制计算机

#### 5.1.2 核心初始化

核心初始化其目的是 OS 内核初始化系统的核心数据。

典型工作有各种寄存器的初始化,存储系统和页表初始化,核心进程构建……

5.1 概述 Haofei Hou



图 3: OS 的初始引导

## 5.1.3 系统初始化

系统初始化为用户使用系统作准备, 使系统处于待命状态。

主要工作有初始化文件系统,初始化网络系统,初始化控制台,初始化 图形界面等。