

本章首先以半导体存储器为对象,在讨论存储器及其基本电路、基本知识的基础上,讨 论存储芯片及其与 CPU 之间的连接和扩充问题。然后,介绍内存条的技术发展以及外部 存储器。最后,简要介绍存储器系统的分层结构。

# 5.1 存储器的分类与组成

计算机的存储器可分为两大类:一类为内部存储器,简称内存或主存,其基本存储元件 多以半导体材料制造;另一类为外部存储器,简称外存,多以磁性材料或光学材料制造。

# 5.1.1 半导体存储器的分类

半导体存储器的分类如图 5.1 所示。按使用的功能可分为两大类:随机存取存储器 (Random Access Memory, RAM)和只读存储器(Read Only Memory, ROM)。RAM 在程 序执行过程中,每个存储单元的内容根据程序的要求既可随时读出,又可随时写入,故可称 读/写存储器。它主要用来存放用户程序、原始数据、中间结果,也用来与外存交换信息和用 作堆栈等。RAM 所存储的信息在断开电源时会立即消失,是一种易失性存储器。



图 5.1 半导体存储器的分类

ROM 在程序执行过程中,对每个存储单元的原存信息,只能读出,不能写入。ROM 在断开电源时,所存储的信息不会丢失。因此,ROM 常用来存储固定的程序,例如,微机的监控程序、汇编程序、系统软件以及各种常数、表格等。

RAM 按工艺又可分为双极型 RAM 和 MOS RAM 两类,而 MOS RAM 又可分为静态 (Static)和动态(Dynamic)RAM 两种。双极型 RAM 的特点是存取速度快,但集成度低,功耗大,主要用于速度要求高的位片式微机中;静态 RAM 的集成度高于双极型 RAM,而功耗低于双极型 RAM;动态 RAM 比静态 RAM 具有更高的集成度,但它是靠电路中的栅极电容来储存信息的,由于电容器上的电荷会泄漏,因此,它需要定时进行刷新。

只读存储器(ROM)按工艺也可分为双极型和 MOS 型,但一般根据信息写入的方式不同,而分为掩模式 ROM,可编程 ROM(PROM)和可擦除、可再编程 ROM(紫外线擦除 EPROM 与电子擦除 EEPROM)等几种。

### 5.1.2 半导体存储器的组成

半导体存储器的组成框图如图 5.2 所示,它一般由存储体、地址选择电路、读/写电路和控制电路组成。



图 5.2 半导体存储器的组成框图

#### 1. 存储体

存储体是存储 1 或 0 信息的电路实体,它由许多个存储单元组成,每个存储单元赋予一个编号,称为地址单元号。而每个存储单元由若干相同的位组成,每个位需要一个存储元件。对存储容量为 1KB(1024 个单元)×8 位的存储体,其总的存储位数为:

$$1024 \times 8$$
 位 = 8192 位

存储器的地址用一组二进制数表示,其地址线的位数 n 与存储单元的数量 N 之间的关系为:

地址线数与存储单元数的关系如表 5.1 所示。

| 地址线数 n     | 3  | 4   | ••• | 8    | 9    | 10   | 11   | 12   | 13   | 14     | 15     | 16     |
|------------|----|-----|-----|------|------|------|------|------|------|--------|--------|--------|
| 存储单元数 N=2" | 8  | 16  |     | 256  | 512  | 1024 | 2048 | 4096 | 8192 | 16 384 | 32 768 | 65 536 |
| 存储容量       | 8B | 16B | ••• | 256B | 512B | 1KB  | 2KB  | 4KB  | 8KB  | 16KB   | 32KB   | 64KB   |

表 5.1 地址线数与存储单元数的关系

#### 2. 地址选择电路

地址选择电路包括地址码缓冲器、地址译码器等。

地址译码器用来对地址码译码。设其输入端的地址线根数为n,输出线数为N,则它分 别对应 2"个不同的地址码,作为对地址单元的选择线。这些输出的选择线又称字线。

地址译码方式有以下两种。

#### 1) 单译码方式(或称字结构)

单译码方式的全部地址码只用一个地址译码器电路译码,译码输出的字选择线直接选 中与地址码对应的存储单元,如图 5.2 所示。图中,有 A2、A1、A0 这 3 根输入地址线,经过 地址译码器输出8种不同编号的字线,即000、001、010、011、100、101、110、111。这8条字 线分别对应着8个不同的地址单元。该方式需要的选择线数较多,只适用于小容量的存 储器。

#### 2) 双译码方式(或称重合译码)

