## **Computer Organization**

Hardware module analysis(簡短解釋一下每個 module 的功能,以及在 CPU 裡扮演的角色):

| <b>Program Counter</b> | gram Counter 存放下個待執行指令的位址      |  |  |
|------------------------|--------------------------------|--|--|
| Adder                  | 32-bi 加法,用在 address 的計算        |  |  |
| Instr_Memory           | input 來自 PC,讀取 instruction 並輸出 |  |  |
| MUX                    | 選擇輸出,一在選rt,一在選ALU_Src          |  |  |
| SE                     | Extend 16-bit to 32-bit        |  |  |
| Shift left             | 將輸入左移 2bit (還原位址)              |  |  |

| Decoder      | ALU_op | ALU_Src | RegWrite | RegDst | Branch |
|--------------|--------|---------|----------|--------|--------|
| 根據輸入的 Opcode |        |         |          |        |        |
| 輸出對應 control |        |         |          |        |        |
| R-type(op=0) | 010    | 0       | 1        | 1      | 0      |
| addi (op=8)  | 000    | 1       | 1        | 0      | 0      |
| slti (op=10) | 110    | 1       | 1        | 0      | 0      |
| beq (op=4)   | 001    | 0       | 0        | 0      | 1      |

|      |    |          |        | ALU_ctrl         | ALU                |
|------|----|----------|--------|------------------|--------------------|
|      |    |          |        | 接收 instruction 的 | 根據 ALU             |
|      | Op | Function | ALU_op | function code 及  | Control 對兩個輸       |
|      |    |          |        | Decoder 送出的      | 入值做                |
|      |    |          |        | ALUOp,輸出控制       | add,sub,and,or,slt |
|      |    |          |        | 信號給 ALU          | 等基本運算              |
| add  |    | 32(0x20) |        | 0010             | add                |
| sub  |    | 34(0x22) |        | 0110             | sub                |
| and  | 0  | 36(0x24) | 010    | 0000             | and                |
| or   |    | 37(0x25) |        | 0001             | or                 |
| slt  |    | 42(0x2a) |        | 0111             | slt                |
| addi | 8  |          | 000    | 0010             | add                |
| slti | 10 | 0        | 110    | 0111             | slt                |
| beq  | 4  |          | 001    | 0110             | sub                |

## Problems you met and solutions:

1.

Decoder 送出的 ALU\_op 有三 bits 和課本不一樣,所以本來 addi 跟 slti 的 ALU\_op 設錯。不過 ALU\_op 也對應正確的 ALU\_control 所以好像沒差。 2.

沒注意到要在 Simple\_CPU 輸入訊號, 然後 simulation 按成 implementation

## Summary:

經過這次的作業才比較清楚 top module 在幹嘛,而在裡面宣告 internal signal 可以連接不同 module。另外也再複習一遍 MIPS 指令的各種控制訊號值