# 计算机组成原理 (第九讲)

厦门大学信息学院软件工程系 曾文华 2021年6月2日



第9章 控制单元的功能

第10章 控制单元的设计



### 第9章 控制单元的功能

- 9.1 微操作命令的分析
- 9.2 控制单元的功能



### 9.1 微操作命令的分析

- 一、取指周期
- 二、间指周期
- 三、执行周期
- 四、中断周期

#### 8.2 指令周期

- 一、指令周期的基本概念
- 二、指令周期的数据流



### 完成一条指令分4个工作周期:

- 1、取指周期
- 2、间址周期
- 3、执行周期
- 4、中断周期

### 一、取指周期

取指周期的目的是:将指令的机器码从存储器中取到IR中





- $\bigcirc 1 \longrightarrow R$
- $\bigcirc$  M (MAR)  $\longrightarrow$  MDR
- $\bigcirc$  MDR  $\rightarrow$  IR
- $\bigcirc$  OP (IR)  $\rightarrow$  CU
- $\bigcirc$  (PC) + 1 $\longrightarrow$  PC

OP(IR):指令的操作码部分

### 二、间址周期

间址周期的目的是: 由形式地址得到有效地址

见P344 (第8章)

① 指令形式地址 → MAR

即:  $Ad(IR) \longrightarrow MAR$ 

- $\bigcirc$  1 $\longrightarrow$ R
- $\bigcirc$  M (MAR)  $\longrightarrow$  MDR



Ad (IR): 指令的地址码部分

10条指令

1. 非访存指令 在执行周期不访问存储器

10条指令

1. 非访存指令 在执行周期不访问存储器

(1) CLA 清A  $0 \rightarrow \overline{ACC}$ 

10条指令

1. 非访存指令 在执行周期不访问存储器

 $0 \longrightarrow ACC$ 

(2) **COM** 取反

 $ACC \longrightarrow ACC$ 

### 10条指令

1. 非访存指令 在执行周期不访问存储器

(1) CLA 清A

 $0 \longrightarrow ACC$ 

(2) **COM** 取反

ACC → ACC 左边->右边

符号位不变

(3) SHR 算术右移  $L(ACC) \rightarrow R(ACC), ACC_0 \rightarrow ACC_0$ 

### 10条指令

1. 非访存指令 在执行周期不访问存储器

(1) CLA 清A

 $0 \longrightarrow ACC$ 

(2) **COM** 取反

 $\overline{ACC} \longrightarrow ACC$ 

符号位不变

左边->右边

(3) SHR 算术右移  $L(ACC) \rightarrow R(ACC), ACC_0 \rightarrow ACC_0$ 

(4) CSL 循环左移  $R(ACC) \rightarrow L(ACC), ACC_0 \rightarrow ACC_n$ 

11110110 ----

11101101

右边->左边

### 10条指令

1. 非访存指令 在执行周期不访问存储器

- 清Α (1) **CLA**
- $0 \longrightarrow ACC$

(2) **COM** 取反

$$\overline{ACC} \longrightarrow ACC$$

符号位不变

左边->右边

- (3) SHR 算术右移  $L(ACC) \rightarrow R(ACC), ACC_0 \rightarrow ACC_0$
- $R(ACC) \rightarrow L(ACC), ACC_0 \rightarrow ACC_n$ (4) CSL 循环左移
- (5) STP 停机指令  $0 \rightarrow G$

右边->左边

运行标志触发器

### 2. 访存指令 在执行周期要访问存储器

### 2. 访存指令 在执行周期要访问存储器



### 2. 访存指令 在执行周期要访问存储器

(1) 加法指令 ADD XADDA,(X) $Ad(IR) \rightarrow MAR$ ADD AL,[2300H]  $1 \longrightarrow R$  $M(MAR) \rightarrow MDR$  $(ACC) + (MDR) \longrightarrow ACC$ (2) 存数指令 STA X MOV(X), A $Ad(IR) \longrightarrow MAR$ MOV [2300H], AL  $1 \longrightarrow W$ 2300 [2300H]  $ACC \longrightarrow MDR$ 

 $MDR \longrightarrow M(MAR)$ 



(3) 取数指令 LDA X MOVA, (X)



 $Ad(IR) \rightarrow MAR$ 

MOV AL,[2300H]

 $1 \rightarrow R$ 

 $M(MAR) \rightarrow MDR$ 

 $MDR \rightarrow ACC$ 

