



## 计算机组成原理课程组

(刘旭东、肖利民、牛建伟、高小鹏、栾钟治)

Tel: 82338174

Mail: liuxd@buaa.edu.cn

liuxd@act.buaa.edu.cn

# 本课讲述:存储系统 **Memory & Storage**

- 一 . 存储系统概述
- 二 . 存储单元电路
- 三. 存储器芯片结构
- 四. 存储器扩展 ★



- 五. DRAM的刷新
- 六. 外部存储器
- 七. 虚拟存储器 →

#### 1.1 存储系统概述

#### ❖存储器分类

- >按介质分类:
  - 半导体存储器
  - 磁介质存储器
  - 光盘存储器



- 随机访问存储器 (Random Access Memory—RAM)
- 只读存储器 (Read Only Memory—ROM)
- 顺序访问存储器 (Tape)
- 直接访问存储器 (Disk)

#### >按功能分类:

- 高速缓冲存储器
- 主存储器
- 辅助存储器
- 控制存储器











### 1.1 存储系统概述

❖ 存储器的层次结构



二级存储系统指:高速缓冲存储器(Cache)十主存储器

- ❖静态随机访问存储器SRAM(Static RAM)
  - >SRAM: 静态存储器,相对动态而言,集成度低,但不必刷新。
- ❖动态随机访问存储器DRAM (Dynamic RAM)
  - ▶DRAM: 动态存储器,需要刷新,相对而言,集成度高。



**SRAM** 





**DRAM** 



http://hi.baidu.com/zhonggongxun/blog/item/23 438af3deccb21bb07ec583.html

#### ❖目前主流DRAM

▶SDRAM (Synchronous DRAM): 同步 DRAM,与系统总线时钟同步,避免了不必要的等待周期,减少数据存储时间,数据可在脉冲上升期便开始传输。SDRAM内存又分为PC66、PC100、PC133等不同规格,相应带宽分别为528MB/S、800MB/S和1.06GB/S。



▶ DDR (Double Data Rate) SDRAM: 双 倍速率SDRAM。SDRAM只在一个时钟 的上升期传输一次数据; 而DDR内存则在 一个时钟的上升期和下降期各传输一次数据,因此称为双倍速率SDRAM。DDR SDRAM可以在与SDRAM相同的总线频率下达到更高的数据传输率。



#### ❖目前主流DRAM

**▶DDR2** (Double Data Rate 2) SDRAM:

DDR2内存拥有两倍于DDR内存预读取能力,换句话说,DDR2内存每个时钟能够以4倍外部总线的速度读/写数据,在同样100MHz的工作频率下,DDR的实际频率为200MHz,而DDR2则可以达到400MHz。 DDR2内存采用1.8V电压,相对于DDR标准的2.5V,降低了不少。

▶DDR3(Double Data Rate 3)SDRAM: 频率 在800M以上,8bit预取设计,而DDR2为4bit 预取,这样DRAM内核的频率只有接口频率的 1/8,DDR3-800的核心工作频率只有100MHz。DDR3是在DDR2基础上采用的新型设计,与DDR2 SDRAM相比具有功耗和发热量较小、工作频率更高、降低显卡整体成本、通用性好的优势。



SDRAM-DDR2 (DIMM)



## ❖只读存储器 (ROM)

- ▶ 固定掩膜(Masks)ROM
- ▶ PROM (Programmable ROM): 一次性可编程
- ➤ EPROM (Erasable PROM): 可擦除可编程(紫外线擦除)
- ➤ EEPROM (Electrically Erasable PROM): 电擦除
- ➤ Flash Memory (闪存):本质上属于电擦除可编程ROM,如SM (Smart Media)卡、CF (Compact Flash)卡,MMC (Multi Media Card)卡、SD (Secure Digital)卡和记忆棒(Memory Stick)等。



Mask ROM



**EPROM** 



U盘上的Flash memory



# 本课讲述:存储系统 Memory & Storage

一. 存储系统概述

二. 存储单元电路

三. 存储器芯片结构

四. 存储器扩展

五. DRAM的刷新

六. 外部存储器

七. 虚拟存储器

#### 2.1 存储单元电路

## ❖基本要求

- ▶具有两种稳定(或半稳定)状态,用来表示 二进制的 1 和 0;
- >可以实现状态写入(或设置);
- > 可以实现状态读去(或感知)。

## 2.1 SRAM存储单元电路

❖SRAM存储单元电路(六管单元电路)



#### MOS管功能:

T1, T2: 工作管;

T3, T4: 负载管;

T5, T6: 门控管;

#### 稳定状态:

"1": T1 截止, T2 导通

"0": T2 截止, T1 导通

#### 保持状态:

字选线低电平,**T5** 和 **T6**截止,内部保持稳定。

#### 2.1 SRAM存储单元电路

**❖SRAM**存储单元电路工作原理(读出)



#### 稳定状态:

"1": T1 截止, T2 导通

"0": T2 截止, T1 导通

#### 保持状态:

字选线低电平,**T5** 和 **T6**截止,内部保持稳定。

#### 读出操作:

- 输入条件:字选线高电平
- ➤ T5和T6导通,如果存储单元原来保存信息是 "1",D线则 "读出"了内部状态(A点电平)则为高,否则为低。

#### 2.1 SRAM存储单元电路

❖SRAM存储单元电路工作原理(写入)



#### 稳定状态:

"1": T1 截止, T2 导通

"0": T2 截止, T1 导通

#### 保持状态:

字选线低电平,**T5** 和 **T6**截止,内部保持稳定。

#### 写入操作:

写 1: D线高电平,D 线低电平,字选线高电平,T5 和 T6 导通,T1截止,T2导通,写入 1。

写 0: D线低电平, D 线高电平, 字选线高电平, T5 和 T6 导通, T2截止, T1导通, 写入 0。

#### 2.2 DRAM存储单元电路

#### ❖ DRAM存储单元电路(单管单元电路)



- ➤ Cs电容 <<Cd电容</p>
- Cs上有电荷表示 '1'
- Cs上无电荷表示 '0'
- 保持状态:字选线低电平,T截止,理论上内部保持稳定状态。

注意: 在保存二进制信息"1"的状态下, Cs有电荷, 但Cs存在漏电流, Cs上的电荷会逐渐消息, 状态不能长久保持, 在电荷泄漏到威胁所保存的数据性质之前, 需要补充所泄漏的电荷, 以保持数据性质不变。这种电荷的补充称之为刷新(或再生)。

#### 2.2 DRAM存储单元电路