双译码方式如图 5.3 所示,它将地址码分为 X 与 Y 两部分,用两个译码电路分别译码。 X 向译码又称行译码,其输出线称行选择线,它选中存储矩阵中一行的所有存储单元。Y向译码又称列译码,其输出线称列选择线,它选中一列的所有存储单元。只有当X向和Y向的选择线同时选中那一位存储单元,才能进行读或写操作。由图可见,具有 1024 个基本 单元电路的存储体排列成  $32 \times 32$  的矩阵,它的 X 向和 Y 向译码器各有 32 根译码输出线, 共 64 根。若采用单译码方式,则有 1024 根译码输出线。因此,双译码方式所需要的选择线 数目较少,也简化了存储器的结构,故它适用于大容量的存储器。



图 5.3 双译码存储器结构

#### 3. 读/写电路与控制电路

读/写电路包括读/写放大器、数据缓冲器(三态双向缓冲器)等。它是数据信息输入和输出的通道。

外界对存储器的控制信号有读信号(RD)、写信号(WR)和片选信号(CS)等,通过控制电路以控制存储器的读或写操作以及片选。只有片选信号处于有效状态,存储器才能与外界交换信息。

# 5.2 随机存取存储器

### 5.2.1 静态随机存取存储器

#### 1. 静态 RAM 的基本存储电路

静态 RAM 的基本存储电路是由 6 个 MOS 管组成的 RS 触发器,如图 5.4 所示。



图 5.4 6 管静态存储电路

在图 5.4 中, $T_3$ 、 $T_4$  为负载管, $T_1$ 、 $T_2$  交叉耦合组成了一个 RS 触发器,具有两个稳定状态。在 A 点(相当于 Q 端)与 B 点(相当于 Q 端)可以分别寄存信息 1 和 0。  $T_5$ 、 $T_6$  为行向选通门,受行选线上的电平控制。  $T_7$ 、 $T_8$  为列向选通门,受列选线上的电平控制。 由此,组成了双译码方式。当行选线与列选线上的信号都为高电平时,则分别将  $T_5$ 、 $T_6$  与  $T_7$ 、 $T_8$  导通,使 A、B 两点的信息经 D 与  $\overline{D}$  两点分别送至输入/输出电路的 I/O 线及 $\overline{I/O}$ 线上,从而存储器某单元位线上的信息同存储器外部的数据线相通。这时,就可以对该单元位线上的信息进行读/写操作。

写入时,被写入的信息从 I/O 和 $\overline{I/O}$ 线输入。如写 1 时,使 I/O 线为高电平, $\overline{I/O}$ 线为低电平,经  $T_7$ 、 $T_5$  与  $T_8$ 、 $T_6$  分别加至 A 端和 B 端,使  $T_1$  截止而  $T_2$  导通,于是 A 端为高电平,触发器为存 1 的稳态;反之亦然。

读出时,只要电路被选中, $T_5$ 、 $T_6$ 与 $T_7$ 、 $T_8$ 导通,A端与B端的电位就送到I/O及 $\overline{I/O}$ 线上。若原存的信息为1,则I/O线上为1, $\overline{I/O}$ 线上为0;反之亦然。读出信息时,触发器状态不受影响,故为非破坏性读出。

#### 2. 静态 RAM 的组成

静态 RAM 的结构组成原理图如图 5.5 所示。存储体是一个由  $64 \times 64 = 4096$  个 6 管静态存储电路组成的存储矩阵。在存储矩阵中,X 地址译码器输出端提供  $X_0 \sim X_{63}$  计 64 根行选择线,而每一行选择线接在同一行中的 64 个存储电路的行选端,故行选择线能同时为该行 64 个行选端提供行选择信号。Y 地址译码器输出端提供  $Y_0 \sim Y_{63}$  计 64 根列选择线,而同一列中的 64 个存储电路共用同一位线,故由列选择线同时控制它们与输入/输出电路(I/O 电路)连通。显然,只有行、列均被选中的某个单元存储电路(这里为1位),在其 X 向选通门与 Y 向选通门同时被打开时,才能进行读出信息和写入信息的操作。



图 5.5 静态 RAM 的结构组成原理图

图 5.5 中所示的存储体是容量为 4K×1 位的存储器,因此,它仅有一个 I/O 电路,用于存取各存储单元中的 1 位信息。如果要组成字长为 4 位或 8 位的存储器,则每次存取时,同时应有 4 个或 8 个单元存储电路与外界交换信息。因此,在这种存储器中,要将列的列向选通门控制端引出线按 4 位或 8 位来分组,使每根列选择线能控制一组的列向选通门同时打开;相应地,I/O 电路也应有 4 个或 8 个。每一组的同一位共用一个 I/O 电路。这样,当存储体的某个存储单元在一次存取操作中被地址译码器输出端的有效输出电平选中时,则该单元内的 4 位或 8 位信息将被一次读/写完毕。

