

计  
算  
机  
结  
构  
与  
结  
构  
基  
本  
复  
习

张  
军

深

## 第一章

1. 计算机体系结构 (architecture) 是那些对程序是可见的系统属性  
直接影响程序的效率执行

计算机组织 (organization) 是指实现结构规范的操作单元及其连接



3. 是否有系统指针是 architecture 问题；而这些指针是通过特定的魔法单元，还是重复使用系统的加法单元来实现，是组织间问题。

4. 系列机具有相同的结构，不同的组织

5. 结构: 部件相互类型的方式  
功能: 作为有关结构组成部分的各个部件的操作

6. 本质上说，计算机能够完成的基本功能

(这就是 P.25 所讲的功能分类)

当由直接与计算机相连的设备接收  
数据并向其发送数据时，这个连接称为输入输出 (I/O)，这个设备称为外围设备 (本机) (直接与主机相连的设备)

7. 与外部环境的所有连接

对简单处理器 CPU

CPU → 通信线路

控制器  
ALU  
寄存器 (为 CPU 提供内部存储)  
CPU 内部互连  
主存储器 (P21), 又称实存存储  
I/O  
系统互连 (BUS)

注: CU 的 flash memory 里存着  
instruction set, 于是成为可编程器件

## 第二章

1. 洛伊德机 (构思: 程序存储)

核心点: 取指—执行 (控制器从主存储器中取指)  
(具体的要在后面的章节了解到每一步有几个操作!)

2. 电子管 (真空管) — 晶体管 — 集成电路

Vacuum tube      transistor      Integrated circuits

↓  
IBM system/360 — 提出了系列化设计思想

3. 系列机 [ 相同或相似的指令集 (结构相同) ] → 程序可以在上机器而不能在下移植

相同或相似的体系结构

更高的速度

更多的I/O端口数

更大的内存容量

成本增加

CPI — average cycle per instruction

MIPS — million instruction per second

加速比 —

(浪去做题!)

## 第2章

1. 演进代数机的恩惠：程序存储  
核心点：取指—执行（控制器从主存读指中取指）  
(具体的要在后面的章节了解到每一步有几个节拍!)

2. 电子管（真空管）—晶体管—集成电路

Vacuum tube      transistor      Integrated circuits

IBM system /360 — 提出了系列机的概念。

3. 系列机 [ 相同或相似的操作集 (结构相同) ]  $\rightarrow$  程序可以向上移植而不能向下移植。

| 相同或相似的操作集

| 更高的速度

| 更多的 I/O 端口数

| 更大的内存容量

| 成本增加