**❖DRAM**存储单元电路工作原理(读出)



读出时: D 线先预充电到 Vpre=2.5V, 然后字选线高电平, T导通

- 若电路保存信息1, Vcs=3.5V, 电流方向从单元电路内部向外;
- 若电路保存信息 0, Vcs=0.0V, 电流方向从外向单元电路内部;
- 因此根据数据线上电流的方向可判断单元电路保存的是 1还是 0。
- 读出过程实际上是Cs与Cd上的电荷重新分配的过程,也是Cs与Cd上的电压重新调整的过程。Cd上的电压,即是D线上的电压。

### 2.2 DRAM存储单元电路

◆DRAM存储单元电路工作原理(写入)



写入操作: D 线加高电平(1)或低电平(0),字选择线置高电平,T导通;

- 写1时,D线高电平,对Cs充电;
- 写0时,D线低电平,Cs放电;

## ❖固定掩膜ROM单元电路



含二级管的电路 表示1,不含电 路表示0



含三级管的电路 表示1,不含电 路表示0



含MOS管的电路 表示0,不含电 路表示1

### ❖可编程的PROM单元电路



- ▶出厂时所有位均为1。
- ▶编程时(写入数据),对写**0**的 单元加入特定的大电流,熔丝被 烧断,变为另一种表示**0**的状态 ,且不可恢复。
- ▶工作时,加入正常电路。

## ❖紫外线擦除可编程的EPROM单元电路



- ➤出厂时所有位均为 1, FAMOS ( 浮空栅极MOS) G极无电荷,处 于截止状态。
- ➤编程时(写入数据),对写0的单元加入特定的电压,FAMOS上的G极与D极被瞬时击穿,大量电子聚集到G极上,撤销编程电压后,G极上的聚集的电子不能越过隔离层,FAMOS导通,表示0。
- ▶工作时,加入正常电压,FAMOS 的状态维持不变。
- ▶擦除时,用紫外线照射,FAMOS 聚集在G极上的电子获得能量,越 过隔离层泄漏,FAMOS恢复截止 状态。

### **❖EEPROM**单元电路



- ▶与EPROM相似,它是在EPROM 基本单元电路的浮空栅的上面再生 成一个浮空栅,前者称为第一级浮 空栅,后者称为第二级浮空栅。第 二级浮空栅引出一个电极,接某一 电压V<sub>G</sub>。
- ▶若V<sub>G</sub>为正电压,第一浮空栅极与漏极之间产生隧道效应,使电子注入第一浮空栅极,即编程写入。
- ▶若使V<sub>G</sub>为负电压,强使第一级浮空栅极的电子散失,即擦除。擦除后可重新写入。

## ❖存储单元的符号表示



# 本课讲述:存储系统 Memory & Storage

一. 存储系统概述

二. 存储单元电路

三. 存储器芯片结构

四. 存储器扩展

五. DRAM的刷新

六. 外部存储器

七. 虚拟存储器

❖存储芯片结构 (一维地址结构)

1024×2: 1024 个字单元,每个字单元 2 个二进制位。



- ❖问题: 如何识别这些字单元?
  - ▶1024×2: 1024 个字单元,需要1024个不同的标示。
  - ▶地址编码:译码电路使得字选择线 W<sub>i</sub>处于工作状态的输入信号(二进制信号),称为W<sub>i</sub>所选中字单元的地址编码(简称地址)。
  - >对于每一个字单元, 地址是唯一的。



- ❖二维地址结构(SRAM)
  - ▶ 芯片示例: 4096 × 4 (4096 个字,每个字 4 位)
  - ➤ 4096×4 = 2<sup>14</sup> 个位单元
  - ▶ 存储矩阵: 2<sup>7</sup>×2<sup>7</sup> (128行×128列)



- ❖二维地址结构(SRAM): 4096×4: 4096 个字,每个字 4 位
  - ▶ 存储矩阵: 2<sup>7</sup>×2<sup>7</sup> (128行×128列)
  - ▶ 行译码: 行地址 7位, 一行含32个字共128位, 任一时刻只有1个字(4位数据线)被选中。



- ❖ 二维地址结构(SRAM): 4096×4: 4096 个字, 每个字 4 位
  - ▶ 存储矩阵: 2<sup>7</sup>×2<sup>7</sup> (128行×128列)
  - ▶ 一行包括32个字,要进行32选1的译码(Y译码),列地址5位



❖ 二维地址结构(SRAM): 4096×4: 4096 个字,每个字 4位。



#### ❖ DRAM芯片结构

- ▶ 芯片示例: 4096×4 DRAM (4096 个字,每个字 4 位)
- ▶ 4096个字 = 2<sup>12</sup>, 12位地址
- ➤ DRAM芯片封装的特殊: 行列地址管脚复用, 行列地址各6位。
- ▶ 存储矩阵: 2<sup>6</sup>× (2<sup>6</sup>×4) (64行×256列)



### 存储芯片结构示例



## 存储芯片结构示例

#### ❖ DRAM 4M×4 DRAM芯片结构(内部包含刷新电路)



#### 存储芯片结构示例

#### ❖ DRAM 2164A 芯片结构 (64K×1)



# 本课讲述:存储系统 Memory & Storage

一. 存储系统概述

二. 存储单元电路

三. 存储器芯片结构

四. 存储器扩展

五. DRAM的刷新

六. 外部存储器

七. 虚拟存储器

#### 4.1 存储器芯片的扩展(位扩展)

#### 例: 1Kx4 SRAM芯片构成1Kx8的存储器

- ▶1K×4 芯片管脚:
  - 10个地址管脚 A9~A0
  - 4个数据管脚 D3~D0
  - 1个片选输入管脚 CS#
  - 1个读写控制管脚 WE#
  - 芯片地址空间: 000H~3FF H
- ▶CPU访问存储器需提供:
  - 地址总线10根: AB9~AB0
  - 数据总线8根: DB7~DB0
  - 读写控制信号: MemW
  - 存储器地址空间: 000H~3FF H
- ▶需要芯片: (1K×8) / (1K×4) = 2片
  - 地址管脚:都连接到AB9~AB0
  - 数据管脚:分别连接到 DB7~DB4和 DB3~DB0
  - 芯片读写控制管脚: 连接MemW



### 4.1 存储器芯片的扩展(位扩展)

例:1K×4的SRAM存储芯片构造1K×8的存储器



#### 4.2 存储器芯片的扩展(字扩展)

#### 例: 1Kx8 SRAM芯片构成4Kx8的存储器