必须指出,在图 5.5 中的存储体如果是  $4K\times1$  位的存储矩阵,则在读/写操作时每次只能存取 1 位信息。如果是 8 个  $4K\times1$  位的存储矩阵,则在读/写操作时每次只能存取 8 位信息,这时的存储容量为  $4K\times8$  位。

通常,一个 RAM 芯片的存储容量是有限的,需要用若干片才能构成一个实用的存储器。这样,地址不同的存储单元,可能处于不同的芯片中,因此,在选中地址时,应先选择其所属的芯片。对于每块芯片,都有一个片选控制端(CS),只有当片选端加上有效信号时,才能对该芯片进行读或写操作。一般来说,片选信号由地址码的高位译码产生。

#### 3. 静态 RAM 的读/写过程

静态 RAM 的读/写过程如图 5.5 所示。

#### 1) 读出过程

- (1) 地址码  $A_0 \sim A_{11}$ 加到 RAM 芯片的地址输入端,经 X 与 Y 地址译码器译码,产生行选与列选信号,选中某一存储单元,经一定时间,该单元中存储的代码出现在 I/O 电路的输入端。I/O 电路对读出的信号进行放大、整形,送至输出缓冲寄存器。缓冲寄存器一般具有三态控制功能,没有开门信号,所存数据也不能送到 DB 上。
- (2) 在传送地址码的同时,还要传送读/写控制信号( $R/\overline{W}$  或 RD、WR)和片选信号( $\overline{CS}$ )。读出时,使  $R/\overline{W}=1$ , $\overline{CS}=0$ ,这时,输出缓冲寄存器的三态门将被打开,所存信息送至 DB 上。于是,存储单元中的信息被读出。
  - 2) 写入过程
  - (1) 地址码加在 RAM 芯片的地址输入端,选中相应的存储单元,使其可以进行写操作。
  - (2) 将要写入的数据放在 DB 上。
- (3) 加上片选信号 $\overline{CS}=0$  及写入信号  $R/\overline{W}=0$ 。这两个有效控制信号打开三态门使 DB上的数据进入输入电路,送到存储单元的位线上,从而写入该存储单元。

### 4. 静态 RAM 芯片举例

常用的静态 RAM 芯片有 2114、2142、6116、6264、62256、628128、628512、6281024 等。

例如,常用的 Intel 6116 是 CMOS 静态 RAM 芯片,属双列直插式、24 引脚封装。它的存储容量为 2K×8 位,其引脚及内部结构框图如图 5.6 所示。



图 5.6 Intel 6116 芯片的引脚及内部结构框图

Intel 6116 芯片内部的存储体是一个由  $128 \times 128 = 16$  384 个静态存储电路组成的存储矩阵。 $A_0 \sim A_{10}$  这 11 根地址线用作行、列地址的译码,以便对  $2^{11} = 2048$  个存储单元进行选址。每当选中一个存储单元,将从该存储单元中同时读/写 8 位二进制信息,故 Intel 6116 有 8 根数据输入/输出线  $I/O_0 \sim I/O_7$ 。 Intel 6116 存储矩阵内部的基本存储电路上的信息,

正是通过 I/O 控制电路和数据输入/输出缓冲器与 CPU 的数据总线连通的。数据的读出或写入将由片选信号( $\overline{CE}$ )、写允许信号( $\overline{WE}$ )以及数据输出允许信号( $\overline{OE}$ )一起控制。当  $\overline{CE}$ 有效而 $\overline{WE}$ 为低电平时,1 门导通,使数据输入缓冲器打开,信息将由 I/O。 $\sim$ I/O,写入被选中的存储单元;当 $\overline{CE}$ 与  $\overline{OE}$ 同时有效而 $\overline{WE}$ 为高电平时,2 门导通,使数据输出缓冲器打开,CPU 将从被选中的存储单元由 I/O。 $\sim$ I/O,读出信息送往数据总线。无论是写入或读出,一次都是读/写 8 位二进制信息。

Intel 6264 芯片的结构及工作原理与 Intel 6116 相似,它是一个存储容量为 8KB×8 位的 CMOS SRAM 芯片,其有 28 条引脚,包括 13 根地址线( $A_{12} \sim A_0$ )、8 根双向数据线( $D_7 \sim D_0$ )以及 4 根控制线(片选信号线 $\overline{CS_1}$ 、 $\overline{CS_2}$ ,输出允许信号 $\overline{OE}$ 与写允许信号 $\overline{WE}$ ),另外,还有 3 根其他信号(+5V 电源端 $V_{CC}$ 、接地端 GND、空端 NC)。这些引脚的功能及其用法都是很容易理解的,限于篇幅这里不再赘述。