3. 转移指令

(3) 取数指令 LDA X MOVA, (X)



 $Ad(IR) \rightarrow MAR$ 

MOV AL,[2300H]

 $1 \rightarrow R$ 

$$M(MAR) \rightarrow MDR$$

$$MDR \rightarrow ACC$$

- 3. 转移指令
  - (1) 无条件转 JMP X

$$Ad (IR) \longrightarrow PC$$

(3) 取数指令 LDA X

MOVA, (X)



 $Ad(IR) \rightarrow MAR$ 

MOV AL,[2300H]

 $M(MAR) \rightarrow MDR$ 

 $MDR \rightarrow ACC$ 

### 3. 转移指令

(1) 无条件转 JMP X

$$Ad(IR) \rightarrow PC$$

条件成立:  $A_0=1$  $A_0$ 'Ad (IR) +  $/A_0$ (PC) = Ad(IR)

条件不成立:  $A_0=0$  $A_0$  Ad (IR) +  $A_0$  (PC) = PC

(2) 条件转移

BAN X

(负则转,A<sub>0</sub>=1)

 $A_0$ :Ad (IR) +  $\overline{A}_0$ (PC)  $\longrightarrow$  PC

### 4. 三类指令的指令周期



## 四、中断周期

中断周期,由中断隐指令自动完成: (1)保护程序 断点; (2)寻找中断服务程序的入口地址; (3)硬件关中断



### 见P363-364 (第八章)





### 9.2 控制单元的功能

- 一、控制单元的外特性
- 二、控制信号举例
- 三、多级时序系统
  - 四、控制方式
  - 五、多级时序系统实例分析



### 控制单元的外特性

数据总线 地址总线 控制总线



### 1. 控制单元的输入信号

(1) 时钟

CU 受时钟控制

一个时钟脉冲

发一个操作命令或一组需同时执行的操作命令

(2) 指令寄存器 OP(IR)→ CU 控制信号 与操作码有关

一指令的操作码

(3) 标志 ← CU 受标志控制

状态寄存器

(4) 外来信号 来自系统总线的控制信号

FC、FZ

如 INTR 中断请求 HRQ 总线请求(DMA请求)

### 2. 控制单元的输出信号

(1) CPU 内的各种控制信号

 $\mathbf{R}_i \longrightarrow \mathbf{R}_j \longleftarrow$ 

寄存器之 间的传递

$$(PC) + 1 \longrightarrow PC$$

**ALU** +、一、与、或 ……

(2) 送至控制总线的信号 CPU 外的控制信号

**MREQ** 

访存控制信号

**IO/M** 

访 IO/ 存储器的控制信号

RD

读命令

 $\overline{ ext{WR}}$ 

写命令

**INTA** 

中断响应信号

**HLDA** 

总线响应信号 (DMA响应信号)

### 二、控制信号举例

1. 不采用 CPU 内部总线的方式



### 二、控制信号举例

ADD A, ((X))

1. 不采用 CPU 内部总线的方式

ADD AL, [[2300H]]

以ADD @ X 为例 取指周期



### 控制信号举例

ADD A, ((X))

1. 不采用 CPU 内部总线的方式

以ADD@X 为例 取指周期



### 二、控制信号举例

ADD A, ((X))

1. 不采用 CPU 内部总线的方式

以ADD @ X 为例 取指周期



### 控制信号举例

ADD A, ((X))

1. 不采用 CPU 内部总线的方式

以ADD@X 为例 取指周期



### 二、控制信号举例 ADD A, ((X))

1. 不采用 CPU 内部总线的方式 以ADD @ X 为例 取指周期 C2有效,打开数据总线送至MDR的输 入门 **AC** PC IR 控制 ALU : 标志 **CU** 时钟 控制信号

### 控制信号举例

ADD A, ((X))

1. 不采用 CPU 内部总线的方式

以ADD @ X 为例 取指周期



### 控制信号举例

ADD A, ((X))

1. 不采用 CPU 内部总线的方式

以ADD@X 为例 取指周期



### 二、控制信号举例

ADD A, ((X))

1. 不采用 CPU 内部总线的方式

以ADD @ X 为例 取指周期



ADD A, ((X))



ADD A, ((X))



ADD A, ((X))



ADD A, ((X))



ADDA, ((X))



ADDA, ((X))



ADD A, ((X))



ADD A, ((X))



ADD A, ((X))



ADD A, ((X))