- ▶1K×8 芯片管脚:
  - 10个地址管脚 A9~A0
  - 8个数据管脚 D7~D0
  - 1个片选输入管脚 CS#
  - 1个读写控制管家WE#
  - 芯片地址空间: **000H~3FF** H
- ▶ CPU访问存储器需提供:
  - 地址总线10根: AB11~AB0
  - 数据总线8根: DB7~DB0
  - 读写控制信号: MemW
  - 存储器地址空间: 000H~FFF H
- ▶ 需要芯片数: (4K×8) / (1K×8) = 4片
  - 地址管脚:都连接到AB9~AB0
  - 数据管脚: 都连接到 DB7~DB0
  - 芯片读写控制管脚:连接MemW
- ▶一个2-4译码器产生4个片选信号
  - 译码器输入: AB11~AB10
  - 译码器输出:分别接4个芯片片选管脚



### 4.2 存储器芯片的扩展(字扩展)

#### 例: 1Kx8 SRAM存储芯片构成4Kx8的存储器



## 4.3 存储器芯片的扩展(混合扩展)

#### 例: 4Kx4 SRAM存储芯片构成16Kx8的存储器

- ▶4K×4芯片:
  - 12个地址管脚 A11~A0
  - 4个数据管脚 D3~D0
  - 1个片选输入管脚 CS#
  - 1个读写控制管脚 WE#
  - 芯片地址空间: **000H~FFF H**
- ▶CPU向存储器提供:
  - 地址总线14根: AB13~AB0
  - 数据总线8根: DB7~DB0
  - 读写控制信号: MemW
  - 存储器地址空间: 0000H~3FFF H
- ▶需要芯片数: (16K×8) / (4K×4) = 8片
  - 分4组(字扩展),每组2个芯片(位扩展)
- ▶一个2-4译码器产生4个片选信号
  - 译码器输入: AB13~AB12
  - 译码器输出:分别接4组芯片片选管脚



#### 4.3 存储器芯片的扩展(混合扩展)

#### 4Kx4 SRAM存储芯片构成16Kx8的存储器地址空间划分





### 4.3 存储器芯片的扩展(混合扩展)

4Kx4 SRAM存储芯片构成16Kx8的存储器连接图



### 存储器芯片的扩展示例(续)





74LS138 引脚图



74LS138 逻辑符号

#### CPU与主存的连接(示例)

CPU地址线A15~A0,数据线D7~D0,WR为读/写信号,MREQ为访存请求信号。0000H~3FFFH为系统程序区,4000H~FFFFH为用户程序区。用8K×4位ROM芯片和16K×8位RAM芯片构成该存储器,要求说明地址译码方案,并将ROM芯片、RAM芯片与CPU连接。

解:因为0000H~3FFFH为系统程序区,ROM区高两位总是00,低14位为全译码。

ROM区大小为: 2<sup>14</sup>×8位=16K×8位=16KB

ROM芯片数为:  $16K \times 8位 / 8K \times 4位 = 2 \times 2 = 8$ , 字方向扩展2倍, 位方向扩展2倍

ROM芯片内地址位数为13位,连到CPU低13位地址线A12~A0

因为4000H~FFFFH为用户程序区,RAM区高两位是01、10、11,低14位为全译码。

RAM区大小为: 3×2<sup>14</sup>×8位=3×16K×8位=48KB

RAM芯片数为:  $48K \times 8位 / 16K \times 8位 = 3 \times 1 = 3$ ,字方向上扩展3倍,位方向上不扩展。

RAM芯片内地址位数为14位,连到CPU低14位地址线A13~A0。



#### 存储器的符号表示

- ❖ 读操作
  - ▶输入
    - 读单元地址: Address
    - 读控制信号: MemRead
  - ▶输出
    - 读出数据: Readdata
- ❖ 写操作
  - ▶输入
    - 写单元地址: Address
    - 写入数据: Writedata
    - 写控制信号: MemWrite
  - ▶输出:无



# 本课讲述:存储系统 Memory & Storage

一. 存储系统概述

二. 存储单元电路

三. 存储器芯片结构

四. 存储器扩展

五. DRAM的刷新

六. 外部存储器

七. 虚拟存储器

#### ❖DRAM单管单元电路的工作特征



 $V_{d}: D$ 线在读出调整后的电压

 $V_{cs}:C_{s}$ 原来的电压

 $\Delta V$ : D线上读出过程前后的变化量

 $\Delta V = V_d' - V_{pre} = (V_{cs} - V_{pre}) \times C_s / (C_s + C_d)$ 

由于 $C_d$ 要比 $C_s$ 大一两个数量级,所以

 $\Delta V$ 不会太大(1%到10%),一般为100mV左右。

D线上的电压在读出过程中的变化量实例计算:

假定 $C_s = 1$ pf, $C_d = 50$ pf, $V_{pre} = 2.5V$ 

存储1时,  $V_{cs} = 3.5V$ , 存储0时,  $V_{cs} = 0V$ 

则:

$$\Delta V(1) = (3.5v - 2.5v) \times 1pf / (1pf + 50pf) = 19.6mv$$

$$\Delta V(0) = (0v - 2.5v) \times 1pf / (1pf + 50pf) = -49mv$$

❖DRAM存储单元电路的信号刷新问题



1. 由于读出过程D线电压变化量较小,需要对变化量进行放大才能得到有效的数据,所以单管存储单元电路中D线上必须增加传感放大器(Sense Amplifier)。

- 1. (没有感应放大器时)读出操作是一种破坏性操作,读1时,Cs放电; 读0时,Cs充电;所以读出操作后,原保存在Cs上的数据(电荷)被破坏,应该立即进行恢复(重写或刷新)。
- 2. 在保持状态下,T管截止,Cs与外部隔开,但Cs两级间存在漏电流,所以,Cs上的电荷也会出现变化,必须在一个时间内重写数据,这个时间称为单元电路的刷新周期,一般为4ms、8ms。
- 2. 刷新由传感放大器在读出过程中同时完成。在D线上增加了传感放大器 后读过程实际上就是一次刷新过程。事实上,DRAM的刷新就是通过这 样的读操作来实现的。

❖读"1"过程中的D线电压变化情况(刷新过程)



❖读"0"过程中的D线电压变化情况(刷新过程)



## 5.2 DRAM存储芯片的刷新

❖ DRAM芯片: 4096×4 DRAM



按行刷新,每次刷新1行

## ❖DRAM的刷新

