# **Computer Organization Lab2**

Name:郭昀 ID:109550018

#### **Architecture diagrams:**



Top module: Simple\_Single\_CPU

#### Hardware module analysis:

主要都是按照 Spec 裡面的 diagram 來設計我的 Simple\_Single\_CPU, 例如:

- PC 透過左上的 adder 每次加 4, 而下一次的 PC 會在右上的 MUX 中由 ALU zero 決定是加 4 的那一個, 還是右上的 adder 算出來的 branch target。
- Register File根據 Instruction memory 傳來的是 R-format 還是 I-format 決定要 從哪裡讀值。
- Decoder 是用來判斷 instruction 所需對應的 RegDst, RegWrite, branch,
  ALUOp, ALUSrc 的值。
- 如果 instruction 是 I-format, 就需要 Sign extender 把 16 bit 轉成 32 bit。
- ALU control 會決定 ALU 要做什麼運算。

#### Finsished part:





## Problems you met and solutions:

我一開始在沒有注意到在 ALU.v 裡面, zero 的輸出的名字是 zero\_o 而我打成 zero, 導致我的 beq 指令都是錯的, 後來 debug 許久後才找到這個錯誤。

### **Summary:**

做完這次的 Simple Single CPU, 讓我對 MIPS 的 Insturction 有更深的了解, 更清楚他是如何處理這些指令, 以及這些指令相對應的輸出。