### 5.2.2 动态随机存取存储器

动态随机存取存储器简称动态 RAM 芯片,它是以 MOS 管栅极电容是否充有电荷来存储信息的,其基本存储电路一般由四管、三管和单管组成,以三管和单管较为常用。由于它所需要的管子较少,故可以扩大每片存储器芯片的容量,并且其功耗较低,所以在微机系统中,大多数采用动态 RAM 芯片。

#### 5.2.2.1 动态基本存储电路

下面重点介绍常用的三管和单管这两种基本存储电路。

#### 1. 三管动态基本存储电路

三管动态基本存储电路如图 5.7 所示,它由  $T_1$ 、 $T_2$ 、 $T_3$  这 3 个管子和两条字选择线(读、



图 5.7 三管动态基本存储电路

写选择线)以及两条数据线(读、写数据线)组成。 其中, $T_1$ 是写数控制管; $T_2$ 是存储管,用其栅极电容 $C_g$ 存储信息; $T_3$ 是读数控制管; $T_4$ 是一列基本存储电路上共同的预充电管,以控制对输出电容 $C_D$ 的预充电。

写入操作时,写选择线上为高电平, $T_1$  导通。 待写入的信息由写数据线通过  $T_1$  加到  $T_2$  管的栅极上,对栅极电容  $C_g$  充电。若写入 1,则  $C_g$  上充有电荷;若写入 0,则  $C_g$  上无电荷。写操作结束后, $T_1$  截止,信息被保存在电容  $C_g$  上。

读出操作时,先在  $T_4$  栅极加上预充电脉冲,使  $T_4$  导通,读数据线因有输出电容  $C_D$  而预充到 1

 $(V_{DD})$ 。然后使读选择线为高电平, $T_3$ 导通。若  $T_2$  栅极电容  $C_g$  上已存有1 信息,则  $T_2$  导通。这时,读数据线上的预充电荷将通过  $T_3$ 、 $T_2$  而泄放,于是读数据线上为 0。若  $T_2$  栅极电容上所存为 0 信息,则  $T_2$  不导通,而读数据线上为 1。因此,经过读操作,在读数据线上

可以读出与原存储相反的信息。若再经过读出放大器反相,即可得到原存储信息。

对于三管动态基本存储电路,即使电源不掉电, $C_g$  的电荷也会在几毫秒之内逐渐泄漏,而丢失原存 1 信息。为此,必须每隔  $1\sim3ms$  定时对  $C_g$  充电,以保持原存信息不变,此即动态存储器的刷新(或称再生)。

刷新要有刷新电路,如图 5.7 所示,若周期性地读出信息,但不往外输出(读信号RD)为高电平有效),经三态门(刷新信号RFSH)为低电平时使其导通)反相,再写人  $C_{o}$ ,就可实现刷新。

#### 2. 单管动态基本存储电路

单管动态基本存储电路如图 5.8 所示,它由 T<sub>1</sub> 管和寄生电容 C<sub>5</sub> 组成。

写入时,使字选线上为高电平, $T_1$ 导通,待写入的信息由位线 D(数据线)存入  $C_s$ 。

读出时,同样使字选线上为高电平, $T_1$ 导通,则存储在  $C_8$ 上的信息通过  $T_1$  送到 D 线上,再通过放大,即可得到存储信息。

为了节省面积,电容  $C_s$  不可能做得很大,一般使  $C_s$   $< C_D$ 。这样,读出 1 和 0 时电平差别不大,故需要鉴别能力高的读出放大器。此外, $C_s$  上的信息被读出后,其上寄存的电压由 0.2V 下降为 0.1V,这是一个破坏性读出。要



图 5.8 单管动态基本存储电路

保持原存信息,读出后必须重写。因此,使用单管电路,其外围电路比较复杂。但由于使用管子最少,故 4KB以上容量较大的 RAM,大多采用单管电路。

#### 5.2.2.2 动态 RAM 芯片举例

Intel 2116 单管动态 RAM 芯片的引脚和逻辑符号如图 5.9 所示。



图 5.9 Intel 2116 引脚和逻辑符号

Intel 2116 的引脚名称如表 5.2 所示。

表 5.2 Intel 2116 的引脚名称