ADD A, ((X))



ADD A, ((X))



ADD A, ((X))



ADD A, ((X))











- 例9.1: CPU内部采用非总线结构,如图9.3所示:
  - 写出取指周期的全部微操作;
  - 写出取数指令 "LDA M"、存数指令 "STA M"、 加法指令 "ADD M"在执行阶段所需的全部微操作;
  - 当上述指令均为间接寻址时,写出执行这些指令所需的全部微操作;
  - 写出无条件转移指令"JMP Y"和结果为零则转指令"BAZ Y"在执行阶段所需的全部微操作。
- 解:

# CPU 内部结构采用非总线方式

图9.3





PC->MAR

现行指令地址->MAR

■ 1->R

命令存储器读

M(MAR)-MDR

现行指令从存储器中读至MDR

MDR->IR

现行指令->IR

OP(IR)->CU

指令的操作码->CU 译码

(PC)+1->PC

形成下一条指令的地址



■ ①取数指令 "LDA M"执行阶段所需的全部微操作

■ Ad(IR)->MAR 指令的地址码字段->MAR

■ 1->R 命令存储器读

M(MAR)->MDR 操作数从存储器中读至MDR

■ MDR->ACC 操作数->ACC

■ ②存数指令 "STA M"执行阶段所需的全部微操作

■ Ad(IR)->MAR 指令的地址码字段->MAR

■ 1->W 命令存储器写

MDR-> M(MAR) 数据写至存储器中

■ ③加法指令 "ADD M"执行阶段所需的全部微操作

Ad(IR)->MAR

■ 1->R

M(MAR)->MDR

(ACC)+(MDR)->ACC

指令的地址码字段->MAR

命令存储器读

操作数从存储器中读至MDR

两数相加结果送ACC



#### ■ (3)间址周期

当上述指令为间接寻址时,需增加间址周期的微操作,间址周期的微操作为:

■ Ad(IR)->MAR 指令的地址码字段(形式地址)->MAR

■ **1->R** 命令存储器读

■ M(MAR)->MDR 有效地址从存储器中读至MDR

■ 进入执行周期,3条指令的第一个微操作均为MDR->MAR(原来是Ad(IR)->MAR),其余微操作不变



#### ■ (4)转移指令

- ①无条件转移指令"JMP Y"执行阶段的微操作如下:
  - Ad(IR)->PC 转移(目标)地址 Y -> PC
- ②结果为零则转指令"BAZ Y"执行阶段的微操作如下:
  - Z•Ad(IR)->PC 当Z=1时,转移(目标)地址Y -> PC

当Z=0时(结果不为0),什么也不做

■ 例9.2: 单总线计算机结构如图9.5所示,其中M为主 存储器,XR为变址寄存器,EAR为有效地址寄存器, LATCH为锁存器。假设指令地址已存于PC中,请画 出 "ADD X,D"(X为变址寄存器XR,D为形式地址) 和 "STA \*D"(\*表示相对寻址, D为相对位移量)两 条指令的指令周期信息流程图,并列出相应的控制信 号序列。  $ACC \rightarrow (PC+D)$ 

• 解: (XR+D) + ACC -> ACC

MQ: 乘商寄存器

乘法时放乘积的低位部分,除法时放商

Multiplier & Quotient



EAR: 有效地址寄存器

LATCH: 锁存器

图 9.5 单总线计算机结构

■ (1) "ADD X,D"指令取指周期和执行周期的信息流程 及相应的控制信号如下,其中Ad(IR)为形式地址:



■ (2) "STA \*D"指令取指周期和执行周期的信息流程及相应的控制信号如下,其中Ad(IR)为相对位移量:



# 三、多级时序系统

1. 机器周期