- >刷新操作: 读操作;
- >按行刷新、所有芯片同时进行;
- ▶刷新操作与CPU访问内存分开进行;
- ➤刷新周期: 2ms, 4ms, 8ms,...,64ms;
- >刷新地址及刷新地址计数器

# **❖**集中刷新方式

- ➤ 将刷新周期分成两部分,在一个时间段内刷新存储器所有行, 另一个时间段CPU访问内存,刷新电路不工作。
- ▶ 集中刷新时间长,此时存储器不能正常读写(访存死区)。很少使用该方法。
- ▶ 集中刷新间隔 = 刷新周期



# ❖分散刷新方式

- ▶ 一个存储周期分为两段:前一段用于正常读写,后一段用于刷新操作。一个存储周期刷新1行,下一存储周期刷新另一行,直至最后1行后,又开始刷新第1行。
- ▶ 存储周期加长,效率降低,很少使用。
- ➤ 分散刷新间隔 = 刷新行数×存储周期 < 刷新周期



# ❖异步刷新方式

- ▶ 结合前两种方式,保证在一个刷新周期内将存储芯片内的所有 行刷新一遍,且只刷新一遍。
- > 异步刷新间隔 = 刷新周期
- 》以128行为例,在2ms时间内必须轮流对每一行刷新一次,即每隔2ms/128=15.5μs刷新一行。这时假定读/写与刷新操作时间都为0.5μs,则可用前15μs进行正常读/写操作,最后0.5μs完成刷新操作。



#### 非易失性存储器

## ❖非易失性内存(Nonvolatile RAM, NVRAM)

▶铁电存储器:FRAM

▶ 电阻式存储器:ReRAM

➤磁阻存储器:MRAM, SRAM的高速读写性能, DRAM的集成度, ROM的非易失性特征,功耗低





**FRAM** 

**MRAM** 

# 本课讲述:存储系统 Memory & Storage

一. 存储系统概述

二. 存储单元电路

三. 存储器芯片结构

四. 存储器扩展

五. DRAM的刷新

六. 外部存储器

七. 虚拟存储器

#### 磁表面存储原理

#### ❖磁表面存储器

- ▶磁头: 体积小, 重量轻;
- ▶软盘采用接触方式,硬盘采用浮动方式(浮动磁头,薄膜磁头)
- ightharpoonup 磁记录材料:极细的 $\gamma$ -Fe<sub>2</sub>O<sub>3</sub>颗粒,涂在(或喷射)在盘面上,形成细密、均匀、光滑的磁膜。
- ▶片基(载体):塑料(软盘),金属(硬盘)

## ❖记录原理

- > 通过磁头与介质的相对运动完成读写操作。
- ▶写入:根据写入代码确定写入驱动电流的方向,使磁表面被磁化的极性方向不同,以区别"0"和"1";
- ▶读出:磁头相对磁化单元做切割磁力线运动,磁化单元的极性决定了感应电势的方向,以此区别"0"和"1"。





## 磁记录编码方式

❖磁记录编码方式实际上是写入电流的变化方式



#### 磁记录编码方式

## ❖评价记录方式的主要指标

- > 可靠性: 归零制低, 调相制高;
- ➤ 编码效率:用记录一位信息的最大磁化翻转次数表示; FM与PM为2, NRZ为1;
- ➤ 自同步能力:能否直接从读出的信号中提取同步信号;NRZ没有自同步能力,PM,FM等都具备自同步能力;

# ❖结构

- ▶全密封: 浮动磁头组件、磁头驱动机构、盘片和主轴组件和前置控制 电路等密封在一起。
- ▶磁头: 非接触式浮动磁头,盘面分启停区和数据区。不工作时,磁头停留在启停区;工作时,磁盘高速旋转带动气流使磁头漂浮在磁表面上方,头盘间隙仅有0.1微米~0.3微米;
- ▶读写电路:安装在磁头臂接近磁头的地方,以减少干扰;

▶旋转速度: 3600RPM, 7200RPM, 10000RPM, 15KPRM; 一般等角

速度旋转。







#### ❖ 磁盘存储结构

- ▶盘面:一个磁盘包含若干盘片,每 盘片分上下两个盘面,每个盘面由 一磁头负责读写
- >磁道:磁盘表面的同心圆环
- ➤扇区:每个磁道包含若干扇区,扇区是磁盘数据读写的最小单位,扇区容量一般为512~4096字节(默认为512字节,默认每个磁道包含的扇区数是相同)
- ▶柱面(cylinder):不同盘面相同 半径磁道构成的圆柱



磁盘上的磁道、扇区和簇

#### ❖ 扇区的地址表示:

扇区地址: Cylinder# Head# Sector#

❖ 补充: 现在的硬盘都使用ZBR(

ZonedBitRecording分区域记录)技术,盘片表 面从里向外划分为数个区域,不同区域的磁道扇 区数目不同,同一区域内各磁道扇区数相同,盘 片外圈区域磁道长扇区数目较多,内圈区域磁道短 扇区数目较少,大体实现了等密度,从而获得了 更多的存储空间。大多数产品划分了16个区域, 最外圈的每磁道扇区数正好是最内圈的一倍( 373~746正是啦)。这样的话, 当磁盘主轴马 达按一定角速度(每秒N转)旋转的时候,越往 外,线速度越大,单位时间内读取的扇区数就越 多,传输率就越高。(是不是也可以稍微理解通 常把系统盘数据放在磁盘最外圈的原因了)



## ❖扇区数据格式示例(Segate ST506 磁盘扇区格式)



#### 磁盘的性能参数

## ◆性能指标

- > 记录密度
  - □ 道密度: 磁盘沿半径方向单位长度的磁道数;
  - □ 位密度: 单位长度磁道记录二进制的位数。
- ➤ 存储容量: 磁头数×磁道(柱面)数×每道扇区数×每扇区字节数
- ightharpoonup 寻道时间  $T_s$ : 磁头从当前位置定位到目标磁道所需时间(用平均值表示):
- ▶ 寻区时间 T<sub>w</sub>: 磁头定位到目标磁道后,等待目标扇区旋转到 磁头下所需的时间(用平均值表示);
- ightharpoonup 访问时间(也称寻址时间) $T_A$ :  $T_A = T_S + T_W$
- ➤ 数据传输率 D<sub>r</sub>: 单位时间内传输的数据位数 (b/s)

### 软磁盘

# ❖软盘(Floppy Disk)

▶尺寸: 5.25 inch, 3.5 inch

▶容量: 360KB, 1.2MB, 720KB, 1.44MB





#### ❖IDE硬盘

