

北京邮电大学

# 实验报告

课程名称 计算机组成原理

实验名称 数据通路实验

计算机系301班

姓名       

教师       

成绩       

2024年4月11日



## 一、实验类型

本实验的类型为 原理型 + 分析型。

## 二、实验目的

1. 进一步熟悉 TEC-8 模型计算机的数据通路的结构；
2. 进一步掌握数据通路中各个控制信号的作用和用法；
3. 掌握数据通路中数据流动的路径。

## 三、实验设备

TEC-8 实验系统 一台

## 四、实验原理

数据通路实验电路图如图 1 所示。它由运算器部分、双端口存储器部分加上数据开关 SD7~SD0 连接在一起构成。下面主要说明 TEC-8 模型计算机的数据流动路径和方式。

在进行数据运算操作时，由 RD0, RD1 选中的寄存器通过 4 选 1 选择器送至 ALU 的 A 端口，由 RS1, RS0 选中的寄存器通过 4 选 1 选择器 B 送至 ALU 的 B 端口；信号 M, S<sub>3</sub>, S<sub>2</sub>, S<sub>1</sub>, S<sub>0</sub> 决定 ALU 的运算类型，ALU 对 A 端口和 B 端口的两个数连同 CIN 的值进行算术逻辑运算，得到的数据运算结果在信号 ABUS 为 1 时送至数据总线 DBUS；在 T<sub>3</sub> 的上升沿，数据总线 DBUS 上的数据结果写入由 RD1, RD0 选中的寄存器。

在寄存器之间进行数据传送操作时，由 RS1, RS0 选中的 4 选 1 选择器 B 送至 ALU 的端口 B；ALU 将端口 B 的数在信号 ABUS 为 1 时送至数据总线 DBUS；在 T<sub>3</sub> 上升沿将数据总线上数写入由 RD1, RD0 选中的寄存器。ALU 进行数据传送操作由一组特定的 M, S<sub>3</sub>, S<sub>2</sub>, S<sub>1</sub>, S<sub>0</sub> 和 CIN 的值确定。

在从存储器中取数操作中，由地址 AR7~AR0 指定的存储器单元中的数在信号 MEMW 为 0 时被读出；在 MBUS 为 1 时送数据总线 DBUS；在 T<sub>3</sub> 的上升沿写入由 RD1, RD0 选中的寄存器。

在写存储器操作中，由 RS1, RS0 选中的寄存器通过 4 选 1 选择器

B送ALU的端口B；ALU将端口B的数据在信号ABUS为1时送往数据总线DBUS；在MEMW为1且MBUS为0时，通过左端口将数据总线DBUS上的数据在T<sub>2</sub>为1期间写入由AR7~AR0指定的存储器单元。

在读指令操作时，通过存储器左端口读出由PC7~PC0指定的存储单元的内容送往INS7~INS0，当信号LR为1时，在T<sub>3</sub>上升沿写入指令寄存器IR。

数据开关SD7~SD0上的数在SBUS为1时送到数据总线DBUS上，用于给寄存器R<sub>0</sub>, R<sub>1</sub>, R<sub>2</sub>和R<sub>3</sub>，地址寄存器AR，程序计数器PC设置初值，用于通过存储器左端口向存储器写入测试程序。

## 五、实验步骤

本次实验在独立模式下进行。

~~三、接线~~

打开实验箱，确定设备断电后，将控制信号切换器的开关拨到中间位置（“独立”），将编程开关拨到“正常”位置，将DP置为高。按照表1.接线参照表接线。

将K<sub>13</sub>, K<sub>14</sub>, K<sub>5</sub>置为低电平，确保DBUS上无数据输入，将K<sub>4</sub>, K<sub>12</sub>置为低电平，关闭对寄存器组和RAM的写入，将K<sub>10</sub>置为低电位，关闭对AR和PC的载入。

合上电源，按下CLR按钮将TEC-8实验系统复位为初始状态。实验开始。

1. 将数据写入到寄存器，验证“SD → R”通路。

表1. 接线参照表