- "单机器指令"方式运行,每次执行1条指令
- →"单周期"方式运行,每次执行1条微指
- "单节拍"方式运行,每次执行1个时钟周期(T周期

(1) 机器周期的概念

所有指令执行过程中的一个基准时间

- (2) 确定机器周期需考虑的因素 每条指令的执行 步骤 每一步骤 所需的 时间
- (3) 基准时间的确定
  - •以完成 最复杂 指令功能的时间 为准
  - 以访问一次存储器的时间为基准

若指令字长 = 存储字长 取指周期 = 机器周期

- "单节拍"方式运行,每次执行1个时钟周期





个机器周期内可完成若干个微操作

每个微操作需一定的时间

将一个机器周期分成若干个时间相等的 时间段(节拍、状态、时钟周期)

时钟周期是控制计算机操作的最小单位时间

用时钟周期控制产生一个或几个微操作命令

# 2. 时钟周期(节拍、状态) 一个机器周期等于4 个时钟周期 时钟周期



#### 3. 多级时序系统

- "单周期"方式运行,每次执行1条微指令
  - "单节拍"方式运行,每次执行1个时钟周期(T周期

器指令"方式运行,每次执行1条指令



机器周期、节拍(状态)组成多级时序系统

一个指令周期包含若干个机器周期(如2个或3个)

一个机器周期包含若干个时钟周期(如4个)





#### 4. 机器速度与机器主频的关系



机器的 主频 ƒ 越快 机器的 速度也越快

在机器周期所含时钟周期数 相同 的前提下, 两机 平均指令执行速度之比 等于 两机主频之比

$$\frac{\text{MIPS}_1}{\text{MIPS}_2} = \frac{f_1}{f_2}$$

机器速度不仅与主频有关,还与机器周期中所含时钟周期(主频的倒数)数以及指令周期中所含的机器周期数有关

- 例9.3: CPU主频=8MHz,每个机器周期平均含2个时钟周期,每条指令的指令周期平均有2.5个机器周期,试问该机器的平均指令执行速度为多少MIPS?
- 若主频不变,每个机器周期平均含4个时钟周期,每条指令的指令周期平均有5个机器周期,试问该机器的平均指令执行速度为多少MIPS?得出什么结论?

- 例9.3: CPU主频=8MHz,每个机器周期平均含2个时钟周期,每条指令的指令周期平均有2.5个机器周期,试问该机器的平均指令执行速度为多少MIPS?
- 若主频不变,每个机器周期平均含4个时钟周期,每条指令的指令周期平均有5个机器周期,试问该机器的平均指令执行速度为多少MIPS?得出什么结论?

#### ■ 解:

- 时钟周期=1/(8MHz)=0.125μs,
  机器周期=0.125μsX2=0.25μs,
  指令周期=0.25μsX2.5=0.625μs,
  平均指令执行速度为1/0.625μs=1.6MIPS
- 若CPU主频不变,每个机器周期平均含4个时钟周期,每条指令的指令周期平均有5个机器周期,则指令周期=0.125μsX4X5=2.5μs,故平均指令执行速度=1/2.5μs=0.4MIPS
- 结论: 机器的速度并不完全取决于主频

# 四、控制方式

产生不同微操作命令序列所用的时序控制方式

1. 同步控制方式

任一微操作均由 统一基准时标 的时序信号控制



(1) 采用 定长 的机器周期

以最长的微操作序列和最繁的微操作作为标准机器周期内节拍数相同(如都是4个)

#### (2) 采用不定长的机器周期



#### 机器周期内 节拍数不等



执行指令的机器周期=3个时钟周期



### (3) 采用中央控制和局部控制相结合的方法



将少数操作复杂的指令中的某些操作(如乘除中央控制节拍均为**4**个时钟周期 法和浮点运算等)采用局部控制方式来完成

## 2. 异步控制方式



无基准时标信号

无固定的周期节拍和严格的时钟同步 采用 应答方式

3. 联合控制方式 同步与异步相结合

4. 人工控制方式

连续执行、单步执行

- (1) Reset
- (2) 连续 和 单条 指令执行转换开关
- (3) 符合停机开关

## 五、多级时序系统实例分析

3个16位寄存器: SP、PC、IDAL 1个5位状态寄存器: FR 1.8085CPU 的组成 11个8位寄存器: B、C、D、E、H、L、IR、AC、TR、ABR、ADBR **INTR** INTA **SID SOD** 中断控制 I/O控制 IDAL:增减地 址锁存器 标志寄存器 FR: 8位内部数据总线 AC(8)**TR(8)** C(8)**B** (8) FR(5)**IR(8) D** (8) E(8)指令译码 地址 H(8)L (8) **SP** (16) TR:暂存器 数据缓冲寄存器 **ALU** 机器周期 **PC** (16) 编码 **IDAL (16)** 定时和控制 地址缓冲寄存器 控制 状态 **ABR**(8) ADBR(8)复位 时钟 **DMA CLK** 

| Reset out

A<sub>15</sub>~A<sub>8</sub>

AD<sub>7</sub>~AD<sub>0</sub>

IO/M

Ready

### 2.8085CPU 的外部引脚



### (4) 与中断有关的信号







### Intel 8085 registers

 $\begin{smallmatrix}1_5&1_4&1_3&1_2&1_1&1_0&0_9&0_8&0_7&0_6&0_5&0_4&0_3&0_2&0_1&0_0&(bit\ position)\end{smallmatrix}$ 

#### Main registers

| A | Flags | Program Status Word  |
|---|-------|----------------------|
| В | С     | В                    |
| D | Е     | D                    |
| Н | L     | H (indirect address) |

### Index registers

SP Stack Pointer

#### Program counter

PC Program Counter

### Status register















## 小结

以一条输出指令(I/O写)为例

机器周期  $M_1$  取指令操作码

机器周期  $M_2$  取设备地址(I/O地址)

一机器周期  $M_3$  执行 ACC 的内容写入设备

每个 控制 信号在 指定机器周期 的 指定节拍 T 时刻 发出

# 4

# 本章小结

■ 取指周期——从存储器中取出指令的机器码(放到IR中)

- ① PC → MAR → 地址线
- $\bigcirc 1 \longrightarrow R$
- $\bigcirc$  M (MAR)  $\rightarrow$  MDR
- $\bigcirc$  MDR  $\rightarrow$  IR
- $\bigcirc$  (PC) + 1  $\longrightarrow$  PC



# 4

# 本章小结

■ 间址周期——根据形式地址从存储器中得到有效地址

- ① 指令形式地址 → MAR
- 2 1→R
- $\bigcirc$  M (MAR)  $\longrightarrow$  MDR

- Ad(IR)->MAR
- 1->R
- M(MAR)->MDR

- 执行周期
  - ■非访存指令
  - ■访存指令
  - ■转移指令

①取数指令 "LDA M"执行阶段所需的全部微操作 Ad(IR)->MAR 指令的地址码字段->MAR ■ 1->R 命令存储器读 M(MAR)->MDR 操作数从存储器中读至MDR MDR->ACC 操作数->IR ②存数指令 "STA M"执行阶段所需的全部微操作 · Ad(IR)->MAR 指令的地址码字段->MAR . 1->W 命令存储器写 ACC->MDR 欲写入的数据->MDR MDR-> M(MAR) 数据写至存储器中 ③加法指令 "ADD M"执行阶段所需的全部微操作 Ad(IR)->MAR 指令的地址码字段->MAR . 1->R 命令存储器读 M(MAR)-MDR 操作数从存储器中读至MDR · (ACC)+(MDR)->ACC 两数相加结果送ACC



■ 中断周期——由中断隐指令自动完成: (1)保护断点; (2)寻找中断服务程序入口地址; (3)硬件关中断



### ■ 控制单元的输入和输出

- 输入:
  - 指令的操作码
  - 标志
  - 来自系统总线的控制信号
  - 时钟信号
- 输出:
  - CPU内容的控制信号
  - 到系统总线的控制信号





■指令周期

■机器周期

■时钟周期

"单机器指令"方式运行,每次执行**1**条指令

·"单周期"方式运行,每次执行1条微指令

"单节拍"方式运行,每次执行1个时钟周期(T周期)



### • 控制方式

- 同步控制方式
  - 采用定长的机器周期
  - 采用不定长的机器周期
  - 采用中央控制和局部控制相结合的方法
- 异步控制方式
- 联合控制方式: 同步与异步的结合
- 人工控制方式: RESET、单步执行、连续执行

## 第15次作业——习题(P393-394)

- **9.1**
- **9.2**
- **9.3**
- **9.4**
- **9.6**
- **9.8**
- **9.14**



## 关于作业的提交

- **1**周内必须提交(上传到学院的FTP服务器上),否则认为是迟交作业;如果期末仍然没有提交,则认为是未提交作业
  - 作业完成情况成绩=第1次作业提交情况\*第1次作业评分+第2次作业提交情况\*第2次作业评分+……+第N次作业提交情况\*第N次作业评分
  - 作业评分: A(好)、B(中)、C(差)三挡
  - 作业提交情况:按时提交(1.0)、迟交(0.5)、未提交(0.0)
- 请采用电子版的格式(Word文档)上传到FTP服务器上,文件 名取"学号+姓名+第X次作业.doc"
  - 例如: 11920192203642+袁佳哲+第15次作业.doc
- 第15次作业提交的截止日期为: 2021年6月9日晚上24点



## **Thanks**