➤IDE(Integrated Drive Electronics): 80年代出现,主要为 IBM PC 兼容机所用的低价磁盘,由BIOS处理磁盘的读写等操作。

#### ❖SCSI硬盘

- ▶SCSI(Small Computer System Interface):接口与IDE不同,具有更高的数据传输率。
- ▶SCSI接口上所有设备(不一定是磁盘)可以同时操作,这是与IDE和最大的不同之处。

| Name                  | Data bits | Bus Mhz | MB/Sec  |
|-----------------------|-----------|---------|---------|
| SCSI-1                | 8         | 5       | 5       |
| SCSI-2                | 8         | 5       | 5       |
| Fast SCSI-2           | 8         | 10      | 10      |
| Fast & Wide SCSI-2    | 16        | 10      | 20      |
| Ultra SCSI            | 16(32)    | 20      | 40      |
| Ultra2 Wide SCSI      | 16        |         | 80      |
| Ultra-160m/Ultra-320m | 16        |         | 160/320 |

#### \*RAID

- ➤ Reduntant Array of Independent Disks(独立冗余磁盘阵列)
- RAID由多个物理构成,但被操作系统当成一个逻辑磁盘,数据分布在不同的物理磁盘上,冗余磁盘用于保存数据校验信息,校验信息保证在出现磁盘损坏时能够有效的恢复数据;
- **▶ RAID**特点
  - □ 通过把多个磁盘组织在一起作为一个逻辑卷提供磁盘跨越功能
  - □ 通过把数据分成多个数据块(Block)并行写入/读出多个磁盘以提高访问磁盘的速度
  - □ 通过镜像或校验操作提供容错能力
- ➤ RAID包括六种不同模式: RAID 0, RAID1, RAID2,RAID3,RAID4和 RAID 5。

#### ❖RAID 0: 无差错控制的带区组

- >实际上不应属于RAID家族成员,完全没有冗余;
- ➤数据条带(Strip)化分布在不同的物理磁盘上。Strip可以是物理 磁盘上的一块存储区(扇区或其他单位)。
- ▶磁盘组中每一个磁盘同一位置的磁盘区构成一个逻辑上的带区, 所以一个带区分布在多个磁盘上。
- ▶单个I/O 操作访问的数据分布在一个带区上时,可实现I/O操作的 并行处理,改善数据传输性能。



#### ❖RAID 1: 镜像结构

- >简单镜像磁盘冗余方案,成本太高;
- ▶与RAID 0类似,用户数据和系统数据条带(Strip)化分布在不同的物理磁盘上(包括镜像磁盘)。
- ▶读操作同时在两组磁盘中进行,数据从访问时间小的磁盘组中获得 ,所以,读操作性能得到改善。
- ▶写操作同时在两组磁盘中进行,写操作的访问时间以速度慢的为准 ,所以,写操作性能指标不高。
- >出现磁盘损坏时,数据恢复简单。



#### ❖RAID 2: 带海明校验

- ➤ 采用完整的并行访问技术,所有磁盘在任何时刻都并行地响应I/O 请求; 磁盘组中物理磁盘处于完全同步状态,以保证任何时刻,所有磁盘的磁头都处于相同位置。
- >数据按较小的条带(一个字或一个字节)分布在不同的磁盘上。
- ▶根据磁盘数据计算错误校验码(比如海明码),校验码按位分布在冗余磁 盘对应位置上。
- ▶数据传输率高;访问效率高;
- ▶成本比较高(比RAID1稍低)



- ❖RAID 3: 带奇偶校验码的并行传送
  - ▶与RAID2一样,采用并行访问技术;
  - >数据按较小的条带(一个字或一个字节)分布在不同的磁盘上。
  - ▶校验码是简单的奇偶校验码(1位),保存在独立的冗余磁盘对应位 置上。
  - >一个磁盘损坏,可以方便地实现数据恢复;
  - ▶数据传输率高;访问效率高;



#### ❖RAID 4: 带奇偶校验码的独立磁盘结构

- ▶采用独立访问技术,每个磁盘独立工作,分散的I/O请求将得到很好的并行处理
- ▶数据按较大的条带分布在不同的磁盘上。
- ▶校验码是奇偶校验码,保存在独立的冗余磁盘对应位置上。
- >一个磁盘损坏,可以方便地实现数据恢复;
- ▶写操作效率较低,需要计算奇偶校验位,磁盘组中一个磁盘写操作 ,均需要读取原检验信息,重新计算校验信息,再写校验信息。



## 硬磁盘的类型

- ❖RAID 5:分布式奇偶校验的独立磁盘结构
  - ▶与RAID 4的差别仅在于校验信息的保存位置;数据校验码作为条带的一部分保存在磁盘组不同的磁盘中



#### CD-ROM

- ▶ 规格: 直径120mm,厚度1.2mm,中心孔径 15mm
- 结构:树脂片基,铝反射层,保护膜,印刷层
- ➤ 数据记录区: 32mm宽的环形记录带。
  - □ 等线速度方式: 一个螺旋环 环绕22188次(600环/mm, 总长度约 5.6km长)
  - □ 等角速度方式

#### ■数据记录

- ▶ 凹点(Pit)表示 0
- ▶ Land 表示 1



## ❖CD-ROM的数据格式

| 12 Bytes SYNCH |         |    |            |                 |               |
|----------------|---------|----|------------|-----------------|---------------|
| 00             | FF x 10 | 00 | 4 Bytes ID | 2048 Bytes Data | 288 Bytes ECC |
| Sector Format  |         |    |            |                 |               |