| $A_6 \sim A_0$              | 地址输入  | $\overline{ m WE}$             | 写(或读)允许  |
|-----------------------------|-------|--------------------------------|----------|
| CAS                         | 列地址选通 | $V_{\scriptscriptstyle  m BB}$ | 电源(-5V)  |
| RAS                         | 行地址选通 | $V_{ m cc}$                    | 电源(+5V)  |
| $\mathrm{D_{IN}}$           | 数据输入  | $V_{\scriptscriptstyle  m DD}$ | 电源(+12V) |
| $\mathrm{D}_{\mathrm{OUT}}$ | 数据输出  | $V_{ m SS}$                    | 地        |

Intel 2116 芯片的存储容量为 16K×1 位,需用 14 条地址输入线,但 Intel 2116 只有 16 条引脚。由于受封装引线的限制,只用了  $A_0 \sim A_0$  这 7 条地址输入线,数据线只有 1 条  $(1 \oplus )$ ,而且数据输入 $(D_{\text{IN}})$ 和输出 $(D_{\text{OUT}})$ 端是分开的,它们有各自的锁存器。写允许信 号WE为低电平时表示允许写入,为高电平时表示可以读出,如表 5.2 所示,它需要 3 种 电源。

Intel 2116 的内部结构如图 5.10 所示。



图 5.10 Intel 2116 的内部结构

为了解决用 7 条地址输入线传送 14 位地址码的矛盾, Intel 2116 采用地址线分时复 用技术,用 A。~A。这 7 根地址线分两次将 14 位地址按行、列两部分分别引入芯片,即先 把 7 位行地址  $A_0 \sim A_6$  在行地址选通信号(RAS)有效时通过 Intel 2116 的  $A_0 \sim A_6$  地址 输入线送至行地址锁存器,而后把 7 位列地址 A7~A13在列地址选通信号(CAS)有效时 通过 Intel 2116 的 A。~A。 地址输入线送至列地址锁存器,从而实现了 14 位地址码的 传送。

7 位行地址码经行译码器译码后,某一行的 128 个基本存储电路都被选中,而列译码器 只选通 128 个基本存储电路中的一个(即 1 位),经列放大器放大后,在定时控制发生器及写 信号锁存器的控制下送至 I/O 电路。

Intel 2116 没有片选信号CS,它的行地址选通信号RAS兼作片选信号,且在整个读、写 周期中均处于有效状态,这是与其他芯片的不同之处。

此外,地址输入线 A。~A。还用作刷新地址的输入端,刷新地址由 CPU 内部的刷新寄 存器提供。

与 Intel 2116 芯片类似的还有 Intel 2164、3764、4164 等 DRAM 芯片。

综上所述,动态基本存储电路所需管子的数目比静态的要少,故提高了集成度,降低了 成本,存取速度也更快,但由于要刷新,需要增加刷新电路,因此,外围控制电路比较复杂。 静态 RAM 尽管集成度低,但静态基本存储电路工作较稳定,也不需要刷新,所以,外围控制 电路比较简单。

# 5.3 只读存储器

## 5.3.1 只读存储器存储信息的原理和组成

ROM 的存储元件如图 5.11 所示,它可以看作一个单向导通的开关电路。当字线上加有选中信号时,如果电子开关 S 是断开的,则位线 D 上将输出信息 1;如果 S 是接通的,则位线 D 经 T<sub>1</sub> 接地,将输出信息 0。

ROM 的组成结构与 RAM 相似,一般也是由地址译码电路、存储矩阵、读出电路及控制电路等组成。图 5.12 所示为有 16 个存储单元、字长为 1 位的 ROM 示意图。16 个存储单元,地址码应为 4 位,因采用复合译码方式,其行地址译码和列地址译码各占两位地址码。对某一固定地址单元而言,仅有一根行选线和一根列选线有效,其相交单元即为选中单元,再根据被选中单元的



图 5.11 ROM 的存储元件

开关状态,数据线上将读出 0 或 1 信息。例如,若地址  $A_3 \sim A_0$  为 0110,则行选线  $X_2$  及列 选线  $Y_1$  有效(输出低电平),图 5.12 中,有 \* 号的单元被选中,其开关 S 是接通的,故读出的信息为 0。当片选信号有效时,打开三态门,被选中单元所存信息即可送至外面的数据总线上。图 5.12 所示的仅是16 个存储单元的 1 位,8 个这样的阵列才能组成一个  $16 \times 8$  位的 ROM 存储器。



# 5.3.2 只读存储器的分类

#### 1. 不可编程掩模式 MOS 只读存储器

不可编程掩模式 MOS ROM 又称为固定存储器,其内部存储矩阵的结构如图 5.12 所示。它是由器件制造厂家根据用户事先编好的机器码程序,把 0、1 信息存储在掩模图形中