4.  $\left\{ \begin{array}{l} CPI - \text{average cycle per instruction} \\ MIPS - \text{million instruction per second} \end{array} \right.$

| 加速比 —

(最后一题是?)

### 第3章

1. MAR：存储地址寄存器，每一次读写都指定内存地址  
    |  
    MHR：在地址缓冲寄存器，暂存送到内存或从内存读取的数据  
    |  
    I/O BR：用于I/O模块和CPU的数据缓冲寄存器  
    |  
    I/O AR：用于I/O AR 指定一个特定的I/O设备

2. 指令周期 { 取指周期  
                | 执行周期

3. CPU 中用一个称为PC的寄存器来保存指取指令的地址。  
    ↓ 指取后的结果  
    装入IR

4. 中断。详细见P14和后面的章节

   取消自然执行完再响应中断，响应时将CPU状态 save 并压栈

5. 连接各种模块的通路的集合称为互连结构。(interconnection structures)

6. 总线 (bus) 是连接两个或多台设备的通信通路

    Bus { 系统总线：连接计算机主要部件 (CPU, I/O, 存储器) 的总线。  
            | 数据 Bus  
            | 地址 Bus  
            | 控制 Bus  
            其他

    数据总线：数据总线宽度 (线的数量) 是决定系统总体性能的关键因素。

    地址总线：地址总线宽度决定了系统能够使用的最大的存储器容量。  
    控制总线

    高分辨率程度  
    低分辨率程度的寄存器  
    元件I/O端口  
    统一端口  
    独立端口

例子：“32位机” { 地址寄存器32位  
            | 数据寄存器32位  
            | 串长32位  
            | 总线宽度32位，寻址范围 $2^{32}$   
            | 最大内存  $2^{32} \times 32$   
            | 地址总线

    { 数据总线宽度 1 bit  
        | 地址总线宽度 n bit, 寻址范围 $2^n$

    一个字 { 指令  
            | 数据  
            | 地址的位数

    最大存储器位数

    地址总线宽度

7. 多层层次结构 (速度相近的在一起)

① 使用多总线的写入 P57

② 局部总线 连接 存储器 / CPU 和高速缓存

(P58)



③ 新时代采用了 高速总线  $\xleftarrow{\text{连接}} \text{高速缓存} \xrightarrow{\text{连接}} \text{存储器}$

↓  
局部总线

8. 总线  $\begin{cases} \text{专用总线} \text{ dedicated (separate data & address lines)} - \text{增加连线规格和成本} \\ \text{复用总线} \text{ multiplexed (shared lines, address valid or data valid control line)} - \text{控制电平复杂} \end{cases}$

9. 总线仲裁方式  $\begin{cases} \text{集中式} & \text{最脆弱} \\ \text{仲裁器 (仲裁逻辑)} & \text{仲裁器是叶结点} \\ \text{独立请求} & \text{有限的性能} \end{cases}$

(与 P53 中断方式)  
分布式  $\begin{cases} \text{特征: 1. 每个 module 都可以 claim the bus. 2. Control logic on all modules.} \\ \text{一个结点为总线} \\ \text{仲裁器 (仲裁逻辑)} \\ \text{独立请求} \\ \text{仲裁器} \\ \text{硬件} \end{cases}$

BR: bus request

BS: bus busy (指总线是 bus stop 呢!)

BG: bus grant

10. The operation in general.

Bus request

Bus arbitration

device addressing

data transfer

Bus release

12. 同步时序没有异步时序灵活,

因为同步总线上的所有设备都遵循固定的时钟频率, 系统不能发挥高性能设备的优势

对异步时序来说, 无论设备快慢, 都可以共享总线。

11. 内存的最大范围 = 地址总线  $\times$  数据总线 不一定对?

宽度对系统容量

有影响, 越宽

可以访问的单元越多



## 第5章 内部存储器

1. RAM { DRAM —便宜, 用于主存。用电容充内存数据, 需要周期性地充电(刷新)  
易失性,  
SRAM —贵, 用于Cache。

必须有直流电源供电。

一旦断电, 数据就会丢失。

ROM

/  
不要求提供电源,  
不能写入数据。

2. DRAM 有 RAS 和 CAS。

高选中 低选中

WE 读入(写)允许, OE 读(输出)允许

3.  $2^k - 1 \geq M + K$

(M是数据的位数, K是所需校验位的位数)

## 第6章 外部存储器

1. 磁盘容量 (别题忘吧!)

Pray 图 6.6 好好理解产磁道、扇区、柱面 (track, sector, cylinder)

2. 平均存取时间
- 寻道时间：从磁头对准磁道所花费的时间。  
旋转延迟：一旦磁道选定，磁盘控制器将处于等待状态，直到相关扇区转到磁头可读写位置。  
传送时间： $T_s = \frac{b}{rN}$  ( $b$  为所要传送的字节数,  $N$  为磁道所含字节数,  $r$  为旋转速率, 单位为转/秒)
- $$T_a = T_s + \frac{1}{2r} + \frac{b}{rN}$$

3. RAID [工业界: Redundant Array of Independent Disks 独立磁盘冗余阵列]

学术界: Redundant Array of Inexpensive Disks  
特点: RAID 是一组物理磁盘驱动器，在操作系统下被视为单一的逻辑驱动器。  
1. 数据分布在一组物理磁盘上。  
2. 容量等于存储奇偶校验信息，保证磁盘万一损坏时能恢复数据。





## 第10章 指令集，特征和功能

1. CPU 的操作被它所执行的指令所确定，这些指令被称为机器指令或加法机指令。

这些指令集合称为指令集。

2. 源和结果操作数位于如下四个范围

主存或寄存器  
CPU 寄存器  
I/O 设备  
立即数

之大多数 CPU 使用的是以下一条指令地址为隐含的单地址、双地址或三地址的指令。

(由程序计数器得到)

4. 隐含地址是被称为累加器 (AC) 的 CPU 寄存器。(单地址指令的第二个地址必须是隐含的)

5.

## 第11章

1. CPU 有多种指令格式。

[计算机结构都提供不止一种寻址方式。  
(上页数指全集)

2. 立即寻址：1. 用于定义和使用常数或设置变量的初值。2. 通用的补码存储值。

寻 找

直接寻址

间接寻址

寄存器寻址

寄存器间接寻址

偏移量寻址

① 偏移量寻址  $\Rightarrow$  [ 相对寻址 ( 是公用的是 PC 寄存器，局部性原理 ) ]

地址  $A$   $\rightarrow$  基址寄存器地址  $B$   $+ \text{ 相对 } A + \text{ 偏移量 }$

地址  $A = B + A$  ( 基址寄存器  $B$  + 偏移量  $A$  )

② 基址寻址 ( 寄存器间接寻址、隐含寻址方式 )

③ 隐含寻址 ( 寄存器间接寻址、隐含寻址方式 )

④ 寄存器寻址 ( 寄存器直接寻址、寄存器间接寻址 )

| 操作码 | 操作数  |
|-----|------|
|     | 地址字段 |

↓  
决定哪一种寻址方式

1. 不同的操作码用不同的寻址方式。

2. 指令格式中的一位或几位用做方式字段

## 第12章 CPU 结构和功能

- 1 寄存器  
用户可见寄存器  
控制和标志寄存器
- 2 所有CPU设计  
都包括常数为PSW的一个或一组 Register.  
—包含有条件代码加上其他状态信息



P<sub>350</sub>.351.351 中的图看前再好好看一下。

- 4 指令流水 (MSF 与 P<sub>352</sub>)

## 第13章 RISC (大量寄存器使用的暴力美学)

- 1 RISC 设计关键点  
(去性)  
1. 一个有限简单的指令集。  
2. 大量的通用寄存器使用编译器技术来优化寄存器的使用。  
3 强调指令流水的优化。
- 2 寄存器分成三个固定长度域  
主数据寄存器域 (适用于过程向上传递的参数)  
局部寄存器域 (用于局部变量)  
临时寄存器域 (用于当前过程与下一级过程交换参数和结果)

- 3 RISC 结构的特点 (每条指令)

- 寄存器到寄存器之间的操作 (大多数指令是 R  $\leftrightarrow$  R 的)  
简单的寻址方式  
简单的指令格式

- 4 提高流水线效率的方式  
延迟转移  
延迟装入  
循环展开

## 第14章 指令级并行性和超标量处理器

1. 超标量：为改善标量 (scalar) 指令执行性能而设计的机器。

本质：在不同流水线中不相关地执行指令的能力。（允许指令从不同于原程序顺序的次序来执行）

2. 超流水：利用了多条流水阶段所完成的任务只需比时钟周期一半还少的时间。

于是双倍的内部时钟速率允许在一个外部时钟周期中完成两个任务。

3. 二者的区别

{ 1. 在稳定状态下且有相同的指令数来执行。

2. 在程序开始和每次转移到目标时，②落后于① processor

失限制

{ 1. 基本数据相关性

2. 过程相关性

3. 资源冲突

4. 程序相关性

5. 反相关性

4. 指令级并行性：当) 指令中的指令是独立的，并因而能通过重叠来并行执行时，则存在...  
机器并行性：处理器获得指令级并行性好处的能力大小。

5. 超标量指令发射策略。

{ 1. 按序发射，按序执行

2. 有序 — 有序 —

3. 无序 — 无序 —

## 第 16 章

从 指令执行  $\Rightarrow$  周期  $\Rightarrow$  微操作 micro-operations

~~从~~  $P_{M2} \hookrightarrow P_{M3}$

所有的微操作

默写!

第17章

l { 硬布线 hardwired implementation  
微程序 microprogrammed implementation 实现/控制器.