- ➤ Symbol: 14位,8位数据,6位海明校验位(看成一个Bytes);
- Frame: 42个连续Symbol (588bits), 其中192位(24字节)存储数据, 其余396位用于错误纠正与控制;
- ➤ Sector: 98个frame构成一个Sector(总计2352Bytes)。
- ▶ 总容量: 650MB
- 等线速度旋转时:单速: 120cm/s(最内圈530RPM, (最外圈 200RPM), 75 Sectors/Sec(150KB/S)。
- 制作过程:母板压模
- 读机制: 0.78微米波长红外激光,根据反射光的强度判断是0还是1;

#### CD-R (Recordables)

➤ 在片基(树脂)与反射层(金)中增加了一层染料层作为数据记录层,初始状态下,染料层透明,在写入状态时,高能量(8-16mw)使照射处的染料变色,变成不透明点,不可再恢复成透明状态。读出状态下(0.5mw),根据透明不透明判断是0还是1。



#### CD-RW (Rewritables)

- ▶ 与CD-R的差别是采用合金层代替染料层。一般采用银、铟、锑、碲合金。该合金具有两种稳定状态:透明状态(晶体结构)和不透明状态(无序结构),初始时为晶体结构。
- ➤ CD-RW工作时采用三种不同功率的激光:
  - □ 大功率(写):合金熔化,由晶体结构变为无序结构;
  - □ 中等功率 (擦除): 合金熔化, 由无序结构变为晶体结构;
  - □ 小功率(读)

# DVD (Digital Video Disk)

#### 与CD-ROM的差别:

- Pit直径更小(0.4微米);
- 环绕密度更高(0.74微米, CDROM是1.6微米);
- $\triangleright$  0.65微米波长红色激光(CDROM是0.78微米的红外激光);
- 》 容量: 单面单层4.7GB, 单面双层8.5GB, 双面单层9.4GB, 双面双层17GB。
- ▶ 数据传输率: 单速DVD 1.4M Bytes/Sec。

# 本课讲述:存储系统 Memory & Storage

一. 存储系统概述

二. 存储单元电路

三. 存储器芯片结构

四. 存储器扩展

五. DRAM的刷新

六. 外部存储器

七. 虚拟存储器

- 存储器管理: 操作系统的功能
  - ▶操作系统:合理地管理、调度计算机的硬件资源。存储器作为一种空间资源也由**OS**来管理;
  - ➤ CPU执行的程序:总是在操作系统和用户程序之间切换。主存中间时要存储OS和用户程序。磁盘中也要存储OS和用户程序;
  - ▶ CPU中的存储器管理部件MMU 协助OS完成存储器访问。



OS为"进程"分配存储器资源,所以,先了解一下进程的概念。

## ◆一个典型程序的转换处理过程

```
经典的"hello.c"C-源程序
1 #include <stdio.h>
2
3 int main()
4 {
5 printf("hello, world\n");
6 }
程序的功能是:
```

输出"hello,world"

#### hello.c的ASCII文本表示

# i n c l u d e < s p > < s t d i o . 35 105 110 99 108 117 100 101 32 60 115 116 100 105 111 46 h > \n \n i n t < s p > m a i n ( ) \n { 104 62 10 10 105 110 116 32 109 97 105 110 40 41 10 123 \n < s p > < s p > < s p > < s p > p r i n t f ( " h e l 10 32 32 32 32 312 114 105 110 116 102 40 34 104 101 108 l o , < s p > w o r l d \n " ) ; \n } 108 111 44 32 119 111 114 108 100 92 110 34 41 59 10 125



# ❖Hello的执行过程

- ▶Unix系统Shell命令行输入: hello,回车
- ▶Shell程序调用驻留在内存的"加载器"程序,由加载器从磁盘上找到特定的hello目标文件,将其指令代码和数据("hello,world\n")从磁盘读到主存;
- unix> ./hello [Enter] hello, world unix>

- ▶处理器从hello程序的指令代码开始执行;
- ▶ Hello程序将 "hello, world\n"串中的字节从 主存读出,送到显示器输出。

问题: hello程序何时被装入? 谁来装入? 被谁启动? 每次是否被装到相同的地方? Hello程序是否知道还有其他程序在同时运行? 是否直接访问硬件资源?

- ❖操作系统在程序执行过程中的作用
  - ▶ Hello执行过程中,其本身没有直接访问键盘、显示器、磁盘和主存储器这些硬件资源,而是依靠操作系统提供的服务来间接访问。
  - >操作系统的两个主要的作用:
    - 硬件资源管理
    - 为用户使用系统提供一个操作接口
  - ▶操作系统通过三个基本的抽象概念(进程、虚拟存储器、文件)实 现硬件资源管理
    - 文件(files)是对I/O设备的抽象表示
    - 虚拟存储器(Virtual Memory)是对主存和磁盘I/O的抽象表示
    - <del>进程(processes</del>)是处理器、主存和I/O设备的一种抽象表示, 实际上是对运行程序的抽象表示



- ❖进程:操作系统对运行程序的抽象
  - ▶一个系统上可以同时运行多个进程,而每个进程都认为自己独占系统,实际上,操作系统让处理器交替执行不多进程中的指令;
  - ▶操作系统的交替执行机制称为"上下文切换(context switching)'
  - ▶进程的上下文:指进程运行所需的所有状态信息,例如:PC、寄存器堆的当前值、主存的内容、段/页表等
    - 系统中有一套状态单元存放当前运行进程的上下文
  - ▶上下文切换过程: (任何时刻,系统中只有一个进程正在运行)
    - 把正在运行的进程换下,换一个新进程到处理器执行,上下文切换时,必须保存换下进程的上下文,恢复换上进程的上下文



开始,Shell进程等待命令行输入 输入"Hello"后Shell进行系统调用 OS保存shell上下文,创建并换入hello进程 Hello进程中止时,进行系统调用 OS恢复shell进程上下文,并换入shell进程 由于在一个进程的整个生命周期中,有不同 进程在处理器交替运行,所以运行时间很难 准确、重复测量。

- ❖虚拟存储技术的动机
  - >(早期)采用单道程序运行,系统的主存中包含:
    - 操作系统(常驻监控程序)
    - 正在执行的一个用户程序

所以无需进行存储管理,即使有也很简单

- >采用多道程序运行,主存中包括操作系统和若干用户程序(进程)
  - 多道程序(进程)如何有效安全的共享内存?
    - 同时运行的程序对内存需求之和超过计算机实际内存容量;
    - 局部性原理: 某个时间点, 只需要一部分活跃的程序
  - 如何消除小的主存容量对编程的限制?
    - 编写程序时,不知道程序运行时将和哪些程序共享内存;编程者总是希望把每个程序编译在它自己的地址空间中。
    - 单用户程序大小超过主存容量

#### ■解决之道

- ▶內存管理采用交换机制(硬件和操作系统实现),进程保存在辅存中,进程执行时,只将其<mark>活跃部分</mark>调入内存(局部性原理)。 此时主存可以视为辅存的"高速缓存"。
- ▶这样一种<mark>把主存当做辅助存储器的高速缓存技术</mark>,称为虚拟存储 技术,也称为虚拟存储器(virtual memory)。
- ➤虚拟存储器能从逻辑上为用户提供一个比物理存贮容量大得多、 可寻址的"主存储器"。
- ▶虚拟存储器的容量与物理主存大小无关,而受限于计算机的地址 结构。



## MIPS程序在内存中的存放

◆ Text: 程序代码段

◆ Static data: 全局变量

例如, C语言中的静态变量, 常数数组和串

\$gp 寄存器初始地址±偏移量 寻址本段内存

◆ Dynamic data: 堆 例如, C中的malloc, Java中的 new

◆ Stack: 栈,自动存储区



#### ■虚存空间与物理空间

- 用户程序空间:用户程序给出的指令和数据地址不是真正的主存实际地址,称为虚地址或逻辑地址,其对应的存储空间称为虚存空间或逻辑地址空间。
- 物理内存空间:真正的主存实际地址称为实地址或物理地址, 其对应的存储空间称为物理空间或主存空间。

# ■虚拟存储器要解决的问题

- ▶ 虚存空间与物理空间之间的数据交换:交换哪些数据?每次交换多少?
- 虚地址与实地址的转换问题:虚地址格式、实地址格式、怎么 判断当前访问的虚地址对应的数据是不是在物理空间中,如何 把虚地址转换为实地址?如何加速这种判断和转换?
- > 缺失处理和替换策略:访问的内容不在物理空间中怎么处理?

- ❖虚拟存储管理模式:简单分区模式
  - 主存分配:
    - 操作系统: 固定
    - 用户区: 分区
  - 简单分区方案:使用长度不等的固定长分区 (fixed-size partition)。
  - 当一个进程调入主存时,分配给它一个能容 纳它的最小的分区。

例如,对于需196K的进程可分配256K的分区。

- 简单分区方式的缺点:
  - 因为是固定长度的分区,故可能会浪费主存空间。多数情况下,进程对分区大小的需求不可能和提供的分区大小一样。

操作系统 128K 64K 古 192K 定 分 256K X 举 例 384K

问题:如何生成物理地址?

## ❖虚拟存储管理模式:可变分区模式

- 分配的分区大小与进程所需大小一样。
- 特点:开始较好,但到最后在存储器中会有许多小空块出现。时间越长,存储器中的碎片就会越来越多,因而存储器的利用率下降。



更有效的方式是分页!

- ❖虚拟存储管理模式:分页模式
- 基本思想:
  - 把内存分成固定长且比较小的存储块,每个进程也被划分成固定长的程序块
  - 程序块(页/page)可装到存储器可用的存储块 (页框/page frame)中
  - 无需用连续页框来存放一个进程
  - 操作系统为每个进程生成一个页表
  - 通过页表(page table)实现逻辑地址向物理地址 转换(Address Mapping)
- 逻辑地址(Logical Address):
  - 程序中的指令所用的地址
- 物理地址(physical或Memory Address):
  - 存放指令或数据的实际内存地址

问题: 是否需要将一个进程的全部都装入到内存? 根据程序访问的局部性可知: 可以仅把当前活跃的 页面调入主存,其余留在磁盘上!



浪费的空间最多是最后一页的部分!

## ❖虚拟存储系统的特征

- ▶程序员在比实际主存空间大得多的逻辑地址空间中编写程序
- ▶程序执行时,把当前需要的程序段和相应的数据块调入主存,其他暂不用的部分存放在磁盘上
- ▶指令执行时,通过硬件(MMU)将逻辑地址(也称虚拟地址或虚地址) 转化为物理地址(也称主存地址或实地址)
- ▶在发生程序或数据访问失效时,由操作系统进行主存和磁盘之间的信息 交换。

虚拟存储器机制由硬件与操作系统共同协作实现,涉及到操作系统中的许多概念,如进程、进程的上下文切换、存储器分配、虚拟地址空间、缺页处理等。

## ■虚拟存储器小知识

- 1. 虚拟存储器源出于英国ATLAS计算机的一级存储器概念。这种系统的主存为16千字的磁芯存储器,但中央处理器可用20位逻辑地址对主存寻址。
- 2. 1970年,美国RCA公司研究成功虚拟存储器系统。
- 3. IBM公司于1972年在IBM370系统上全面采用了虚拟存储技术。
- 4. 目前虚拟存储器已成为计算机系统中非常重要的部分。

- >主存分成固定长度且比较小的存储块,称为实页(物理的页);
- ▶进程也划分成相同长度的程序块,称为虚页(虚拟的页);
- ▶主存按页顺序编号,每个独立编址的程序(进程)空间有自己的页号顺序,通过调度辅存中程序各页可离散装入主存不同实页位置。
- ▶ CPU执行指令时,首先需将逻辑地址转换为主存的物理地址,地址转换由CPU中的MMU实现。
- ▶页式调度:按页交换
  - 优点:页内零头小,页表对程序员来说是透明的,地址变换快, 调入操作简单;
  - 缺点: 各页不是程序的独立模块,不便于实现程序和数据保护。

- ➤ 虚存(逻辑地址空间)和主存(物理地址空间)按固定大小分成若干页,虚存页称为虚页,主存页称为实页。辅存中程序按页调入内存;
- ▶页表:记录虚页与实页的映射关系 ,实现虚实地址的转换,页表建立 在内存中,操作系统为每道程序建 立一个页表。页表用虚页号作为索 引,页表项包括虚页对应的实页号 和有效位。
- ▶ 页表寄存器:保存页表在内存中的 首地址。
- ▶虚地址格式:

| >实地址格式: | 实 |
|---------|---|
|---------|---|





#### 页表 (Page Table)

| 虚页 | 实页号 | 有效位 | 修改位 |
|----|-----|-----|-----|
| 0  | 14  | 1   | 1   |
| 1  | 16  | 1   | 0   |
| 2  | 17  | 1   | 1   |
| 3  | 19  | 1   | 1   |
| 4  | XX  | 0   | 1   |
|    | XX  | 0   | 0   |
|    | XX  | 0   | 0   |

程序A的页表



## ❖页表

- ▶每个进程有一个页表,页表项数 取决于虚拟地址的结构。
- ▶页表项包括:实页号、装入位、 修改位等
- ▶页表在内存中的首地址记录在页 表基址寄存器中。

#### 

## ❖页表空间问题

- ▶页表可能很大。如VAX系统中,用户程序(进程)虚拟存储空间最大可达 2GB,按512B分页,有2<sup>22</sup>页,页表可以包括2<sup>22</sup>个页表项。显然,这么大的 页表需要占用很大的内存空间。
- ▶ 多进程运行,对个页表同时都在内存。多个同时运行的进程的页表空间超过 内存可分配空间的可能性是存在的。
- ▶采用多级页表机制:将页表分页,当前使用的页的页表项所在页在内存,其 余在外存,页表也采用按页交换机制。

❖ 虚拟地址到物理地址的转换



# ◆一种页表机制

- 》当虚页在内存中时( 装入位为1时),页 表提供虚页到实页的 映射(实页号);
- 》当虚页不在内存时( 装入位为**0**时),页 表提供保存该虚页的 磁盘地址,以便进行 磁盘读取;



有些系统采用双表结构,页表只提供虚页到实页的映射,由外页表实现虚页到磁盘地址的映射。

#### ❖ 举例

某计算机虚拟地址32位,物理内存128MB,页大小4KB。

- (1)程序虚拟空间最多可有多少页?
- (2) 页表项共有多少位?
- (3)每个页表占多少内存空间?

#### ❖ 解答

虚地址32位:虚页号(20位)+页内偏移(12位)

实地址27为: 实页号(15位)+页内偏移(12位)

每个程序虚拟空间最多可有: 220个虚页

每个页表项: 1位(有效位)+15位(实页号)=16位

每个页表所占空间: 2<sup>20</sup>×16=16Mb=2MB

多道程序运行时,所有程序的页表都在内存中,页表占用内存空间不可忽视,极端情况下,页表有可能消耗所有内存空间。(采用多级页表解决)

- ❖ 加快地址转换,采用快表TLB(Translation Lookaside Buffer,转换后备缓冲器)
  - ▶ 问题:每次虚拟存储器的访问带来两次存储器访问,一次访问页表,一次访问所需数据(或指令),简单的虚拟存储器速度慢。
  - ➤ 解决办法:使用Cache存储部分活跃的页表项,称为TLB(快表),它包含了最近使用的那些页表项。
  - ➤ TLB内容(全相联模式):标记(虚页号)、数据块(实页号)、有效位、修改位。

标记 (tan)

➤ TLB一般采用全相联

有效位 修改位

| 11 从世 | Mill (tag) | <b>双</b> 烟 |
|-------|------------|------------|
|       | 虚页号        | 实页号        |

粉坪

快表 (TLB)





- ❖ CPU通过TLB和Cache访 问的全过程
  - > TLB和Cache都采用组相联
  - ▶ 以虚拟页号为依据访问TLB 获取物理页号
  - > 以物理地址为依据访问 Cache获取最终数据





❖ TLB,页表,Cache三种缺失的可能性

| TLB  | Page<br>table | Cache | Possible? If so, under what circumstance? |
|------|---------------|-------|-------------------------------------------|
| hit  | hit           | miss  | 可能,TLB命中则页表一定命中,但实际上不会查页表                 |
| miss | hit           | hit   | 可能,TLB缺失但页表可能命中,信息在主存,就可能在Cache           |
| miss | hit           | miss  | 可能,TLB缺失但页表可能命中,信息在主存,但可能不在Cache          |
| miss | miss          | miss  | 可能,TLB缺失页表可能缺失,信息不在主存,一定也不在Cache          |
| hit  | miss          | miss  | 不可能,页表缺失,说明信息不在主存,TLB中一定没有该页表项            |
| hit  | miss          | hit   | 同上                                        |
| miss | miss          | hit   | 不可能,页表缺失,说明信息不在主存,Cache中一定也没有该信息          |

最好的情况应该是hit、hit、hit,此时,访问主存几次?不需要访问主存!以上组合中,最好的情况是什么?hit、hit、miss和miss、hit、hit 只需访问主存1次以上组合中,最坏的情况是什么?miss、miss、miss 需访问磁盘、并访存至少2次介于最坏和最好之间的是什么?miss、hit、miss 不需访问磁盘、但访存至少2次

#### 举例

假定页式虚拟存储系统按字节编址,逻辑地址36位,页大小16KB,物理地址32位,页表中包括有效位和修改位各1位、使用位和存期方式位各2位,且所有虚拟页都在使用中。请问:

- (1)每个进程的页表大小为多少?
- (2) 如果所使用的快表(TLB)总表项数为256项,且采用2路组相联 Cache实现,则快表大小至少为多少?

#### **❖**解答(1)

页面大小: 16KB=2<sup>14</sup>, 页内偏移14位

虚地址36位: 虚页号=36-14=22位

实地址32为: 实页号=32-14=18位

每个进程最多可有: 222个虚页

每个页表项: 1 +1+2 +2+ 18=24位

每个页表所占空间: 2<sup>22</sup>×24=12MB

#### **(2)**

- ➤ TLB: 256个表项, 2路组相联, 所以共有128组
- ➤ 22位虚页号: 7位组地址,15位 Tag
- ➤ TLB每个表项: 15+24=39位
- ➤ TLB容量: 39×256=9984位 =1248字节

#### MIPS的存储空间管理

- ❖ MIPS CPU运行模式:用户态和核心态
  - Kuseg: 0000000 7FFF FFFF (2G),用户模式下可用,即MIPS规范约定用户空间为2G在带有MMU的机器里,这些地址都将由MMU转换。
  - KSeg0:80000000-9FFFFFF(512M),通过将最高位清零映射到物理地址低端512M(00000000-1FFFFFF)空间。这种映射简单,无需MMU转换(Unmapped)。这段地址的存取都会通过高速缓存(cached),对于有MMU的系统,操作系统内核会存放在该区域。
  - ➤ KSeg1: A0000000 BFFFFFFF(512M),将最高3位清零映射到物理地址低端512M(00000000 1FFFFFFF)空间,无需MMU转换(Unmapped),kseg1不使用缓存(Uncached)。kseg1是系统重启时能正常工作的内存映射地址空间,重新启动时的入口向量是BFC00000,这个向量对应的物理地址是1FC00000。因此你可以使用这段地址空间来访问你的初始化程序的ROM。
  - KSeg2: C0000000 FFFFFFFF (1G), 只能在核心态下使用,并且要经过MMU转换,一般情况下你不需要使用这段地址空间。



#### MIPS的存储空间管理

# ❖MIPS按如下约定为程序分配 空间

- 堆栈在高地址区,从高到低增长。
- 过程调用时,生成当前"栈帧",返回 后退回当前栈帧
- ➤ 程序的动态数据(如:C中的malloc 申请区域、链表)在堆(heap)中从 低向高进行存放和释放(free时)栈 区位于堆栈高端,堆区位于堆栈低 端,静态数据区上方。
- 全局指针\$gp固定设为0x10008000, 其16位偏移量的访问范围为 0x10000000 到0x1000FFFF
- ➤ 静态数据区从固定的0x10000000处 开始存放
- 程序代码从固定的0x00400000处开 始存放,故PC的初始值为 0x00400000。



MIPS每个进程的虚拟(逻辑)地址空间