# **Computer Organization Lab 1**

0113110 Po-Han Chen, 0316213 Yu-Wen Pwu

### **Architecture Diagram**



Top module: Simple\_Single\_CPU

# **Detailed Description of the Implementation**

- ALU Operations
  - 0: src1\_i & src2\_i
  - o 1: src1\_i | src2\_i
  - o 2: src1\_i + src2\_i
  - 6: src1\_i src2\_i
  - o 7: src1\_i < src2\_i</p>
  - o 12: ~(src1\_i | src2\_i)
  - 14: src2\_i\_signed >>> src1\_i\_signed
  - o 15: src2\_i << 16

- ALU Control (input [5:0] funct\_i)
   Case (funct\_i)
  - o 3: ALUCtrl o = 14; // SRA
  - o 7: ALUCtrl\_o = 14; // SRAV
  - o 32: ALUCtrl o = 2; // ADD
  - o 34: ALUCtrl o = 6; // SUB
  - o 36: ALUCtrl\_o = 0; // AND
  - o 37: ALUCtrl o = 1; // OR
  - o 42: ALUCtrl o = 7; // SLT
- Decoder Output Signals (input [4:0] instr\_op\_i;)
  - RegWrite = 1, if instr\_op\_i ∈ {0, 35, 8, 9, 15, 13}
     R-type, Load, ADDI, SLTIU, LUI, ORI
     -> nead to write result to some register
  - O ALU\_op =

- ALUSrc = 1, if instr\_op\_i ∈ {35, 43, 8, 9, 15, 13}
   Load, Store, ADDI, SLTIU, LUI, ORI
   -> multiplexer selects [15:0] as the second ALU source
- RegDst = 1, if instr\_op\_i == 0
   R-type
   -> multiplexer selects [15:11] as the register to write to
- Branch = 1, if instr\_op\_i  $\in$  {4, 5} BEQ, BNE
- Simple\_Single\_CPU
  - keep\_sign (KeepSign) = 1, if inst[31:26] ∈ {9, 13}
     Keep sign (Zero-extend) if op is SLTIU, ORI
  - Assign shamt ([10:6]) as the first ALU source if op is SRA

```
TakeBranch =BEQ -> ZeroBNE -> !Zero
```

#### **Problems Encountered and Solutions**

- Errors related to timing (eg. results come after 1 clock cycle later)
  Solution: Change all nonblocking assignments to blocking assignments.
- General debugging difficulties
   Debugging is a pain throughout the implementation.

   Solution: Declare an always block and use \$display to see the contents in the variables during simulation (evaluation).

```
always @(*) begin

$display("%b", inst);

// $display("addr_nxt1 = %d, addr_nxt2 = %d, addr = %d, addr_nxt = %d", addr_nxt1,
addr_nxt2, addr, addr_nxt);

$display("%b", RegWrite);

// $display("%b %b", RegRead1, reg_read1);

$display("%d %d => %d ", reg_data1, reg_data2, res_alu);

end
```

## **Lesson Learned (If Any)**

- Debugging is surprisingly difficult with so many modules in 1 place.
   Next time it's probably wise to test individual components first, but even that would be kind of troublesome.
- Read the samples first to make sure that I truly understand the MIPS operations.