#### 计算机组成原理实验报告

- 一、 CPU 设计文档
- (一) 总体设计



|                | Α        | В         | С       | D       | E         | F        | G            | Н | 1         | J         | K        | L        | М         | N         | 0         | Р         | Q         | R        | S        | T         | U         | V         | W         | X         | γ         | <b>A</b> |
|----------------|----------|-----------|---------|---------|-----------|----------|--------------|---|-----------|-----------|----------|----------|-----------|-----------|-----------|-----------|-----------|----------|----------|-----------|-----------|-----------|-----------|-----------|-----------|----------|
| 1              |          |           | MUX     | 控制信号    | (         | 0 1      | . 2          |   | lw        | SW        | addu/add | subu/sub | ori       | lui       | beg       | i         | ial       | ir       | ialr     | lb        | lbu       | lh        | lhu       | sb        | sh        | sll      |
| 2              | PC       |           | M_nPC   | PCSel   | ADD4      | NPC      | MFPCF        |   | ADD4      | ADD4      | ADD4     | ADD4     | ADD4      | ADD4      | ADD4/NPC  | NPC       | NPC       | RF.V1    | RF.V1    | ADD4      | ADD4      | ADD4      | ADD4      | ADD4      | ADD4      | ADC      |
| 3              | ADD4     |           |         |         | PC        |          |              |   | PC        | PC        | PC       | PC       | PC        | PC        | PC        | PC        | PC        | PC       | PC       | PC        | PC        | PC        | PC        | PC        | PC        | PC       |
| 4              | IM       |           |         |         | PC        |          |              |   | PC        | PC        | PC       | PC       | PC        | PC        | PC        | PC        | PC        | PC       | PC       | PC        | PC        | PC        | PC        | PC        | PC        | PC       |
| 5              | D级寄存器    | IR_D      |         |         | IM        |          |              |   | IM        | IM        | IM       | IM       | IM        | IM        | IM        | IM        | IM        | IM       | IM       | IM        | IM        | IM        | IM        | IM        | IM        | IM       |
| 6              |          | PC8_D     |         |         | ADD4+4    |          |              |   |           |           |          |          | sh+J2:J3  |           |           |           | ADD4+4    |          | ADD4+4   |           |           |           |           |           |           |          |
| 6<br>7         |          | PC4_D     |         |         | ADD4      |          |              |   |           |           |          |          |           |           | ADD4      |           | ADD4      |          | ADD4     |           |           |           |           |           |           |          |
|                | RF       | A1        |         |         | IR_D[rs]  |          |              |   | IR_D[rs]  | IR_D[rs]  | IR_D[rs] | IR_D[rs] | IR_D[rs]  | IR_D[rs]  | IR_D[rs]  |           |           | IR_D[rs] | IR_D[rs] | IR_D[rs]  | IR_D[rs]  | IR_D[rs]  | IR_D[rs]  | IR_D[rs]  | IR_D[rs]  | IR_C     |
| 9              |          | A2        |         |         | IR_D[rt]  |          |              |   |           | IR_D[rt]  | IR_D[rt] | IR_D[rt] |           |           | IR_D[rt]  |           |           |          |          |           |           |           |           | IR_D[rt]  | IR_D[rt]  | IR_E     |
| 10             | EXT      |           |         |         | IR_D[I16] |          |              |   | IR_D[I16] | IR_D[I16] |          |          | IR_D[I16] | IR_D[I16] |           |           |           |          |          | IR_D[I16] | IR_D[I16] | IR_D[I16] | IR_D[I16] | IR_D[I16] | IR_D[I16] |          |
| 11             | CMP      | D1        |         |         | MFcmp1D   |          |              |   |           |           |          |          |           |           | RF.V1     |           |           |          |          |           |           |           |           |           |           |          |
| 12             |          | D2        |         |         | MFcmp2D   |          |              |   |           |           |          |          |           |           | RF.V2     |           |           |          |          |           |           |           |           |           |           |          |
| 13             | NPC      | 126       |         |         | IR_D[126] |          |              |   |           |           |          |          |           |           | IR_D[I16] | IR_D[126] | IR_D[126] |          |          |           |           |           |           |           |           |          |
| 14             | E级寄存器    | IR_E      |         |         | IR_D      |          |              |   | IR_D      | IR_D      | IR_D     | IR_D     | IR_D      | IR_D      |           |           | IR_D      |          | IR_D     | IR_D      | IR_D      | IR_D      | IR_D      | IR_D      | IR_D      | IR_C     |
| 15             |          | PC8_E     |         |         | PC8_D     |          |              |   |           |           |          |          |           |           |           |           | PC8_D     |          | PC8_D    |           |           |           |           |           |           |          |
| 16             |          | PC4_E     |         |         | PC4_D     |          |              |   |           |           |          |          |           |           |           |           | PC4_D     |          | PC4_D    |           |           |           |           |           |           |          |
| 15<br>16<br>17 |          | V1 E      |         |         | D1        |          |              |   | RF.V1     | RF.V1     | RF.V1    | RF.V1    | RF.V1     |           |           |           |           |          |          | RF.V1     | RF.V1     | RF.V1     | RF.V1     | RF.V1     | RF.V1     | RF.\     |
| 18             |          | V2 E      |         |         | D2        |          |              |   |           | RF.V2     | RF.V2    | RF.V2    |           |           |           |           |           |          |          |           |           |           |           | RF.V2     | RF.V2     | RF.\     |
| 19             |          | E32_E     |         |         | EXT       |          |              |   | EXT       | EXT       |          |          | EXT       | EXT       |           |           |           |          |          | EXT       | EXT       | EXT       | EXT       | EXT       | EXT       |          |
|                | ALU      | Α         | M_ALUB  | ASel    | MFaluaE   | IR[10:6] | MFaluaE[4:0] |   | V1_E      | V1_E      | V1_E     | V1_E     | V1_E      |           |           |           |           |          |          | V1_E      | V1_E      | V1_E      | V1_E      | V1_E      | V1_E      | IR[1     |
| 21             |          | В         | M_ALUB  | BSel    | MFalubE   | E32_E    |              |   | E32_E     | E32_E     | V2_E     | V2_E     | E32_E     | E32_E     |           |           |           |          |          | E32_E     | E32_E     | E32_E     | E32_E     | E32_E     | E32_E     | V2_      |
| 22             | M级寄存器    | IR_M      |         |         | IR_E      |          |              |   | IR_E      | IR_E      | IR_E     | IR_E     | IR_E      | IR_E      |           |           | IR_E      |          | IR_E     | IR_E      | IR_E      | IR_E      | IR_E      | IR_E      | IR_E      | IR_E     |
| 23             |          | PC8_M     |         |         | PC8_E     |          |              |   |           |           |          |          |           |           |           |           | PC8_E     |          | PC8_E    |           |           |           |           |           |           |          |
| 24<br>25<br>26 |          | PC4_M     |         |         | PC4_E     |          |              |   |           |           |          |          |           |           |           |           | PC4_E     |          | PC4_E    |           |           |           |           |           |           |          |
| 25             |          | AO_M      |         |         | ALU       |          |              |   | ALU       | ALU       | ALU      | ALU      | ALU       | ALU       |           |           |           |          |          | ALU       | ALU       | ALU       | ALU       | ALU       | ALU       | ALU      |
| 26             |          | V2_M      |         |         | MFalubE   |          |              |   |           | V2_E      |          |          |           |           |           |           |           |          |          |           |           |           |           | V2_E      | V2_E      |          |
| 27             | DM       | Α         |         |         | AO_M      |          |              |   | AO_M      | AO_M      |          |          |           |           |           |           |           |          |          | AO_M      | AO_M      | AO_M      | AO_M      | AO_M      | AO_M      |          |
| 28             |          | WD        |         |         | MFdmdataN | <u> </u> |              |   |           | V2_M      |          |          |           |           |           |           |           |          |          |           |           |           |           | V2_M      | V2_M      |          |
| 29             | W级寄存器    | IR_W      |         |         | IR_M      |          |              |   | IR_M      |           | IR_M     | IR_M     | IR_M      | IR_M      |           |           | IR_M      |          | IR_M     | IR_M      | IR_M      | IR_M      | IR_M      |           |           | IR_N     |
| 30             |          | PC8_W     |         |         | PC8_M     |          |              |   |           |           |          |          |           |           |           |           | PC8_M     |          | PC8_M    |           |           |           |           |           |           |          |
| 31             |          | PC4_W     |         |         | PC4_M     |          |              |   |           |           |          |          |           |           |           |           | PC4_M     |          | PC4_M    |           |           |           |           |           |           |          |
| 32             |          | AO_W      |         |         | AO_M      |          |              |   |           |           | AO_M     | AO_M     | AO_M      | AO_M      |           |           |           |          |          |           |           |           |           |           |           | AO_      |
| 33             |          | DR_W      |         |         | DM        |          |              |   | DM        |           |          |          |           |           |           |           |           |          |          | DM        | DM        | DM        | DM        |           |           |          |
| 34             | DMEXT    |           |         |         |           |          |              |   |           |           |          |          |           |           |           |           |           |          |          |           |           |           |           |           |           |          |
| 35             | RF       | A3        | M_WReg  | WRSel   | IR_W[rt]  | IR_W[rd] | 0x1f         |   | IR_W[rt]  |           | IR_W[rd] | IR_W[rd] | IR_W[rt]  | IR_W[rt]  |           |           | 0x1f      |          | IR_W[rd] | IR_W[rt]  | IR_W[rt]  | IR_W[rt]  | IR_W[rt]  |           |           | IR_V     |
| 36             |          | WD        | M_Wdata | WDSel   | AO_W      | DR_W     | PC8_W        |   | DR_W      |           | AO_W     | AO_W     | AO_W      | AO_W      |           |           | PC8_W     |          | PC8_W    | DR_W      | DR_W      | DR_W      | DR_W      |           |           | AO 🔻     |
|                | <b>.</b> | 数据通路      | 转发暂停    | 亨   ctr | +         |          |              |   |           |           |          |          |           |           |           | 4         |           |          |          |           |           |           |           |           |           |          |
| 1              |          | XX./白/四/口 | 14次日    | T Cu    | +         |          |              |   |           |           |          |          |           |           | - :       | 4         |           |          |          |           |           |           |           |           |           | P        |

#### 图表 2数据通路设计

|      |      |     |    |      |      |      |      | E   | 11% 2 3 | 以加四  | A 以 N |           |          |             |         |      |       |       |
|------|------|-----|----|------|------|------|------|-----|---------|------|-------|-----------|----------|-------------|---------|------|-------|-------|
|      | Tuse |     |    |      |      | Tnew |      |     |         |      |       |           |          |             |         |      |       |       |
| 指令   | rs   | rt  |    | 指令   | 功能部件 | E    | М    | W   |         |      |       | 转发MUX     | 控制信号     | 输入0         | 输入1     | 输入2  | 输入3   | 输入4   |
| addu | 1    | 1   |    | addu | ALU  | 1    |      |     | )       |      |       | MFcmp1D   | Fcmp1D   | RF.V1       | M_Wdata | AO_M | PC8_M | PC8_E |
| subu | 1    | 1   |    | subu | ALU  | 1    | . (  |     | )       |      |       | MFcmp2D   | Fcmp2D   | RF.V2       | M_Wdata | AO_M | PC8_M | PC8_E |
| ori  | 1    |     |    | ori  | ALU  | 1    | . (  | ) ( | )       |      |       | MFaluaE   | FaluaE   | <u>V1_E</u> | M_Wdata | AO_M | PC8_M |       |
| lui  |      |     |    | lui  | ALU  | 1    | . (  | ) ( | )       |      |       | MFalubE   | FalubE   | V2_E        | M_Wdata | AO_M | PC8_M |       |
| lw   | 1    |     |    | lw   | DM   | 2    |      | 1 ( | )       |      |       | MFdmdataM | FdmdataN |             | M_Wdata |      |       |       |
| SW   | 1    | 2   |    | SW   |      |      |      |     |         |      |       | MFPCF     | FPCF     | RF.V1       | M_Wdata | AO_M | PC8_M | PC8_E |
| beq  | 0    | 0   |    | beq  |      |      |      |     |         |      |       |           |          |             |         |      |       |       |
| jr   | 0    |     |    | jr   |      |      |      |     |         |      |       |           |          |             |         |      |       |       |
| jalr | 0    |     |    | jalr | PC   | 0    | (    | ) ( | )       |      |       |           |          |             |         |      |       |       |
| j    |      |     |    | j    |      |      |      |     |         |      |       |           |          |             |         |      |       |       |
| jal  |      |     |    | jal  | PC   | 0    | (    | ) ( | )       |      |       |           |          |             |         |      |       |       |
|      |      |     |    |      |      |      |      |     |         |      |       |           |          |             |         |      |       |       |
|      |      |     |    |      |      |      |      |     |         |      |       |           |          |             |         |      |       |       |
|      |      |     |    |      |      |      |      |     |         |      |       |           |          |             |         |      |       |       |
|      |      |     |    |      |      |      |      |     |         |      |       |           |          |             |         |      |       |       |
| rs   |      |     |    |      |      | Tnew |      | _   |         |      |       |           |          |             |         |      |       |       |
|      |      |     | E  |      |      | М    |      |     | W       |      |       |           |          |             |         |      |       |       |
|      |      | ALU | DM | PC   | ALU  | DM   | PC   | ALU | DM      | PC   |       |           |          |             |         |      |       |       |
|      |      | 1   | 2  | _    | 0 0  | 1    |      | 0 ( | 0       | 0    |       |           |          |             |         |      |       |       |
| Tuse |      | S   | S  | F    | F    | S    | F    | F   | F       | F    |       |           |          |             |         |      |       |       |
|      | 1    | F   | S  | F    | F    | F    | F    | F   | F       | F    |       |           |          |             |         |      |       |       |
|      |      |     |    |      |      |      |      |     |         |      |       |           |          |             |         |      |       |       |
|      |      |     |    |      |      | _    |      |     |         |      |       |           |          |             |         |      |       |       |
| rt   |      |     | _  |      | _    | Tnew |      |     | 111     |      |       |           |          |             |         |      |       |       |
|      |      |     | E  | 100  |      | M    | lno. |     | W       | lno. |       |           |          |             |         |      |       |       |
|      |      | ALU | DM | PC   | ALU  | DM   | PC   | ALU | DM      | PC   |       |           |          |             |         |      |       |       |
| _    |      | 1   | 2  | F    | 0 0  | 1    | F (  | ) ( | 0       | F 0  |       |           |          |             |         |      |       |       |
| Tuse |      | S   | 5  | 1    | F    | S    |      | lt. | l E     | F    | -     |           |          |             |         |      |       |       |
|      |      | F   | S  | F    | F    | F    | F    | F   | F       | F    | -     |           |          |             |         |      |       |       |
|      | 2    | F   | F  | lF.  | IF.  | F    | lF.  | lF. | IF.     | II-  | 1     |           |          |             |         |      |       |       |

图表 3 转发暂停设计

图表 4 控制器设计

|    | Α        | В      | С      | D      | E                | F      | G      | Н      | L      | J      | K      | L      | M      | N      | 0                                                               |
|----|----------|--------|--------|--------|------------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|-----------------------------------------------------------------|
| 1  |          | 100001 | 100011 | 100000 | 100010           | 001000 | 001001 |        |        |        |        |        |        |        |                                                                 |
| 2  | ор       | 000000 | 000000 | 000000 | 000000           | 000000 | 000000 | 001101 | 100011 | 101011 | 000100 | 001111 | 001110 | 101001 |                                                                 |
| 3  |          | addu   | subu   | add    | sub              | jr     | jalr   | ori    |        | SW     | beq    | lui    | xori   | sh     |                                                                 |
| 4  | RegDst   | 1      | . 1    | . 1    |                  |        |        | . 0    | 0      | 0      |        |        |        |        | Ort 1rd 进rf2                                                    |
| 5  | Asel     | 00     | 00     | 00     | 00               | 00     | 00     | 00     | 00     | 00     | 00     | 00     | 00     | 00     | 0grfdata1 1IR[10:6] 2MFaluaE[4:0] 进aluA                         |
| 6  | Bsel     | 0      | ) 0    | ) 0    | ) C              | 0      | C      | 1      | 1      | 1      | . 0    | 1      | . 1    | 1 1    | 1 Ogrfdata2 1i32 进aluB                                          |
| 7  | MemtoReg | 0      | 0      | 0      | 0                | 0      | 0      | 0      | 1      | 0      | 0      | (      | ) (    | ) (    |                                                                 |
| 8  | RegWrite | 1      | 1 1    | . 1    | . 1              | . 0    | 1      | . 1    | 1      | 0      | 0      | 1      | 1      | 1 0    |                                                                 |
| 9  | MemWrite | 0      | 0      | 0      | 0                |        |        |        | 0      |        | 0      | (      | ) (    |        |                                                                 |
| 10 |          |        |        | 00     | 00               | 00     | 00     | 00     | 10     | 10     | 11     | 01     | 00     | 10     | 0无符号 1低16位补0 2有符号 3有符号后左移两位                                     |
| 11 |          |        |        | 0000   | 0001             | 0000   | 0000   | 0010   | 0000   | 0000   | 0000   | 0011   | 0100   | 0000   | 0000加 0001减 0010或 0011B 0100异或 0101逻辑左移 0110逻辑右移 0111算数右移 1000与 |
| 12 | dmextop  | 000    | 000    | 000    | 000              | 000    | 000    | 000    | 000    | 000    | 000    | 000    | 000    | 000    | 000不扩展 001无符号字节扩展 010有符号字节扩展 011无符号半字扩展 100有符号半字扩展              |
| 13 |          |        |        |        |                  |        |        |        |        |        |        |        |        |        |                                                                 |
| 14 |          |        |        |        |                  |        |        |        |        |        |        |        |        |        |                                                                 |
| 15 |          | 000000 | 000000 | 000000 | 000000           | 000000 | 000000 | 000011 | 000010 | 100000 | 100100 | 100001 | 100101 | 101000 |                                                                 |
| 16 | ор       | 000000 | 000010 | 000011 | 000100           | 000110 | 000111 | jal    | j      | lb     | lbu    | lh     | lhu    | sb     |                                                                 |
| 17 |          | sll    | srl    | sra    | sllv             | srlv   | srav   | 0      |        |        |        |        | ) (    |        |                                                                 |
| 18 | RegDst   | 1      | 1      | 1      | 1                | 1      | 1      | 00     | 00     | 00     | 00     | 00     | 00     | 00     |                                                                 |
| 19 | Asel     | 01     | 01     | 01     | 10               | 10     | 10     | 0      | 0      | 1      | . 1    | . 1    | . 1    | 1 1    | 1                                                               |
| 20 | Bsel     | 0      | 0      | 0      | 0                | 0      | 0      | 0      | 0      | 1      | . 1    | . 1    | . 1    | 1 0    |                                                                 |
| 21 | MemtoReg | 0      | 0      | 0      | 0                | 0      | 0      | 1      | 0      | 1      | 1      | . 1    | . 1    | 1 0    |                                                                 |
| 22 | RegWrite | 1      | 1      | 1      | 1                | 1      | 1      | 0      | 0      | 0      | 0      |        | ) (    |        | 1                                                               |
| 23 | MemWrite | 0      | 0      | 0      | 0                | 0      | O      | 00     | 00     | 10     | 10     | 10     | 10     | 10     |                                                                 |
| 24 |          |        | 00     | 00     | 00               | 00     | 00     | 0000   | 0000   | 0000   | 0000   | 0000   | 0000   | 0000   |                                                                 |
| 25 | ALUctr   | 0101   |        | 0111   | 0101             | 0110   | 0111   | 000    | 000    | 010    | 001    | 100    | 011    | 000    |                                                                 |
| 26 | dmextop  | 000    | 000    | 000    | 000              | 000    | 000    |        |        |        |        |        |        |        |                                                                 |
| 27 |          |        |        |        |                  |        |        |        |        |        |        |        |        |        |                                                                 |
| 28 |          |        |        |        |                  |        |        |        |        |        |        |        |        |        |                                                                 |
| 29 |          |        |        |        |                  |        |        |        |        |        |        |        |        |        |                                                                 |
| 30 |          |        |        |        |                  |        |        |        |        |        |        |        |        |        |                                                                 |
| 31 |          |        |        |        |                  |        |        |        |        |        |        |        |        |        |                                                                 |
| 22 | ▶  数     | 据通路    | 转发暂停   | ctr    | ( <del>+</del> ) |        |        |        |        |        |        |        |        |        |                                                                 |

## (二) 数据通路设计

1. datapath(数据通路)

表格 1datapath 端口说明

|    | <b>夜</b> 悄 Tuatapath <b>姉口切り</b>                    |
|----|-----------------------------------------------------|
| 方向 | 描述                                                  |
| I  | 时钟信号                                                |
| I  | 复位信号 1:复位 0:无效                                      |
| I  | D 控制器发来选择 nPC 信号 10:转发器 MFPCF 结果 01: NPC 00: ADD4   |
| I  | D 控制器发来 16 位立即数                                     |
| I  | D 控制器发来 26 位立即数                                     |
| I  | W 控制器发来写寄存器信号 1: 写寄存器 0: 无效                         |
| I  | M 控制器发来写内存信号 1: 写内存 0: 无效                           |
| I  | D 控制器发来扩展器信号 000: 无符号扩展 001: 低 16 位补 0 010: 有符号     |
|    | 扩展 011: 有符号扩展后逻辑左移两位                                |
| I  | E 控制器发来 ALU 控制信号 000: 加运算 001: 减运算 010: 或运算 011: 输出 |
|    | 写入数据 2 100: 异或运算                                    |
| I  | D 控制器发来选择寄存器 A3 端口信号 10:31 号寄存器 01: IR_W[rd] 00:    |
|    | IR_W[rt]                                            |
|    | <br>                                                |

| WDsel[1:0]  | I | W 控制器发来选择寄存器输入信号 00: A0_W01: DR_W10: PC8_W                  |
|-------------|---|-------------------------------------------------------------|
| Fcmp1D[2:0] | I | 冒险单元发来选择 MFcmp1D 信号 000: RF. V1 001: M_Wdata 010: A0_M 011: |
|             |   | PC8_M 100: PC8_E                                            |
| Fcmp2D[2:0] | I | 冒险单元发来选择 MFcmp2D 信号 000: RF. V2 001: M_Wdata 010: A0_M 011: |
|             |   | PC8_M 100: PC8_E                                            |
| FdmdataM    | I | 冒险单元发来选择 MFdmdataM 信号 0: V2_M 1: M_Wdata                    |
| FaluaE[1:0] | I | 冒险单元发来选择 MFaluaE 信号 00: V1_E 01: M_Wdata 10: A0_M 11: PC8_M |
| FalubE[1:0] | I | 冒险单元发来选择 MFalubE 信号 00: V2_E 01: M_Wdata 10: A0_M 11: PC8_M |
| FPCF[2:0]   | 1 | 冒险单元发来选择 MFPCF 信号 000: RF. V1 001: M_Wdata 010: A0_M 011:   |
|             |   | PC8_M 100: PC8_E                                            |
| Bsel        | 1 | E 控制器发来 ALUb 选择信号 0: MFalubE 选择结果 1: E32_E                  |
| stall       | 1 | 冒险单元发来选择暂停信号 1: 暂停 0: 无效                                    |
| beq         | 1 | D 控制器发来 beq 识别信号 1: beq 0: 无效                               |
| IRF[31:0]   | 0 | 输出到 D 控制器的 F 级指令                                            |
| IRD[31:0]   | 0 | 输出到 E 控制器的 D 级指令                                            |
| IRE[31:0]   | 0 | 输出到 M 控制器的 E 级指令                                            |
| IRM[31:0]   | 0 | 输出到 W 控制器的 M 级指令                                            |
| RESE[1:0]   | 0 | 输出到冒险单元的 E 级 Tnew 状态 00: NW 不写 01: 写 ALU 10: 写 DM 11: 写     |
|             |   | PC                                                          |
| RESM[1:0]   | 0 | 输出到冒险单元的 M 级 Tnew 状态 00: NW 不写 01: 写 ALU 10: 写 DM 11: 写     |
|             |   | PC                                                          |
| RESW[1:0]   | 0 | 输出到冒险单元的 W 级 Tnew 状态 00: NW 不写 01: 写 ALU 10: 写 DM 11: 写     |
|             |   | PC                                                          |
| RFA3E[4:0]  | 0 | 输出到冒险单元的 E 级指令 A3 寄存器                                       |
| RFA3M[4:0]  | 0 | 输出到冒险单元的 M 级指令 A3 寄存器                                       |
| RFA3W[4:0]  | 0 | 输出到冒险单元的 W 级指令 A3 寄存器                                       |

| 序号 | 功能名称   | 功能描述                                |
|----|--------|-------------------------------------|
| 1  | 连接基本模块 | 通过 datapath,以声明中间变量和实例化引用的方式连接各基础模块 |

#### 2. ifu(取指令单元)

#### 1) 端口说明

表格 3ifu 端口说明

| 信号名               | 方向 | 描述                                                 |
|-------------------|----|----------------------------------------------------|
| reset             | I  | 复位信号 1: 复位 0: 无效                                   |
| clk               | I  | 时钟信号                                               |
| PCsel[1:0]        | I  | D 控制器发来选择 nPC 信号 10: 转发器 MFPCF 结果 01: NPC 00: ADD4 |
| CO                | ı  | cmp 发来比较信号 1: alu 两输入相等 0: alu 两输入不等               |
| i16 [15:0]        | I  | D 控制器发来 16 位立即数                                    |
| i26[25:0]         | I  | D 控制器发来 26 位立即数                                    |
| PCtempD[31:0]     | I  | MFPCF 转发多选器的结果                                     |
| beq               | I  | D 控制器发来 beq 识别信号 1:beq 0:无效                        |
| stall             | ı  | 冒险单元发来选择暂停信号 1: 暂停 0: 无效                           |
| instruction[31:0] | 0  | 输出的指令                                              |
| PC8[31:0]         | 0  | 输出的当前 PC+8                                         |

表格 4 ifu 功能定义

| 序号 | 功能名称     | 功能描述                                          |
|----|----------|-----------------------------------------------|
| 1  | 复位       | 复位信号有效时,PC 被置为 0x00000000                     |
| 2  | 取指令      | 根据 PC 从 IM 中取出指令                              |
| 3  | 计算下条指令地址 | PC←PC+4    PC←reg1data    PC←PC + 4 + immed32 |
|    |          | PC←{PC[31:28], immed26, 2'b0}                 |
| 4  | 暂停       | Stall 信号有效时,冻结 PC 寄存器                         |

#### 3. rf(寄存器堆)

#### 1) 端口说明

表格 5grf 端口说明

|                 |    | 71H 09H 400 11    |
|-----------------|----|-------------------|
| 信号名             | 方向 | 描述                |
| reset           | ı  | 复位信号 1: 复位 0: 无效  |
| clk             | ı  | 时钟信号              |
| reg1 [4:0]      | ı  | 读寄存器号 1 编号        |
| Reg2 [4:0]      | ı  | 读寄存器号 2 编号        |
| writereg[4:0]   | ı  | 写寄存器编号            |
| regwrite        | ı  | 写控制信号 1: 写入 0: 无效 |
| writedata[31:0] | ı  | 写入的 32 位数据        |
| data1[31:0]     | 0  | 32 位寄存器 1 输出      |
| data2[31:0]     | 0  | 32 位寄存器 2 输出      |

## 2) 功能定义

表格 6grf 功能定义

| 序号 | 功能名称 | 功能描述                          |
|----|------|-------------------------------|
| 1  | 复位   | 复位信号有效时,32 个寄存器被置为 0x00000000 |
| 2  | 写寄存器 | 写寄存器控制信号有效时,把 32 位数据写入寄存器     |
| 3  | 读寄存器 | 根据输入的地址读出两个寄存器中的值             |

#### 4. alu(算术逻辑单元)

表格 7alu 端口说明

| 信号名        | 方向 | 描述                                                 |
|------------|----|----------------------------------------------------|
| A[31:0]    | I  | 32 位写入数据 1                                         |
| B[31:0]    | I  | 32 位写入数据 2                                         |
| ALU0p[2:0] | 1  | 控制信号 000: 加运算 001: 减运算 010: 或运算 011: 输出写入数据 2 100: |

|          |   | 异或运算     |
|----------|---|----------|
| A0[31:0] | 0 | 32 位输出数据 |

表格 8alu 功能定义

| 序号 | 功能名称     | 功能描述 |
|----|----------|------|
| 1  | 加运算      | A+B  |
| 2  | 减运算      | A-B  |
| 3  | 或运算      | A B  |
| 4  | 输出写入数据 2 | В    |
| 5  | 异或运算     | A^B  |

#### 5. dm (数据存储器)

## 1) 端口说明

表格 9dm 端口说明

| 信号名       | 方向 | 描述                |
|-----------|----|-------------------|
| D1 [31:0] | _  | 32 位输入数据 1        |
| D2[31:0]  | _  | 32 位输入数据 2        |
| CO        | 0  | 比较结果 0: 不相等 1: 相等 |

表格 10dm 功能定义

| 序号 | 功能名称 | 功能描述                     |
|----|------|--------------------------|
| 1  | 比较   | 比较两输入数据大小,相等输出 1, 否则输出 0 |

- 6. cmp (比较器)
- 1) 端口说明

表格 11dm 端口说明

| 信号名         | 方 | 描述                  |
|-------------|---|---------------------|
|             | 向 |                     |
| clk         | ı | 时钟信号                |
| reset       | ı | 复位信号 1: 复位 0: 无效    |
| ADDR [31:0] | ı | 32 位写入内存地址          |
| din[31:0]   | ı | 32 位写入数据            |
| PC8[31:0]   | ı | 当前 PC+8             |
| MemWrite    | I | 写内存控制信号 1: 写入 0: 无效 |
| dout[31:0]  | 0 | 32 位输出数据            |

表格 12dm 功能定义

| 序号 | 功能名称 | 功能描述                              |
|----|------|-----------------------------------|
| 1  | 复位   | 复位信号有效时,内存和读出内存的寄存器被置为 0x00000000 |
| 2  | 写内存  | 写内存控制信号有效时,根据输入的地址写入 32 位数据       |
| 3  | 读内存  | 根据输入的地址读出内存数据                     |

## 7. ext (位扩展器)

## 1) 端口说明

表格 13ext 端口说明

| 信号名           | 方向 | 描述                                               |
|---------------|----|--------------------------------------------------|
| immed16[15:0] | ı  | 16 位写入立即数                                        |
| EXTop[2:0]    | ı  | 扩展控制信号 000: 无符号扩展 001: 低 16 位补 0 010: 有符号扩展 011: |
|               |    | 有符号扩展后逻辑左移两位                                     |
| E0[31:0]      | 0  | 32 位输出立即数                                        |

表格 14ext 功能定义

| 序号 | 功能名称      | 功能描述                                             |
|----|-----------|--------------------------------------------------|
| 1  | 无符号扩展     | 高 16 位补 0                                        |
| 2  | 低 16 位补 0 | 低 16 位补 0                                        |
| 3  | 有符号扩展     | Immed[15]为1时高16位补1,为0时高16位补0                     |
| 4  | 有符号扩展后    | Immed[15]为 1 时高 16 位补 1,为 0 时高 16 位补 0,再左移两位,溢出舍 |
|    | 逻辑左移两位    | 去,低 2 位补 0                                       |

#### 8. mux (多路选择器)

#### 1) 端口说明

表格 15mux 端口说明

|         |    | 农借 13IIIIX <b>纳口优奶</b>                                   |
|---------|----|----------------------------------------------------------|
| 信号名     | 方向 | 描述                                                       |
| A[4:0]  | _  | 5 位输入 A                                                  |
| B[4:0]  | _  | 5 位输入 B                                                  |
| C[4:0]  | I  | 5 位输入 C                                                  |
| 0p[1:0] | I  | 选择控制信号 10: 输出 C 01: 输出 B 00: 输出 A                        |
| 0 [4:0] | 0  | 5 位输出 0                                                  |
| A[31:0] | I  | 32 位输入 A                                                 |
| B[31:0] | I  | 32 位输入 B                                                 |
| C[31:0] | I  | 32 位输入 C                                                 |
| D[31:0] | 1  | 32 位输入 D                                                 |
| E[31:0] | 1  | 32 位输入 E                                                 |
| op[2:0] | 1  | 选择控制信号 100: 输出 E 011: 输出 D 010: 输出 C 001: 输出 B 000: 输出 A |
| 0[31:0] | 0  | 32 位输出 0                                                 |

表格 16mux 功能定义

| 序号 | 功能名称        | 功能描述                                 |
|----|-------------|--------------------------------------|
| 1  | 5 位输入 3 选 1 | option 为 10 输出 C,为 01 输出 B,为 00 输出 A |

| 2 | 32 位输入 2 选 1 | option 为 1 输出 B, 为 0 输出 A                              |
|---|--------------|--------------------------------------------------------|
| 3 | 32 位输入 3 选 1 | option 为 10 输出 C, 为 01 输出 B, 为 00 输出 A                 |
| 4 | 32 位输入 4 选 1 | option 为 11 输出 D, 为 10 输出 C, 为 01 输出 B, 为 00 输出 A      |
| 5 | 32 位输入 5 选 1 | option100 输出 E, 011 输出 D, 010 输出 C, 001 输出 B, 000 输出 A |

# 9. Dregs (D级流水线寄存器)

表格 17 Dregs 端口说明

| 信号名          | 方向 | 描述                                                 |
|--------------|----|----------------------------------------------------|
| clk          | ı  | 时钟信号                                               |
| reset        | I  | 复位信号 1: 复位 0: 无效                                   |
| IR[31:0]     | I  | D 级部件将使用的指令                                        |
| PC8[31:0]    | I  | D 级部件对应指令的 PC+8                                    |
| Stall        | I  | 冒险单元输入的暂停信号                                        |
| PCsel[1:0]   | I  | 将传回 F 级部件的 PC 选择信号                                 |
| I16[15:0]    | I  | 将传回 F 级部件的 16 位立即数                                 |
| 126[25:0]    | I  | 将传回 F 级部件的 26 位立即数                                 |
| Beq          | Ι  | 将传回 F 级部件的 beq 识别信号                                |
| EXTop [2:0]  | Ι  | 扩展控制信号 000: 无符号扩展 001: 低 16 位补 0 010: 有符号扩展 011:   |
|              |    | 有符号扩展后逻辑左移两位                                       |
| WRsel[1:0]   | I  | 选择寄存器 A3 端口信号 10:31 号寄存器 01: IR_W[rd] 00: IR_W[rt] |
| IR_D [31:0]  | 0  | 输出到 E 级寄存器的指令                                      |
| PC8_D[31:0]  | 0  | 输出到 E 级寄存器的 PC+8                                   |
| PCseI_D[1:0] | 0  | 输出到 F 级寄存器的 PC 选择信号                                |
| i16_D        | 0  | 将传回 F 级部件的 16 位立即数                                 |
| 126_D        | 0  | 将传回 F 级部件的 26 位立即数                                 |
| Beq_D        | 0  | 将传回 F 级部件的 beq 识别信号                                |
| EXTop_D[2:0] | 0  | 扩展控制信号 000: 无符号扩展 001: 低 16 位补 0 010: 有符号扩展 011:   |

|              |   | 有符号扩展后逻辑左移两位                                       |
|--------------|---|----------------------------------------------------|
| WRseI_D[1:0] | 0 | 选择寄存器 A3 端口信号 10:31 号寄存器 01: IR_W[rd] 00: IR_W[rt] |

表格 18 Dregs 功能定义

| 序号 | 功能名称 | 功能描述                        |
|----|------|-----------------------------|
| 1  | 存储结果 | 存储 F 级部件结果,发送到 D 级部件或 F 级部件 |

## 10. Eregs(E 级流水线寄存器)

表格 19 Eregs 端口说明

| 信号名          | 方向 | 描述                                            |
|--------------|----|-----------------------------------------------|
| clk          | ı  | 时钟信号                                          |
| reset        | ı  | 复位信号 1: 复位 0: 无效                              |
| IR[31:0]     | ı  | E 级部件将使用的指令                                   |
| PC8[31:0]    | ı  | E 级部件对应指令的 PC+8                               |
| Stall        | ı  | 冒险单元输入的暂停信号                                   |
| V1 [31:0]    | ı  | MFcmp1D 转发而来的结果                               |
| V2[31:0]     | ı  | MFcmp2D 转发而来的结果                               |
| E32[31:0]    | ı  | EXT 结果                                        |
| RFA3[4:0]    | ı  | E 级指令要写入的寄存器编号                                |
| Bsel         | ı  | Alub 多选器的选择信号                                 |
| ALUctr [2:0] | ı  | 控制信号 000: 加运算 001: 减运算 010: 或运算 011: 输出写入数据 2 |
|              |    | 100:异或运算                                      |
| IR_E[31:0]   | 0  | 输出到 E 级寄存器的指令                                 |
| PC8_E[31:0]  | 0  | 输出到 E 级寄存器的 PC+8                              |
| RFA3E[4:0]   | 0  | 输出到 E 级的要写入的寄存器编号                             |
| V1 [31:0]    | 0  | MFcmp1D 转发而来的结果                               |

| V2[31:0]      | 0 | MFcmp2D 转发而来的结果                               |
|---------------|---|-----------------------------------------------|
| BseI_E        | 0 | Alub 多选器的选择信号                                 |
| ALUctr_E[2:0] | 0 | alu 控制信号 000:加运算 001:减运算 010:或运算 011:输出写入数据   |
|               |   | 2 100:异或运算                                    |
| Res_E [1:0]   | 0 | E 级指令对部件的产生结果位置 ALU: 在 alu 产生结果 DM: 在 dm 产生结果 |
|               |   | PC: 产生 PC 结果 NW: nowrite, 不产生结果               |

表格 20Eregs 功能定义

| 序号 | 功能名称     | 功能描述                 |
|----|----------|----------------------|
| 1  | 存储结果     | 存储 D 级部件结果,发送到 E 级部件 |
| 2  | 产生控制转发信号 | 计算 E 级指令对部件的产生结果位置   |

## 11. Mregs(M 级流水线寄存器)

表格 21Mregs 端口说明

|             |    | _                     |
|-------------|----|-----------------------|
| 信号名         | 方向 | 描述                    |
| clk         | I  | 时钟信号                  |
| reset       | I  | 复位信号 1: 复位 0: 无效      |
| IR[31:0]    | -  | M 级部件将使用的指令           |
| PC8[31:0]   | I  | M 级部件对应指令的 PC+8       |
| A0[31:0]    | I  | ALU 的结果               |
| V2[31:0]    | I  | MFcmp2D 转发而来的结果       |
| RFA3[4:0]   | I  | M 级指令要写入的寄存器编号        |
| MemWrite    | I  | Dm 写入控制信号 1: 写入 0: 无效 |
| IR_M[31:0]  | 0  | 输出到 W 级寄存器的指令         |
| PC8_M[31:0] | 0  | 输出到 W 级寄存器的 PC+8      |
| RFA3M[4:0]  | 0  | 输出到 M 级的要写入的寄存器编号     |

| A0_M[31:0] | 0 | 输出到 W 级的 alu 结果                               |
|------------|---|-----------------------------------------------|
| V2[31:0]   | 0 | 输出到 W 级的 MFcmp2D 转发而来的结果                      |
| MemWrite   | 0 | 输出到 M 级部件的 Dm 写入控制信号 1: 写入 0: 无效              |
| Res_M[1:0] | 0 | M 级指令对部件的产生结果位置 ALU: 在 alu 产生结果 DM: 在 dm 产生结果 |
|            |   | PC: 产生 PC 结果 NW: nowrite, 不产生结果               |

表格 22Mregs 功能定义

| 序号 | 功能名称     | 功能描述                 |
|----|----------|----------------------|
| 1  | 存储结果     | 存储 E 级部件结果,发送到 M 级部件 |
| 2  | 产生控制转发信号 | 计算 M 级指令对部件的产生结果位置   |

## 12. Wregs(W 级流水线寄存器)

表格 23Wregs 端口说明

|             |    | ATH ZOWINGS AND BUY                      |
|-------------|----|------------------------------------------|
| 信号名         | 方向 | 描述                                       |
| clk         | I  | 时钟信号                                     |
| reset       | -  | 复位信号 1: 复位 0: 无效                         |
| IR[31:0]    | -  | W 级部件将使用的指令                              |
| PC8[31:0]   | I  | W 级部件对应指令的 PC+8                          |
| A0[31:0]    | -  | ALU 的结果                                  |
| DR[31:0]    | I  | DM 的结果                                   |
| RFA3[4:0]   | I  | W 级指令要写入的寄存器编号                           |
| RegWrite    | I  | 寄存器堆写入控制信号 1: 写入 0: 无效                   |
| WDsel[1:0]  | I  | 寄存器堆写入数据选择信号 10: PC8_W 01: DR_W 00: A0_W |
| PC8_W[31:0] | 0  | 输出到 W 级部件的 PC+8                          |
| RFA3W[4:0]  | 0  | 输出到 W 级的要写入的寄存器编号                        |
| AO_W[31:0]  | 0  | 输出到 W 级部件的 alu 结果                        |

| DR_W[31:0]   | 0 | 输出到 W 级部件 DM 的结果                              |
|--------------|---|-----------------------------------------------|
| RegWrite     | 0 | 输出到 W 级部件的寄存器写入控制信号 1: 写入 0: 无效               |
| WDsel_W[1:0] | 0 | 寄存器堆写入数据选择信号 10: PC8_W 01: DR_W 00: A0_W      |
| Res_W[1:0]   | 0 | W 级指令对部件的产生结果位置 ALU: 在 alu 产生结果 DM: 在 dm 产生结果 |
|              |   | PC: 产生 PC 结果 NW: nowrite, 不产生结果               |

表格 24Wregs 功能定义

| 序号 | 功能名称     | 功能描述                 |
|----|----------|----------------------|
| 1  | 存储结果     | 存储 M 级部件结果,发送到 W 级部件 |
| 2  | 产生控制转发信号 | 计算 W 级指令对部件的产生结果位置   |

## 13. Cp0(协处理器)

表格 25cp0 端口说明

| 信号名           | 方向 | 描述                                                    |
|---------------|----|-------------------------------------------------------|
| clk           | 1  | 时钟信号                                                  |
| reset         | 1  | 复位信号 1: 复位 0: 无效                                      |
| A1 [4:0]      | I  | 读 cp0 寄存器号                                            |
| A2[4:0]       | I  | 写 cp0 寄存器号                                            |
| DIn[31:0]     | 1  | 写入数据                                                  |
| PC[31:0]      | 1  | 异常 PC                                                 |
| BD            | 1  | 延迟槽指示信号 1: 在延迟槽中 0: 无效                                |
| ExcCode [6:2] | 1  | 中断异常类型 0: 中断 4: 取指取数错误 5: 存数地址错误 10: 无效指令 12: 自陷式指令溢出 |
| HWInt[5:0]    | I  | 6 个中断设备                                               |
| We            | I  | 写使能信号 1: 写入 0: 无效                                     |
| EXLCIr        | 1  | EXL 清零信号 1: 清零 0: 无效                                  |
| AdEL          | 1  | AdEL 指示信号                                             |

| AdES        | 1 | AdES 指示信号        |
|-------------|---|------------------|
| IntReq      | 0 | 中断指示 1: 中断 0: 无效 |
| EPC[31:2]   | 0 | 异常 PC            |
| DOut [31:0] | 0 | Cp0 输出数据         |

表格 26cp0 功能定义

| 序号 | 功能名称     | 功能描述                        |
|----|----------|-----------------------------|
| 1  | 复位       | 复位信号有效时,HI 和 LO 寄存器和信号被置为 0 |
| 2  | 写入数据     | 向 cp0 中寄存器写入数据 din          |
| 3  | 读取数据     | 读出 cp0 中寄存器值                |
| 4  | 输出中断信号   | 输出中断信号                      |
| 5  | 存储中断异常类型 | 在寄存器中存储中断异常类型               |

## 14. Muldiv (乘除单元)

表格 27Muldiv 端口说明

| 信号名       | 方向 | 描述                                             |  |  |  |  |  |  |  |
|-----------|----|------------------------------------------------|--|--|--|--|--|--|--|
| clk       | I  | 时钟信号                                           |  |  |  |  |  |  |  |
| reset     | I  | 复位信号 1: 复位 0: 无效                               |  |  |  |  |  |  |  |
| A[31:0]   | I  | 乘除单元输入数据 1                                     |  |  |  |  |  |  |  |
| B[31:0]   | I  | 乘除单元输入数据 2                                     |  |  |  |  |  |  |  |
| op[2:0]   | I  | 乘除单元控制信号 000: 无效 001: 有符号乘 010: 无符号乘 011: 有符号隊 |  |  |  |  |  |  |  |
|           |    | 100: 无符号除 101: mthi 110: mtlo                  |  |  |  |  |  |  |  |
| HI [31:0] | 0  | HI 寄存器                                         |  |  |  |  |  |  |  |
| L0[31:0]  | 0  | L0 寄存器                                         |  |  |  |  |  |  |  |
| busy      | 0  | 乘除运算进行信号 1: 正在运算 0: 无效                         |  |  |  |  |  |  |  |
| start     | 0  | Busy 信号产生信号 1:下一个时钟上升沿 busy 有效 0:无效            |  |  |  |  |  |  |  |

表格 28Muldiv 功能定义

| 序号 | 功能名称  | 功能描述                                           |
|----|-------|------------------------------------------------|
| 1  | 复位    | 复位信号有效时,HI 和 LO 寄存器和信号被置为 0                    |
| 2  | 有符号乘  | 有符号乘法, 其中结果高 32 位保存在 HI, 低 32 位保存在 L0, 时长 5 周期 |
| 3  | 无符号乘  | 无符号乘法, 其中结果高 32 位保存在 HI, 低 32 位保存在 L0, 时长 5 周期 |
| 4  | 有符号除  | 有符号除法,其中结果余数保存在 HI ,商保存在 L0,时长 10 周期           |
| 5  | 无符号除  | 无符号除法,其中结果余数保存在 HI ,商保存在 L0,时长 10 周期           |
| 6  | 修改 HI | 将 rs 的值存入 HI 寄存器                               |
| 7  | 修改 L0 | 将 rs 的值存入 L0 寄存器                               |
| 8  | 读取HI  | 读取 HI 寄存器的值,写入 rd                              |
| 9  | 读取 L0 | 读取 L0 寄存器的值,写入 rd                              |

# (三) 冒险单元

## 1. 端口说明

表格 29hazard 端口说明

| 信号名        | 方向 | 描述               |
|------------|----|------------------|
| IR[31:0]   | I  | D 级部件将使用的指令      |
| Res_E[1:0] | I  | E 级传来的控制信号       |
| Res_M[1:0] | I  | M 级传来的控制信号       |
| Res_W[1:0] | I  | W 级传来的控制信号       |
| A3_E[4:0]  | I  | E 级指令要写入的寄存器编号   |
| A3_M[4:0]  | I  | M 级指令要写入的寄存器编号   |
| A3_W[4:0]  | I  | W 级指令要写入的寄存器编号   |
| A1_D[4:0]  | I  | D 级指令要读入的寄存器编号 1 |
| A2_D[4:0]  | I  | D 级指令要读入的寄存器编号 2 |
| A1_E[4:0]  | I  | E 级指令要读入的寄存器编号 1 |

| A2_E[4:0]   | Ι | E 级指令要读入的寄存器编号 2                                               |
|-------------|---|----------------------------------------------------------------|
| A2_M[4:0]   | Ι | M 级指令要读入的寄存器编号                                                 |
| Busy        | I | 乘除运算进行信号 1: 正在运算 0: 无效                                         |
| start       | I | Busy 信号产生信号 1:下一个时钟上升沿 busy 有效 0:无效                            |
| stall       | 0 | 暂停信号 1: 暂停 0: 无效                                               |
| Fcmp1D[2:0] | 0 | 输出到 D 级的 cmp 编号 1 转发信号 000: RF. V1 001: M_Wdata 010: A0_M      |
|             |   | 011: PC8_M 100: PC8_E                                          |
| Fcmp2D[2:0] | 0 | 输出到 D 级的 cmp 编号 2 转发信号 000: RF. V2 001: M_Wdata 010: A0_M      |
|             |   | 011: PC8_M 100: PC8_E                                          |
| FaluaE[1:0] | 0 | 输出到 E 级 ALUa 的转发信号 00: V1_E 01: M_Wdata 10: A0_M 11: PC8_M     |
| FalubE[1:0] | 0 | 输出到 E 级 ALUb 的转发信号 00: V2_E 01: M_Wdata 10: A0_M 11: PC8_M     |
| FPCF [2:0]  | 0 | 输出到 F 级 PC 的转发信号 000: RF. V1 001: M_Wdata 010: A0_M 011: PC8_M |
|             |   | 100: PC8_E                                                     |
| FdmdataM    | 0 | 输出到 M 级 DMin 的转发信号 0: V2_M 1: M_Wdata                          |

#### 2. 功能定义

表格 30hazard 功能定义

| 序号 | 功能名称   | 称 功能描述                |  |  |  |  |  |  |  |  |
|----|--------|-----------------------|--|--|--|--|--|--|--|--|
| 1  | 产生暂停信号 | 根据 Tuse 和 Tnew 产生暂停信号 |  |  |  |  |  |  |  |  |
| 2  | 产生转发信号 | 根据 Tuse 和 Tnew 产生转发信号 |  |  |  |  |  |  |  |  |

# (四) Bridge 和 timer

## 1. 端口说明

表格 31bridge 和 timer 端口说明

| 信号名         | 方向 | 描述                                 |
|-------------|----|------------------------------------|
| clk         | I  | 时钟信号                               |
| reset       | I  | 复位信号 1: 复位 0: 无效                   |
| ADD_I [1:0] | I  | 写入寄存器信号 0: ctrl 1: preset 2: count |

| WE_I          | 1 | 写入控制信号 1: 写入 0: 无效               |
|---------------|---|----------------------------------|
| DAT_I [31:0]  | 1 | 写入数据                             |
| DAT_0[31:0]   | 0 | 输出数据                             |
| IRQ           | 0 | Timer 中断信号 1: 中断 0: 无效           |
| PrAddr [31:0] | 1 | 识别写入 timer0 或 timer1             |
| timer0we      | 0 | Timer0 指示信号 1: 对 timer0 处理 0: 无效 |
| Timer1we      | 0 | Timer1 指示信号 1: 对 timer1 处理 0: 无效 |

## 2. 功能定义

表格 32bridge 和 timer 功能定义

| 序号 | 功能名称   | 功能名称      功能描述                  |  |  |  |  |  |  |  |  |
|----|--------|---------------------------------|--|--|--|--|--|--|--|--|
| 1  | 复位     | 复位 复位信号有效时, HI 和 LO 寄存器和信号被置为 0 |  |  |  |  |  |  |  |  |
| 2  | 产生中断信号 | 倒数至 0 时产生中断信号                   |  |  |  |  |  |  |  |  |
| 3  | 读取数据   | 读取 timer 中数据                    |  |  |  |  |  |  |  |  |
| 4  | 写入数据   | 向 timer 中写入数据                   |  |  |  |  |  |  |  |  |

## (五) 控制器设计

# 1. 端口说明

表格 33ctr 端口说明

| 信号名                                                   | 方向 | 描述                                                     |  |  |
|-------------------------------------------------------|----|--------------------------------------------------------|--|--|
| instruction[31:0]                                     | I  | 32 位指令                                                 |  |  |
| WR_sel                                                | 0  | grf 写寄存器决定信号 0: rd 1: rt 2: 31 号寄存器                    |  |  |
| A_sel                                                 | 0  | alu 输入数据 A 决定信号 0: MFaluaE 1: IR[10:6] 2: MFaluaE[4:0] |  |  |
| B_sel                                                 | 0  | alu 输入数据 B 决定信号 1:32 位立即数 0:GRF 寄存器 2 输出值              |  |  |
| RegWrite                                              | 0  | grf 写寄存器信号 1: 写寄存器 0: 无效                               |  |  |
| MemWrite 0                                            |    | 写内存 dm 信号 1:写入内存 0:无效                                  |  |  |
| PC_sel 0 PC 跳转信号 `ADD4: 跳转 PC+4 `NPC: 跳转 npc `RFV1: 跳 |    |                                                        |  |  |
| EXTop[1:0] 0 扩展控制信号 00: 无符号扩展 01: 低 16 位补 0 10: 有符    |    |                                                        |  |  |

|                                                         | 有符号扩展后逻辑左移两位                                          |  |  |  |  |  |  |
|---------------------------------------------------------|-------------------------------------------------------|--|--|--|--|--|--|
| 0                                                       | alu 控制信号 0000 加 0001 减 0010 或 0011B 0100 异或 0101 逻辑左移 |  |  |  |  |  |  |
|                                                         | 0110 逻辑右移 0111 算数右移 1000 与 1001 或非 1010 有符号小于置 1      |  |  |  |  |  |  |
|                                                         | 1011 无符号小于置 1                                         |  |  |  |  |  |  |
| 0                                                       | Beq 指示信号 0: 无效 1: beq                                 |  |  |  |  |  |  |
| 0                                                       | bne 指示信号 0: 无效 1: bne                                 |  |  |  |  |  |  |
| 0                                                       | Bgez 指示信号 0: 无效 1: Bgez                               |  |  |  |  |  |  |
| 0                                                       | Blez 指示信号 0: 无效 1: Blez                               |  |  |  |  |  |  |
| 0                                                       | Bgtz 指示信号 0:无效 1:Bgtz                                 |  |  |  |  |  |  |
| 0                                                       | blez 指示信号 0: 无效 1: blez                               |  |  |  |  |  |  |
| 0                                                       | 乘除模块控制信号 0: 无效 1: mult 2: multu 3: div 4: divu 5:     |  |  |  |  |  |  |
| mthi 6: mtlo                                            |                                                       |  |  |  |  |  |  |
| 0                                                       | 写入寄存器堆数据选择信号 0: DR_W 1: PC8_W 2: A0_W                 |  |  |  |  |  |  |
| Dmexto[2:0] 0 Dm 扩展器控制信号 0: 无效 1: Ibu 2: Ib 3: Ihu 4: I |                                                       |  |  |  |  |  |  |
|                                                         | 0<br>0<br>0<br>0<br>0                                 |  |  |  |  |  |  |

# 2. 真值表

| func     | 100001 | 100011 | 100000 | 100010 | 001000 | 001001     |        |        |        |        |        |        |        |
|----------|--------|--------|--------|--------|--------|------------|--------|--------|--------|--------|--------|--------|--------|
| ор       | 000000 | 000000 | 000000 | 000000 | 000000 | 000000     | 001101 | 100011 | 101011 | 000100 | 001111 | 001110 | 101001 |
|          | addu   | subu   | add    | sub    | jr     | jalr       | ori    | lw     | SW     | beq    | lui    | xori   | sh     |
| RegDst   |        | 11     | . 1    | . 1    | 1 0    |            | _      | 00     | 0 0    |        |        |        | •      |
| Asel     | 00     | 00     | 00     | 00     | 00     | 00         | 00     | 00     | 00     | 00     | 00     | 00     | 00     |
| Bsel     | (      | 0 0    | 0      | 0      | 0      | 0          |        | 1 1    | 1 1    | 1 0    | 1      | . 1    | 1 1    |
| MemtoReg | (      | 0 0    | 0      | 0      | 0      | 0          | ) /    | 0 1    | 1 0    | 0      | 0 0    | 0      | 0 0    |
| RegWrite | 1      | 1 1    | 1      | 1      | 0      | , <b>1</b> | L .    | 1 1    | 1 0    | 0      | 1      | . 1    | 1 0    |
| MemWrite |        | 0 0    |        |        |        |            |        | 00     | 0 1    |        |        | _      |        |
|          | 00     |        |        | 00     |        | 00         | 00     | 10     |        | 11     |        | 00     | 10     |
|          | 0000   | 0001   | 0000   | 0001   |        | 0000       | 0010   | 0000   | 0000   | 0000   |        | 0100   | 0000   |
| dmextop  | 000    | 000    | 000    | 000    | 000    | 000        | 000    | 000    | 000    | 000    | 000    | 000    | 000    |
|          |        |        | -      | -      |        | -          |        | _      |        |        |        | -      |        |
| func     | 000000 | 000000 | 000000 | 000000 |        | 000000     |        |        |        |        |        |        |        |
| ор       | 000000 | 000010 | 000011 | 000100 | 000110 | 000111     | 000011 | 000010 | 100000 | 100100 | 100001 | 100101 | 101000 |
|          | sll    | srl    | sra    | sllv   | _      | srav       | jal    | ٦j     | lb     | lbu    | lh     | lhu    | sb     |
|          | 1      | 1      |        | 1      | 1      | 1          |        | 0 0    |        | •      |        | ,      |        |
| Asel     | 01     | 01     |        | 10     |        | 10         | 00     | 00     | 00     | 00     | 00     | 00     | 00     |
| Bsel     | 0      | 0      | 0      | 0      | 0      | 0          |        | 0 0    | J 1    | . 1    | . 1    | . 1    | 1 1    |
| MemtoReg | 0      | 0      | 0      | 0      | 0      | 0          |        | 0 0    | J 1    | . 1    | . 1    |        | 1 0    |
| RegWrite | 1      | 1      | 1      | 1      | 1      | 1          | (      | 1 0    | 0 1    | 1 1    | 1 1    |        | 1 0    |
| MemWrite | 0      | 0      | 0      | 0      | 0      | 0          |        | 0 0    |        |        |        |        |        |
|          | 00     | 00     | 00     | 00     | _      | 00         | 00     | 00     | 10     | 10     |        | 10     | 10     |
| ALUctr   | 0101   | 0110   | 0111   | 0101   | 0110   | 0111       | 0000   | 0000   | 0000   | 0000   | 0000   | 0000   | 0000   |
|          | 000    | 000    | 000    | 000    |        | 000        | 000    | 000    | 010    | 001    | 100    | 011    | 000    |

表格 34ctr 真值表

(六) 测试

(一) 测试程序

功能测试:

```
add $a2, $t1, $t1 #++
#功能测试
                                                 lui $t3,0xf39f
                        subu $a0, $t0, $t1 #-+
                                                 or $a1,$t0,$t3 #--
ori $t0,$0,520
                        subu $a1, $t1, $t0 #+-
                                                 xor $a2, $t3, $t0
ori $t1, $t0, 233
                        subu $a2, $t1, $t2 #++
                                                 nor $a0, $t0, $t1 #-+
                        subu $a3, $t2, $t1 #++
                                                 nor $a1,$t1,$t0 #+-
1ui $t0,520
                        lui $t3,0xf39f
                                                 nor $a2, $t1, $t2 #++
lui $t1, 0xffff
                        subu $a1, $t0, $t3 #--
ori $t1, $t1, 0xffff
                        subu $a2,$t3,$t0
                                                 #mult
                                                 lui $t0,0xfeaf
#addu, subu
                        #and, or, xor, nor
                                                 ori $t0, $t0, 0x5254
addu $t2, $t0, $t0#++
                        ori $s0, $0, 1
                                                 lui $t1,0x0243
addu $t3, $t0, $t1#+-
                        ori $s1, $0, 4
                                                 ori $t1, $t1, 0x323f
addu $t4, $t1, $t1#--
                        ori $s2, $0, 15
                                                mult $t0,$t0 #--
subu $t5,$t0,$t2#++
                        lui $t0,0xfda3
                                                 mfhi $a0
subu $t6, $t0, $t1#+-
                        ori $t0, $t0, 0x34f5 #-
                                                 mflo $al
subu $t7,$t1,$t4#--
                        ori $t1, $0, 0x234 #+
                                                 mult $t1,$t0 #+-
                        lui $t2,0x424
                                                 mfhi $a0
#add, sub
                        ori $t2, $t2, 32853
                                                 mflo $al
ori $s0,$0,1
                        and $a0, $t0, $t1 #-+
ori $s1,$0,4
                                                 mult $t1,$t1 #-+
                        and $a1,$t0,$t0 #--
ori $s2, $0, 15
                                                 mfhi $al
                        and $a2,$t1,$t1 #++
                                                 mflo $a0
lui $t0,0xfda3
ori $t0,$t0,0x34f5 #- or $a0,$t0,$t1 #-+
                        or $a1,$t1,$t0 #+-
                                                 #multu
ori $t1,$0,0x234 #+
                        or $a2,$t1,$t2 #++
                                                 lui $t0,0xfeaf
1ui $t2,0x424
                        xor $a3, $t2, $t1 #++
                                                 ori $t0, $t0, 0x5254
ori $t2, $t2, 32853
                        xor $a0, $t0, $t1 #-+
                                                 1ui $t1, 0x0243
add $a0,$t0,$t1 #-+
                        xor $a1, $t1, $t0 #+-
                                                 ori $t1,$t1,0x323f
add $a1,$t0,$t0 #--
```

| mflo \$al                      | mflo \$al                      | mfhi \$a0            |
|--------------------------------|--------------------------------|----------------------|
| multu \$t1,\$t0                | div \$t1,\$t3 #++              | mflo \$al            |
| mfhi \$a0                      | mfhi \$a0                      | mu1t \$t1,\$t0       |
| mflo \$al                      | mflo \$al                      | mthi \$t1            |
| multu \$t1,\$t1                | div \$t0,\$t1 #-+              | mfhi \$a0            |
| mfhi \$a0                      | mfhi \$a0                      | mu1t \$t1, \$t1      |
| mflo \$al                      | mflo \$al                      | mtlo \$t0            |
|                                | div \$t1,\$t0                  | mfhi \$a0            |
| #div, divu                     | mfhi \$a0                      | mflo \$al            |
| lui <mark>\$t0</mark> ,0xfeaf  | mflo \$al                      |                      |
| ori \$t0,\$t0,0x5254           | div \$t0,\$t2 #                | #s11, sr1, sra       |
| lui \$t1,0x0243                | mfhi \$a0                      | ori \$t0,\$t0,123    |
| ori \$t1,\$t1,0x323f           | mflo \$al                      | s11 \$t0,\$t0,4      |
| 1ui <mark>\$t2</mark> , 0xe120 | div \$t2,\$t0                  | srl \$t0,\$t0,4      |
| ori \$t2,\$t2,0x300            | mfhi \$a0                      | ori \$t1,\$t1,0xffff |
| ori \$t3,\$0,0x99              | mflo \$al                      | s11 \$t1, \$t1, 2    |
| div \$t0,\$t1 #-+              | div \$t1,\$t3 #++              | sr1 \$t1,\$t1,2      |
| mfhi \$a0                      | mfhi \$a0                      | sra \$t0,\$t0,3 #+   |
| mflo \$al                      | mflo \$al                      | 1ui \$t0,0xf234      |
| div \$t1,\$t0                  |                                | sra \$t1,\$t0,3 #-   |
| mfhi \$a0                      | #mthi, mtlo                    | 1ui \$t0,0x23        |
| mflo \$al                      | lui <mark>\$t0</mark> , 0xfeaf | sra \$t0,\$t0,4 #+   |
| div \$t0,\$t2 #                | ori \$t0,\$t0,0x5254           |                      |
| mfhi \$a0                      | 1ui \$t1,0x0243                | #s11v, sr1v, srav    |
| mflo \$al                      | ori \$t1,\$t1,0x323f           | ori \$s0,\$0,1       |
| div \$t2,\$t0                  | mult \$t0,\$t0                 | ori \$s1,\$0,4       |
| mfhi \$a0                      | mthi \$t0                      | ori \$s2,\$0,15      |
|                                |                                |                      |

```
sltu $a2, $t3, $t4
lui $t0,0xfda3
                                                    addi $a0,$t0,0xea4
                          s1tu $a3,$t4,$t3
ori $t0,$t0,0x34f5
                                                    addi $a1, $t0, -134
ori $t1,$0,0x234
                                                    addi $a2,$t1,0xf53f
                          #jalr
lui $t2,0x424
                                                    addi $a3,$t1,533
                          ori $t0,$0,1
ori $t2,$t2,32853
                                                    addiu $a0, $t0, 0xea4
                          jal jalr_loop
s11v $a0, $t0, $s0 #-
                                                    addiu $a1,$t0,-134
                          ori $t0, $ra, 0
s11v $a1, $t1, $s1 #+
                                                    addiu $a2,$t1,0xf53f
                          ori $t2, $0, 2
s11v $a3, $t2, $s2 #+
                                                    addiu $a3, $t1, 533
                          addu $a1, $a1, $a0
srlv $a0,$t0,$s0
                                                    andi $a0,$t0,0xea4
                          j jalr_end
srlv $al,$tl,$sl
                                                    andi $a1,$t0,-134
                          ori $t6, $t6, 6
sr1v $a3,$t2,$s2
                                                    andi $a2,$t1,0xf53f
                          jalr_loop:
srav $a0,$t0,$s0
                                                    andi $a3,$t1,533
                          addu $a0,$0,$ra
srav $a0,$t0,$s1
                                                    xori $a0,$t0,0xea4
                          |ja1r $a0,$ra
srav $a1, $t1, $s1
                                                    xori $a1, $t0, -134
                          ori $t4,$a0,0
srav $a3,$t2,$s2
                                                    xori $a2, $t1, 0xf53f
                          ori $t5,$t5,5
                                                    xori $a3, $t1, 533
                          jalr end:
#slt, sltu
ori $t0, $0, 2
                                                    #slti, sltiu
                          #addi, addiu, andi, xori
ori $t1, $0, 1
                                                    ori $t0,$0,2
                          ori $s0, $0, 1
ori $t2, $0, 2
                                                    ori $t1,$0,1
                          ori $s1, $0, 4
lui $t3, Oxffff
                                                    lui $t3, 0xffff
                          ori $s2, $0, 15
s1t $a0,$t2,$t1#++
                                                    slti $a0,$t1,2 #+
                          1ui $t0, 0xfda3
s1t $a1,$t3,$t1#-+
                                                    slti $a1, $t0, 1
                          ori $t0, $t0, 0x34f5 #-
ori $t4, $t3, 0x1234
                                                    slti $a2,$t0,-100
                          ori $t1, $0, 0x234 #+
s1t $a2,$t3,$t4 #--
                                                    s1ti $a3, $t3, 2390
                          1ui $t2,0x424
s1tu $a0, $t2, $t1 #++
                                                    sltiu $a0,$t1,2 #+
                          ori $t2, $t2, 32853
s1tu $a1, $t3, $t1 #-+
                                                    sltiu $a1,$t0,1
```

```
bgtz $a2, bgtz_1abe13
                              1bu $2,3($0)
s1tiu $a2, $t0, -100 #-
                                                           ori $t0, $t0, 1
sltiu $a3, $t3, 2390
                                                           ori $t1, $t1, 2
                              #bne
                                                           bgtz $a0, bgtz_1abe13
#sw, sh, sb, 1h. 1hu, 1b, 1bu ori $t0, $0, 1
                                                           ori $t2, $t2, 2
                              bne $t0, $t0, bne_1abel1
ori $20, $0, 1
                                                           ori $t3, $t3, 3
1ui $21, 0xffff
                              ori $t1,$0,1
                                                           bgtz $al, bgtz_label3
ori $21, $21, 0xffff
                              ori $t2,$0,2
                                                           ori $t5, $t5, 5
                              bne $t0, $t2, bne 1abel1
1ui $3,0xf3f4
                                                           ori $t6, $t6, 6
ori $3, $3, 0x71f2
                              ori $t3,$0,3
                                                           bgtz label3:ori $t4, $t4, 4
sw $3,0($0)
                              ori $t4, $0, 4
                              bne_1abe11:ori $t3, $t3, 3
sh $3,8($0)
                                                           #bltz, bgez
sh $3, 10($0)
                                                           ori $a1, $0, 1
                              #blez, bgtz
sb $3, 4($0)
                                                           1ui $a2, 0xf433
sb $3,5($0)
                              ori $a1,$0,1
                                                           bgez $a2, bgez_label1
sb $3,6($0)
                              lui $a2,0xf433
                                                           ori $t0, $t0, 1
                              blez $al, blez_labell
sb $3,7($0)
                                                           ori $t1, $t1, 2
                              ori $t0,$t0,1
1h $2,0($0)
                                                           ori $a0, $0, 0
                              ori $t1,$t1,2
1h $2, 2($0)
                                                           bgez $a0, bgez labell
                              ori $a0,$0,0
1hu $2,0($0)
                                                           ori $t2, $t2, 2
1hu $2, 2($0)
                              blez $a0, blez labell
                                                           ori $t3, $t3, 3
                              ori $t2, $t2, 2
1b $2,0($0)
                                                           bgez labell:ori $t4, $t4, 4
                              ori $t3, $t3, 3
1b $2, 1($0)
                              blez_labell:ori $t4,$t4,4 | bgez $al,bgez_label2
1b $2, 2($0)
                                                           ori $t5, $t5, 5
                              blez $a2, bgez_label2
1b $2, 3($0)
                                                           ori $t6, $t6, 6
1bu $2,0($0)
                              ori $t5, $t5, 5
                                                           bgez_label2:ori $t7, $t7, 7
                              ori $t6, $t6, 6
1bu $2, 1($0)
                              blez_label2:ori $t7,$t7,7 | bltz $al,bgez_label3
1bu $2, 2($0)
```

```
ori $t0, $t0, 1
ori $t1, $t1, 2
bltz $a0, bgez_label3
ori $t2, $t2, 2
ori $t3, $t3, 3
bltz $a2, bgez_label3
ori $t5, $t5, 5
ori $t6, $t6, 6
bgez_1abe13:ori $t4,$t4,4
ori $t0,$0,8
sw $t1, -8($t0)
sw $t2,0($t0)
sw $t3,8($t0)
1w $t4, -8($t0)
1w $t5,0($t0)
1w $t6,8($t0)
```

#### 异常测试:

```
li $28, 0
                                   sub $5, $0, $5
                             47
     li $29, 0
                                   andi $4, $3, 0x25c4
     mtc0 $0, $13
                                   addi $1, $3, 0x4ffb
     mtc0 $0, $14
                              50
                                   mflo $2
     li $0, 0x45762dbc
                                   mtc0 $5, $14
                             51
     li $1, 0x1402ca0f
                                   lw $1, 1($0)
                             52
     li $2, 0x203c737d
                                   sub $5, $5, $5
     li $3, 0x25df6e42
                                   sltu $1, $2, $4
                             54
     li $4, 0x7d998177
                                   or $4, $2, $2
10
     li $5, 0x1c55e393
                                   addi $2, $2, 0x48da
                              56
11
     sub $5, $1, $3
                                   addi $0, $5, 0x76a3
                             57
     sub $2, $5, $2
12
                             58
                                   xori $2, $0, 0xb0c
13
     andi $1, $2, 0x47c0
                                   mtlo $3
     lh $3, 8($0)
14
                             60
                                   add $2, $2, $0
15
     sltiu $4, $1, 0x6fb6
                                   srav $0, $2, $0
16
     mtc0 $3, $14
                                   xor $1, $5, $1
                             62
     mtc0 $0, $14
17
                                   slt $4, $3, $2
                             63
18
     and $5, $4, $4
                                   mfc0 $3, $13
                             64
19
     divu $4, $0
                                   mflo $3
                             65
     mthi $5
20
                             66
                                   addi $5, $2, 0x4540
     nor $0, $2, $0
21
                                   lui $0, 0x4c44
                             67
     sw $4, 22($0)
22
                                   multu $4, $0
                             68
23
     mfc0 $2, $13
                                   mtc0 $2, $14
     sub $2, $5, $3
24
                                   srlv $5, $0, $4
                             70
     addu $0, $1, $3
                                   sub $0, $1, $3
                             71
     add $2, $2, $3
26
                                   sub $0, $3, $3
     li $5, 0xdc874dc4
27
                                   sltu $0, $0, $1
     sub $4, $5, $3
28
                              74
                                   mflo $3
29
     nor $3, $3, $5
                              75
                                   mfc0 $2, $14
     mfc0 $1, $13
30
                                   or $1, $2, $4
                              76
     slti $3, $5, 0x5393
                              77
                                   add $1, $3, $0
     xori $3, $1, 0x94b
32
                              78
                                   sub $5, $4, $1
     addi $4, $0, 0x1a02
                              79
                                   addi $2, $3, 0x34e6
     addiu $5, $2, 0x70a
34
                             80
                                   xor $4, $2, $5
     multu $0, $0
35
                                   ori $3, $4, 0x6f34
                             81
36
     lw $3, 34($0)
                                   mfc0 $2, $13
                             82
     slti $1, $3, 0x12d3
37
                                   and $3, $1, $1
     nor $4, $5, $2
38
                                   or $5, $0, $2
                             84
     addi $5, $4, 0x5b64
                                   mfc0 $1, $13
     mtc0 $5, $14
40
                                   and $5, $2, $3
                             86
     lb $4, 27($0)
41
                                   lw $1, 3($0)
                             87
42
     add $2, $2, $1
                             88
                                   lui $2, 0x8eb
43
     divu $3, $1
                                   subu $0, $4, $0
44
     multu $1, $5
                                   sub $1, $3, $0
                             90
45
     addi $1, $5, 0x5d5d
                              91
                                   mflo $4
     addi $3, $2, 0x2b9d
46
```

```
137
                                  auu ρ∠, ρ4, ρ
      sub $2, $2, $1
92
                                  add $1, $3, $2
                            138
93
      mthi $4
                                  addi $2, $4, 0x3fa6
                            139
      mfc0 $1, $14
                                  sub $0, $1, $5
                            140
      add $4, $4, $3
                            141
                                  mfhi $4
      nor $0, $4, $4
96
                            142
                                  div $1, $4
97
      mtc0 $3, $13
                                  slti $4, $4, 0x7bfb
                            143
98
      add $3, $3, $0
                            144
                                  sub $0, $0, $3
      multu $1, $1
99
                                  li $2, 0x8eb3782a
                            145
      nor $3, $5, $4
100
                            146
                                  addi $4, $0, 0x6b37
      addi $1, $5, 0x38e5
101
                            147
                                  subu $5, $1, $1
      mthi $3
102
                                  addu $1, $1, $2
                            148
103
      addi $0, $1, 0x46a
                                  li $0, 0xef7fcf4f
                            149
      addi $3, $4, 0x372f
104
                            150
                                  mtc0 $1, $13
      addi $1, $1, 0x5d91
105
                                  addi $2, $4, 0x1bf0
                            151
      addi $5, $1, 0x9c4
106
                                  addi $4, $4, 0xd2a
                            152
      addi $4, $2, 0x78a1
107
                            153
                                  add $1, $0, $4
      addi $0, $4, 0x168a
108
                            154
                                  sub $1, $2, $0
      add $1, $0, $2
109
                            155
                                  mtc0 $3, $13
110
      sltu $1, $4, $0
                            156
                                  add $2, $4, $0
111
      lh $3, 44($0)
                                  sltiu $1, $3, 0x2efb
112
      mfhi $5
                            158
                                  sub $1, $5, $2
113
      mtc0 $1, $14
                                  add $5, $3, $3
                            159
114
      slt $1, $1, $5
                            160
                                  li $3, 0xab904171
115
      mtc0 $2, $13
                                  addi $5, $2, 0x5d55
      subu $4, $1, $0
116
                            162
                                  slt $3, $2, $1
      add $2, $4, $2
117
                            163
                                  sub $5, $2, $0
      mflo $4
118
                                  xor $1, $5, $1
                            164
      lh $2, 23($0)
119
                            165
                                  nor $1, $4, $4
120
      div $1, $4
                            166
                                  mfc0 $1, $13
      lhu $0, 51($0)
121
                                  lui $0, 0x35fa
                            167
      or $1, $2, $4
122
                            168
                                  addi $1, $2, 0x1731
      sub $1, $3, $4
123
                                  divu $3, $3
      slt $5, $2, $4
124
                                  sw $4, 48($0)
                            170
125
      lui $1, 0x317c
                                  lbu $3, 18($0)
                            171
      and $0, $5, $3
126
                            172
                                  sltu $2, $1, $5
      and $4, $5, $4
127
                                  sb $5, 20($0)
                            173
      and $3, $0, $1
128
                            174
                                  mthi $0
      addi $3, $1, 0x4c72
129
                            175
                                  sw $3, 22($0)
130
      sub $4, $0, $4
                                  sltiu $4, $5, 0x3755
                            176
      mflo $4
131
                            177
                                  addiu $4, $4, 0x2c82
132
      or $3, $0, $1
                            178
                                  sub $2, $3, $5
      nor $0, $0, $3
133
                                  add $0, $4, $3
                            179
134
      andi $3, $2, 0x148
                            180
                                  sub $1, $4, $5
135
      sub $5, $2, $2
                            181
                                  lhu $4, 11($0)
      subu $3, $2, $4
136
                            182
                                  add $1, $2, $0
      add $2, $4, $3
137
```

```
183
      sltiu $2, $3, 0x56d2
                                       ՏԱՄ ՔՄ, Ք4,
                                 229
                                       add $4, $4, $0
      xor $2, $0, $4
184
                                 230
                                       mtc0 $3, $14
      add $0, $0, $4
185
                                 231
                                       sub $4, $4, $2
      lb $1, 36($0)
186
                                       sub $0, $0, $0
                                 232
      mtc0 $5, $14
187
                                 233
                                       sub $3, $3, $0
      lhu $4, 0($0)
188
                                 234
                                       add $0, $0, $5
      lhu $4, 51($0)
189
                                       lhu $2, 41($0)
                                 235
      sw $4, 12($0)
190
                                 236
                                       sh $2, 12($0)
      sh $1, 13($0)
191
                                       sub $5, $2, $3
                                 237
      sb $4, 46($0)
192
                                       ori $3, $5, 0x721f
                                 238
      addi $0, $3, 0x2615
                                 239
                                       nor $2, $0, $4
      addi $3, $0, 0x2f38
194
                                 240
                                       addi $0, $1, 0x2e54
195
      nor $3, $0, $0
                                 241
                                       subu $4, $3, $0
      sw $1, 8($0)
196
                                 242
                                       addi $0, $1, 0x7c05
      lhu $0, 51($0)
197
                                 243
                                       1h $0, 25($0)
198
      addiu $4, $4, 0xe58
                                 244
                                       xori $2, $5, 0x2235
      mtlo $1
199
                                 245
                                       addi $2, $4, 0x2006
      addi $2, $3, 0x14d6
200
                                 246
                                       mflo $3
      xor $5, $2, $4
201
                                 247
                                       addi $0, $4, 0x6bc5
      sub $5, $2, $2
202
                                 248
                                       sub $0, $1, $4
      mfc0 $0, $13
203
                                 249
                                       sub $2, $4, $2
      1h $0, 28($0)
204
                                 250
                                       srav $3, $3, $0
      andi $3, $2, 0x3a10
205
                                 251
                                       sub $4, $0, $3
      addiu $3, $3, 0x6447
206
                                 252
                                       nor $5, $5, $2
      addi $2, $2, 0x6efc
207
                                 253
                                       sw $5, 14($0)
      mflo $4
208
                                 254
                                       andi $3, $3, 0x4240
209
      addi $4, $0, 0x332f
                                 255
                                       mthi $1
210
      slt $1, $0, $3
                                 256
                                       sub $1, $3, $4
      mult $5, $0
211
                                 257
                                       or $5, $1, $0
212
      srlv $5, $1, $0
                                 258
                                       mfhi $2
      addiu $1, $3, 0x108a
213
                                 259
      addi $1, $1, 0x21a8
                                       sub $1, $4, $4
214
                                 260
                                       multu $2, $5
      sltiu $5, $2, 0x12af
215
                                       addi $2, $4, 0xcd7
                                 261
      slt $1, $0, $1
216
                                       slti $1, $0, 0x711c
      subu $1, $0, $1
                                 262
217
                                 263
                                       1hu $3, 35($0)
      sb $4, 45($0)
218
                                       xori $1, $0, 0x2ad9
                                 264
      sub $3, $0, $1
219
                                       mult $1, $4
                                 265
220
      mtlo $0
                                 266
                                       or $2, $3, $5
      add $4, $1, $0
221
                                 267
                                       mflo $5
222
      sb $4, 10($0)
                                       li $4, 0x7b81228b
223
      add $2, $4, $3
                                 269
                                       addu $0, $0, $5
      sub $2, $2, $3
224
                                       sub $0, $2, $1
                                 270
225
      add $2, $3, $3
                                 271
                                       add $1, $0, $1
      addi $1, $2, 0xc9a
226
                                       sub $4, $2, $4
                                 272
      addi $5, $1, 0x4de1
227
                                       nor $1, $4, $0
                                 273
     sub $0, $4, $2
228
```

```
ושק)ר ,רק מטד
      lw $1, 9($0)
274
                                     sltiu $4, $0, 0x722d
                               320
      mfhi $1
                               321
                                     lhu $0, 25($0)
      addi $2, $1, 0x2b41
276
                                     addi $4, $2, 0x4bdf
                               322
      addiu $4, $5, 0x3aad
277
                                     addi $1, $1, 0x77bb
                               323
      addi $4, $1, 0x73e4
278
                               324
                                     add $4, $5, $0
279
      lh $2, 42($0)
                               325
                                     lui $5, 0x1f7f
      sltu $0, $0, $2
                                     lui $0, 0x59b1
                               326
281
      sub $3, $1, $2
                                     mthi $0
                               327
282
      addi $3, $1, 0x66c6
                               328
                                     slti $0, $5, 0x20ce
      li $2, 0x607b981a
                                     1bu $0, 0($0)
                               329
284
      mtc0 $3, $14
                               330
                                     mfc0 $0, $14
      addiu $3, $4, 0x2a02
                               331
                                     addi $2, $1, 0x10d8
286
      mtlo $1
                                     addi $0, $0, 0x3e87
                               332
      sltiu $4, $1, 0x2238
287
                                     mtc0 $2, $13
288
      add $1, $3, $3
                               334
                                     sltiu $1, $2, 0x3a84
      addi $0, $1, 0x5141
289
                                     addi $1, $1, 0x206c
                               335
      sltiu $3, $2, 0xfd0
290
                                     slti $3, $4, 0x5108
                               336
291
      addu $3, $3, $2
                                     addi $1, $4, 0x694e
                               337
      add $1, $4, $3
292
                                     sub $5, $0, $5
                               338
      sub $1, $5, $4
293
                               339
                                     sub $1, $1, $2
      mfc0 $3, $13
294
                               340
                                     slti $1, $2, 0x5353
      addi $5, $5, 0x7f52
295
                                     sub $5, $2, $4
                               341
      slti $5, $1, 0x3c8d
296
                               342
                                     add $0, $5, $3
      addi $1, $4, 0x4848
297
                                     sltu $1, $0, $2
                               343
      mfc0 $4, $14
298
                                     lhu $1, 22($0)
                               344
299
      sub $5, $2, $2
                               345
                                     mfhi $4
      add $2, $1, $1
300
                                     mfc0 $3, $14
                               346
      mflo $0
301
                               347
                                     sub $3, $0, $2
302
      addiu $3, $4, 0x4584
                                     addi $4, $1, 0x4211
                               348
303
      sw $5, 30($0)
                               349
                                     sub $4, $2, $4
      xor $4, $0, $5
304
                                     or $1, $1, $0
                               350
305
      subu $1, $0, $4
                                     sltiu $0, $4, 0x7968
      sub $3, $2, $0
306
                                     sb $3, 39($0)
                               352
307
      add $4, $1, $3
                               353
                                     sub $0, $2, $3
      mfc0 $4, $14
308
                                     addi $3, $3, 0xa69
                               354
309
      lhu $3, 35($0)
                               355
                                     addiu $2, $1, 0x5635
310
      mtc0 $2, $14
                                     lui $4, 0x63ac
                               356
      sb $4, 9($0)
311
                               357
                                     addi $3, $5, 0x7e2d
      lh $1, 0($0)
312
                                     mfc0 $5, $14
                               358
      addi $3, $2, 0x2f4f
313
                                     div $5, $5
                               359
      srlv $2, $0, $2
314
                                     add $2, $5, $3
                               360
315
      addi $0, $3, 0x6a22
                                     lhu $5, 37($0)
                               361
      div $5, $4
316
                                     add $1, $3, $4
                               362
      andi $5, $5, 0x5c4d
317
                               363
                                     slt $3, $1, $2
318
      add $4, $0, $4
                               364
                                     add $2, $3, $2
      1bu $3. 5($0)
319
```

```
auu ρι, ρ4, σ
      add $3, $3, $2
365
                              411
                                    sub $3, $4, $0
      add $3, $0, $0
366
                                    lui $4, 0x24b5
                              412
      mfc0 $5, $13
367
                                    lbu $1, 33($0)
                              413
368
      mfhi $5
                                    add $0, $1, $0
                              414
      srlv $2, $2, $5
369
                                    add $0, $1, $4
                              415
370
      mtlo $2
                                    add $4, $5, $1
                              416
371
      sltu $4, $0, $5
                                    nor $2, $5, $5
                              417
      add $0, $4, $4
372
                                    srlv $2, $1, $3
                              418
373
      mtc0 $3, $13
                                    subu $1, $1, $0
                              419
374
      mtc0 $0, $13
                              420
                                    nor $5, $2, $2
375
      addi $2, $1, 0x4ceb
                                    sltu $3, $4, $3
                              421
      slti $4, $4, 0x11ac
376
                              422
                                    mtc0 $3, $13
377
      mfc0 $4, $14
                              423
                                    slt $2, $0, $4
378
      div $3, $3
                                    addi $3, $4, 0x3a34
                              424
379
      lw $2, 39($0)
                                    xor $3, $5, $3
                              425
      lb $3, 10($0)
380
                                    lhu $2, 49($0)
                              426
381
      addi $4, $4, 0x63b2
                                    add $3, $2, $3
                              427
382
      andi $5, $2, 0x16a
                              428
                                    addu $2, $0, $2
383
      add $3, $0, $3
                              429
                                    mfc0 $0, $14
384
      sltiu $5, $3, 0x4b45
                              430
                                    add $0, $3, $5
385
      sub $1, $3, $3
                              431
                                    andi $4, $3, 0x7451
386
      andi $3, $2, 0x1624
                                    lui $0, 0x78d3
                              432
387
      ori $0, $0, 0x5729
                                    sub $1, $0, $3
                              433
388
      ori $4, $1, 0x1c01
                              434
                                    addi $0, $5, 0x48d9
389
      add $5, $2, $0
                                    andi $2, $1, 0x6c88
                              435
      add $0, $5, $3
390
                              436
                                    addi $3, $1, 0x2d4d
      sub $0, $5, $5
391
                                    li $1, 0x90b0c80e
                              437
392
      subu $4, $4, $3
                              438
                                    lbu $1, 39($0)
      ori $5, $3, 0x6c18
393
                              439
                                    sub $0, $1, $1
394
      addu $5, $1, $3
                                    mfc0 $2, $14
                              440
395
      lbu $2, 4($0)
                              441
                                    addi $4, $0, 0xf09
      sltiu $1, $1, 0x4bd3
396
                              442
                                    multu $5, $5
397
      mthi $2
                                    mtc0 $3, $14
                              443
      mfc0 $5, $14
398
                              444
                                    mtc0 $3, $13
      and $3, $0, $2
399
                                    sub $2, $0, $0
                              445
400
      addi $3, $5, 0x258e
                              446
                                    or $2, $2, $3
401
      lh $3, 9($0)
                              447
                                    subu $3, $1, $1
      divu $0, $4
402
                                    1bu $4, 47($0)
                              448
403
      srav $3, $1, $3
                              449
                                    mtc0 $1, $14
404
      lb $4, 32($0)
                              450
                                    mthi $2
405
      sub $1, $2, $2
                              451
                                    srav $2, $2, $4
406
      add $1, $4, $0
                              452
                                    sub $3, $4, $4
407
      andi $4, $4, 0x6943
                                    mfc0 $5, $14
408
      1hu $3, 8($0)
                              454
                                    lw $1, 36($0)
409
      add $4, $4, $5
                                    sub $4, $4, $3
410
      add $1, $4, $5
```

```
אם , בם , כם Suu
456
      add $2, $5, $5
                                  502
                                        sw $1, 12($0)
      add $4, $1, $1
457
                                        xori $2, $4, 0x14c2
                                  503
      sub $4, $5, $2
458
                                  504
                                        srlv $1, $3, $3
      divu $3, $0
                                        sub $3, $1, $1
      add $1, $4, $3
460
                                        add $5, $1, $2
                                  506
      sb $3, 46($0)
461
                                        lw $2, 28($0)
                                  507
      addi $3, $0, 0x50a1
462
                                  508
                                        mtc0 $3, $13
      sllv $0, $0, $0
463
                                        add $4, $5, $0
      xor $1, $1, $4
464
                                        lb $0, 17($0)
                                  510
      sw $4, 35($0)
465
                                        addi $5, $5, 0x1a05
                                  511
466
      lbu $2, 3($0)
                                  512
                                        sub $5, $0, $2
      sub $2, $4, $2
467
                                        lw $4, 22($0)
                                  513
      xori $3, $5, 0x603a
468
                                        sub $0, $5, $2
                                  514
469
      nor $3, $5, $3
                                        addi $0, $4, 0x7384
                                  515
      div $5, $2
470
                                        add $0, $0, $5
                                  516
471
      or $0, $2, $3
                                  517
                                        and $4, $0, $5
      srav $5, $5, $4
472
                                        mtc0 $4, $14
                                  518
473
      lh $1, 46($0)
                                        nor $3, $1, $5
                                  519
474
      mtc0 $5, $13
                                        add $1, $5, $5
                                  520
475
      mtlo $0
                                        sb $1, 51($0)
                                  521
476
      nor $0, $3, $4
                                        add $0, $1, $3
                                  522
      sltiu $1, $5, 0x1557
477
                                        sub $0, $4, $1
                                  523
478
      mfhi $1
                                        add $5, $4, $4
                                  524
479
      nor $5, $1, $3
                                  525
                                        mtc0 $0, $14
      addi $0, $1, 0x6d93
480
                                  526
                                        addi $0, $3, 0x7be8
481
      div $5, $0
                                        addi $4, $2, 0xe05
                                  527
      lui $3, 0x2224
482
                                  528
                                        xor $2, $3, $5
      multu $2, $0
483
                                  529
                                        divu $5, $5
484
      add $3, $1, $3
                                        sltiu $3, $5, 0x7491
                                  530
485
      mfc0 $4, $13
                                        1b $0, 8($0)
                                  531
      sub $0, $4, $4
486
                                        add $2, $4, $2
                                  532
      ori $0, $1, 0x475c
487
                                        add $4, $4, $4
                                  533
      sub $1, $1, $2
488
                                        addi $0, $4, 0xcb6
                                  534
      sub $2, $5, $2
489
                                  535
                                        li $5, 0x44eeba22
490
      addu $3, $1, $2
                                        add $3, $4, $4
                                  536
      add $1, $4, $1
491
                                        addi $2, $4, 0x738c
                                  537
      nor $5, $0, $3
492
                                  538
                                        addi $4, $2, 0x6afd
493
      mfc0 $3, $13
                                        add $5, $4, $5
494
      sub $1, $1, $1
                                        multu $4, $1
                                  540
      or $0, $3, $1
                                  541
                                        add $5, $1, $3
496
      add $4, $0, $4
                                        mtc0 $4, $13
                                  542
497
      addi $2, $0, 0x697a
                                        addi $1, $4, 0x3f30
                                  543
      addi $1, $1, 0x1d37
498
                                        mthi $1
                                  544
499
      sh $1, 30($0)
                                  545
                                        mtlo $3
500
      li $2, 0xd4cd0200
                                        mult $4, $3
                                  546
      sub $3, $1, $4
501
```

```
שנונאט ,44 ,נק auuı
544
      mthi $1
      mtlo $3
545
      mult $4, $3
546
      addi $5, $0, 0x3ded
547
      add $2, $1, $1
548
549
      add $1, $1, $1
      mfc0 $0, $14
550
      mult $2, $4
      lhu $5, 38($0)
552
      lb $4, 2($0)
553
      xori $0, $4, 0x7152
554
      mfc0 $3, $13
      mtc0 $0, $14
556
      xori $1, $4, 0x68e
557
558
      mtc0 $3, $14
      sllv $5, $5, $2
559
      srav $4, $1, $5
560
561
      subu $1, $0, $2
      sw $0, 34($0)
562
      sltiu $1, $0, 0x5c40
563
      mfhi $4
564
565
      sub $1, $4, $4
      sllv $4, $4, $1
566
567
      sub $3, $2, $5
568
      lbu $4, 49($0)
      add $4, $0, $1
569
      nor $0, $0, $2
570
571
      addiu $5, $4, 0x4f5e
      lbu $3, 24($0)
572
     lhu $0, 33($0)
573
574
      addu $5, $4, $0
      lb $1, 46($0)
575
      lhu $4, 26($0)
576
      sub $0, $2, $0
577
      sltiu $1, $5, 0x809
578
579
      add $3, $3, $5
      mtc0 $5, $13
580
      srav $1, $1, $5
581
582
      lw $1, 18($0)
      lhu $1, 30($0)
583
      slti $1, $2, 0x3404
584
      sh $2, 19($0)
586
      xori $1, $0, 0x1411
      addi $4, $3, 0x127
587
588
      sub $0, $0, $1
```

#### (二) 结论

期望输出与实际输出相同。

#### 二、思考题

(一) 我们计组课程一本参考书目标题中有"硬件/软件接口"接口字样,那么到底什么是"硬件/软件接口"?

硬件/软件接口:在接口一端是中断处理程序和用于不同设备的设备驱动程序,另一端 是各种硬件设备的控制器,如键盘控制器、打印机控制器。由于设备种类繁多,故该接 口相当复杂。

(二) 在我们设计的流水线中, DM 处于 CPU 内部, 请你考虑现代计算机中它的位置应该在何处。

计算机中的存储器按用途存储器可分为主存储器(内存)和辅助存储器(外存)。外存通常是磁性介质或光盘等,能长期保存信息,容量巨大。内存(即主存)指主板上的存储部件,用来存放当前正在执行的数据和程序,容量大、速度较慢。

无论是 IM 指令存储器还是 DM 数据存储器,以及所有设备,都应该位于 CPU 外部,因为 DM 相当于现代计算机中的外存,现代计算机通过总线来传输所有的数据和信号,达到沟通的目的。

(三) BE 部件对所有的外设都是必要的吗?

并不是对所有外设都需要。比如本实验用的两个 timer 只需要支持 sw, 而不需要 sb、 sh, 而对于需要支持按半字和字节写入的外设, 比如 dm 来说, BE 是必须的。BE 是 否使用, 取决于外设的需求。

(四) 请开发一个主程序以及定时器的 exception handler。整个系统完成如下功能。

定时器在主程序中被初始化为模式

定时器倒计数至 0 产生中断

handler 设置使能 Enable 为 1 从而再次启动定时器的计数。 2 及 3 被无限重复。设定初值寄存器的为某个值,如 1000或 1000。(注意,主程序可能需要涉及对 CPO.SR 的编程,推荐

#### 阅读过后文再进行。

```
ori $t4, $0, 64513
mtc0 $t4, $12
ori $t1, $0, 0
ori $t1, $t1, 0x7f00
ori $t2, $0, 0
ori $t2, $t2, 1000#preset
sw $t2, 4($t1) #preset存入相关寄存器
ori $t2, $0, 0
ori $t2, $t2, 9
sw $t2, ($t1)#启动倒数
ori $t3, $0, 1
ori $t3, $0, 2
ori $t3, $0, 3
ori $t3, $0, 4
ori $t3, $0, 5
ori $t3, $0, 6
ori $t3, $0, 7
ori $t3, $0, 8
ori $t3, $0, 9
ori $t3, $0, 10
ori $t3, $0, 1
ori $t3, $0, 2
ori $t3, $0, 3
ori $t3, $0, 4
ori $t3, $0, 5
ori $t3, $0, 6
ori $t3, $0, 7
ori $t3, $0, 8
ori $t3, $0, 9
```

#### (五) 请查阅相关资料,说明鼠标和键盘的输入信号是如何被

#### CPU 知晓的?

ori \$t3, \$0, 10

键盘、鼠标这类的低速设备是通过中断请求的方式进行 IO 操作的。即当键盘上按下一个按键的时候,键盘会发出一个中断信号,中断信号经过中断控制器传到 CPU, 然后 CPU 根据不同的中断号执行不同的中断响应程序, 然后进行相应的 IO 操作, 把按下的按键编码读到寄存器(或者鼠标的操作),最后放入内存中。