| 电平/开关           | 输入信号                               | 接线信号颜色 |
|-----------------|------------------------------------|--------|
| K <sub>0</sub>  | RD <sub>0</sub>                    | 黄      |
| K <sub>1</sub>  | RD <sub>1</sub>                    |        |
| K <sub>2</sub>  | RS <sub>0</sub>                    | 绿      |
| K <sub>3</sub>  | RS <sub>1</sub>                    |        |
| K <sub>4</sub>  | DR <sub>W</sub>                    | 蓝      |
| K <sub>5</sub>  | S <sub>0</sub>                     |        |
| K <sub>6</sub>  | S <sub>1</sub>                     | 绿      |
| K <sub>7</sub>  | S <sub>2</sub>                     |        |
| K <sub>8</sub>  | S <sub>3</sub>                     |        |
| K <sub>9</sub>  | M                                  | 黄      |
| K <sub>10</sub> | L <sub>AR/L<sub>PC</sub></sub>     | 绿      |
| K <sub>11</sub> | AR <sub>INC/PC<sub>INC</sub></sub> | 蓝      |
| K <sub>12</sub> | MEM <sub>W</sub>                   | 黄      |
| K <sub>13</sub> | A <sub>BUS</sub>                   | 绿      |
| K <sub>14</sub> | S <sub>BUS</sub>                   | 蓝      |
| K <sub>15</sub> | M <sub>BUS</sub>                   | 黄      |
| V <sub>CC</sub> | LD <sub>C/LD<sub>Z</sub></sub>     | 红      |

- ① 将  $K_4$ (DRW) 置为高电平，启动通用寄存器的写入功能；将  $S_{bus}$   $K_{14}$ (S<sub>bus</sub>) 置为高电平，将数据开关的值送到数据总线上。
- ② 将 SD<sub>7</sub>~SD<sub>0</sub> 置为 0111 0101，将  $K_1, K_0$ (RD<sub>1</sub>, RD<sub>0</sub>) 置为 0,0，按下 QD，将 75H 写入寄存器 R<sub>0</sub>，观察 ALU 的 A 端口示数。
- ③ 将 SD<sub>7</sub>~SD<sub>0</sub> 置为 0010 1000，将  $K_1, K_0$ (RD<sub>1</sub>, RD<sub>0</sub>) 置为 0,1，按下 QD，将 28H 写入寄存器 R<sub>1</sub>，观察 ALU 的 A 端口示数。
- ④ 将 SD<sub>7</sub>~SD<sub>0</sub> 置为 1000 1001，将  $K_1, K_0$ (RD<sub>1</sub>, RD<sub>0</sub>) 置为 1,0，按下 QD，将 89H 写入寄存器 R<sub>2</sub>，观察 ALU 的 A 端口示数。
- ⑤ 将 SD<sub>7</sub>~SD<sub>0</sub> 置为 0011 0010，将  $K_1, K_0$ (RD<sub>1</sub>, RD<sub>0</sub>) 置为 1,1，按下 QD，将 32H 写入寄存器 R<sub>3</sub>，观察 ALU 的 A 端口示数。

2. 将寄存器 R<sub>0</sub>~R<sub>3</sub> 中的数通过 ALU 写入存储器 20~23H 单元。

验证 “R → MEM” 通路。

- ① 将  $K_4$ (DRW) 置为低电平，~~将  $K_{14}$ (S<sub>bus</sub>) 置为低电平~~。
- ② 将  $K_0$ (LAR/LPC) 置为高电平，在数据开关 SD<sub>7</sub>~SD<sub>0</sub> 处拨出 0010 0000，按下 DP，将 20H 写入 AR 和 PC。
- ③ 将  $K_0$ (LAR/LPC) 置为低电平，将  $K_1$ (AR<sub>INC</sub>/PC<sub>INC</sub>) 置为高电平。  
将 S<sub>3</sub>~S<sub>0</sub> 置为 1111，将 K<sub>9</sub>(M) 置为高电平，使 ALU 计算结果为 A 端口的值，~~将  $K_{14}$ (S<sub>bus</sub>) 置为低电平~~，将  $K_{13}$ (Abus) 置为高电平，使得 ALU 计算结果输出到数据总线上，将  $K_{12}$ (MEMW) 置为高电平。
- ④ 将  $K_1, K_0$ (RD<sub>1</sub>, RD<sub>0</sub>) 置为 0,1，按下 QD，将 R<sub>0</sub> 中的值 75H 写入在存储器中地址为 20H 的存储单元。
- ⑤ 将  $K_1, K_0$ (RD<sub>1</sub>, RD<sub>0</sub>) 置为 0,1，按下 QD，将 R<sub>1</sub> 中的值 28H 写入存储器中地址为 21H 的存储单元。
- ⑥ 将  $K_1, K_0$ (RD<sub>1</sub>, RD<sub>0</sub>) 置为 1,0，按下 QD，将 R<sub>2</sub> 中的值 89H 写入存储器中地址为 22H 的存储单元。
- ⑦ 将  $K_1, K_0$ (RD<sub>1</sub>, RD<sub>0</sub>) 置为 1,1，按下 QD，将 R<sub>3</sub> 中的值 32H 写入存储器中地址为 23H 的存储单元。
- ⑧ 将  $K_1$ (AR<sub>INC</sub>/PC<sub>INC</sub>)， $K_{13}$ (Abus)， $K_{12}$ (MEMW) 置为低电平。

