Student ID: R08922167

Name: 曾民君

\_\_\_\_\_

Environment: Ubuntu 16.04

1. CPU.v: wires named as

## Data Path



- 2. Adder.v: pc = instAddr + four
- Control.v: use opCode[5] to decide aluSrc ans aluOp, let both regDst and regWrite are 1
- 4. ALU\_Control.v: set aluCtrl based on funct as

```
case(funct_i)
10'b0000000111: ALUCtrl_o = 3'b000;
10'b0000000110: ALUCtrl_o = 3'b001;
10'b0000000000: ALUCtrl_o = 3'b010;
10'b0100000000: ALUCtrl_o = 3'b110;
10'b0000001000: ALUCtrl_o = 3'b011;
endcase
```

but if aluOp is 01 then set aluCtrl to 3'b010

- 5. Sign\_Extend.v: concat 20 immData[11] letf to immData[11:0]
- 6. ALU.v: set aluResult = rsData {+, -, \*, &, |} mux32\_o
- 7. MUX32.v: mux32\_o = if aluSrc ==0: rtData? immExtented
- 8. MUX5.v: design logic is same as MUX32, but it doesn't play a role in this homework