3. 将存储器中地址为 20H~23H 的存储单元的数送到寄存器 R<sub>3</sub>~R<sub>0</sub>, 验证 "MEM → R" 通路。

- ① 将 K<sub>10</sub> (LAR1PC) 置为高电平, 将数据开关 SD<sub>7</sub>~SD<sub>0</sub> 拨为 0010 0000, 将 K<sub>14</sub> (SBUS) 置为高电平, 按下 QP, 将 20H 载入 AR 和 PC.
- ② 将 K<sub>14</sub> (SBUS) 置为低电平, 将 K<sub>15</sub> (MBUS) 置为高电平, 将储存的数据输出到数据总线上, 将 K<sub>11</sub> (AR<sub>ZNC</sub>/PC<sub>ZNC</sub>) 置为高电平, 使得地址在后续操作中自增. 将 K<sub>4</sub> (DRW) 置为高电平, 使得寄存器可被写入。
- ③ 将 RD<sub>1</sub>, RD<sub>0</sub>, K<sub>1</sub>, K<sub>0</sub> (RD<sub>1</sub>, RD<sub>0</sub>) 拨为 1, 1, 按下 QD, 将存储器中 20H 的值 75H 写入 R<sub>3</sub>.
- ④ 将 K<sub>1</sub>, K<sub>0</sub> (RD<sub>1</sub>, RD<sub>0</sub>) 拨为 1, 0, 按下 QD, 将存储器中 21H 的值 28H 写入 R<sub>2</sub>.
- ⑤ 将 K<sub>1</sub>, K<sub>0</sub> (RD<sub>1</sub>, RD<sub>0</sub>) 拨为 0, 1, 按下 QD, 将存储器中 22H 的值 89H 写入 R<sub>1</sub>.
- ⑥ 将 K<sub>1</sub>, K<sub>0</sub> (RD<sub>1</sub>, RD<sub>0</sub>) 拨为 0, 0, 按下 QD, 将存储器中 23H 的值 32 写入 R<sub>0</sub>.
- ⑦ 将 K<sub>4</sub> (DRW) 置为低电平, 将 K<sub>11</sub> (AR<sub>ZNC</sub>/PC<sub>ZNC</sub>) 置为低电平, 将 K<sub>15</sub> (MBUS) 置为低电平).

4. 关闭电源, 整理实验仪器, 实验结束。

## 六、实验数据分析

"MEM → R" 通路验证数据见表 2. "MEM → R" 通路表。

表 2. "MEM → R" 通路表

| R              | RD | 按下 QD 前 |                      |     | 按下 QD 后 |                      |     |
|----------------|----|---------|----------------------|-----|---------|----------------------|-----|
|                |    | AR/PC   | D <sub>BUS/INS</sub> | A   | AR/PC   | D <sub>BUS/INS</sub> | A   |
| R <sub>3</sub> | 11 | 20H     | 75H                  | 32H | 21H     | 28H                  | 75H |
| R <sub>2</sub> | 10 | 21H     | 28H                  | 89H | 22H     | 89H                  | 28H |
| R <sub>1</sub> | 01 | 22H     | 89H                  | 28H | 23H     | 32H                  | 89H |
| R <sub>0</sub> | 00 | 23H     | 32H                  | 75H | 24H     |                      | 32H |

## 七、实验思考题

1. 结合实验过程，分析各信号在 TEC-8 模型计算机中的作用。

答：见「四、实验原理」部分，操纵过程试验收时已演示。

2. 写出下列操作时，数据的流动路径和流动方向。

① 给寄存器置初值。

答： $SD \xrightarrow{SBUS=1} DBUS \xrightarrow{DRW=1} R$

② 设置存储器地址

答： $SD \xrightarrow{SBUS=1} DBUS \xrightarrow{AR/PC=1} AR/PC$

③ 将寄存器中的数写到存储器中

答： $R \rightarrow ALU \xrightarrow{ABUS=1} DBUS \xrightarrow{MEMW=1} MEM$

④ 从存储器读数到寄存器

答： $MEM \xrightarrow[MEMR=0]{MBUS=1} DBUS \xrightarrow{DRW=1} R$

3. 若用 I-cache 和 D-cache 来代替双端口存储器，请提出一种数据通路方案。

答：指令读取：读取 I-cache

数据读取/写入：通过 D-cache 读取或写入数据。

I-cache 类似本次实验的右端口，D-cache 类似为左端口。

## 八、实验总结

在本次实验中，我进一步熟悉了 TEC-8 模型计算机的数据通路的结构，进一步掌握了数据通路中各个控制信号的作用和用法，掌握了数据通路中数据流动的路径。可以说，我较好地达成了本次实验的目。

