# **Computer Organization, Spring 2021**

# **Lab 3: Single Cycle CPU- Simple Edition**

Due: 2021/5/14

#### 1. Goal

Utilizing the ALU in Lab2 to implement a simple single cycle CPU. CPU is the most important unit in computer system. Reading the document carefully and do the Lab, you will have elementary knowledge of CPU.

#### 2. Demands

- A. Please use iverilog environment.
- B. "Simple\_Single\_CPU.v", "Adder.v", "ALU.v", "ALU\_Ctrl.v", "Decoder.v", "Instr\_Memory.v", "Mux2to1.v", "Mux3to1.v", "Program\_Counter.v", "Reg\_File.v", "Shifter.v", "Sign\_Extend.v", "Zero\_Filled.v", and "TestBench.v" are supplied. Please use these modules to accomplish the design of your CPU and don't change the file name.

Instruction set: the following instructions have to running in your designed CPU (80pts.)

| Instruction | Example       | Meaning                                                                       | Op field  | Shamt | <b>Function field</b> |
|-------------|---------------|-------------------------------------------------------------------------------|-----------|-------|-----------------------|
| ADD         | add r1,r2,r3  | r1=r2+r3                                                                      | 6'b000000 | X     | 6'b010011             |
| SUB         | sub r1,r2,r3  | r1=r2-r3                                                                      | 6'b000000 | X     | 6'b010001             |
| AND         | and r1,r2,r3  | r1=r2&r3                                                                      | 6'b000000 | X     | 6'b010100             |
| OR          | or r1,r2,r3   | r1=r2 r3                                                                      | 6'b000000 | X     | 6'b010110             |
| NOR         | nor r1,r2,r3  | $r1 = \sim (r2 r3)$                                                           | 6'b000000 | X     | 6'b010101             |
| SLT         | slt r1,r2,r3  | if(r2 <r3) r1="1&lt;/th"><th>6'b000000</th><th>X</th><th>6'b110000</th></r3)> | 6'b000000 | X     | 6'b110000             |
|             |               | else r1=0                                                                     |           |       |                       |
| SLL         | sll rd,rt,5   | rd=rt<<5                                                                      | 6'b000000 | 5     | 6'b000000             |
| SRL         | srl rd,rt,5   | rd=rt>>5                                                                      | 6'b000000 | 5     | 6'b000010             |
| ADDI        | addi r1,r2,10 | r1=r2+10                                                                      | 6'b001000 | X     | X                     |

#### Shifter

The block diagram of the shifter to be implemented is shown:



Shift.v contains the following inputs and outputs:

- sftSrc: A 32-bit input data, is the source data of the shifter.
- leftRight: A 1-bit input control signal. When it is set to 1, the shifter perform logical left shift; else, does logical right shift.
- shamt: A 5-bit input data, represents the number of bit positions to be shifted.
- result: A 32-bit output data, which represents the shifting result of the shifter.

## SRL Rd, Rt, shamt (Rs is ignored for SRL)

Shift register Rt right by the distance indicated by immediate shamt

| 0 Rs | Rt | Rd | shamt | 2 |
|------|----|----|-------|---|
|------|----|----|-------|---|

## 3. Architecture Diagram



## 4. **Bonus**(10pts.)

Implement SLLV (Shift left logical variable) and SRLV (Shift right logical variable) instructions. You can add new module or control signal in this advanced design.

| Instruction | Example       | Meaning                                                                | Op field  | Shamt | Function field |
|-------------|---------------|------------------------------------------------------------------------|-----------|-------|----------------|
| SLLV        | sllv rd,rt,rs | rd=rt< <rs< th=""><th>6'b000000</th><th>5</th><th>6'b000110</th></rs<> | 6'b000000 | 5     | 6'b000110      |
| SRLV        | srlv rd,rt,rs | rd=rt>>rs                                                              | 6'b000000 | 5     | 6'b000100      |

## SRLV Rd, Rt, Rs

Shift register Rt right by the distance indicated by the register Rs

| 0 Rs | Rt | Rd | shamt | 6 |
|------|----|----|-------|---|
|------|----|----|-------|---|

#### 5. Test Bench

In Lab3, three test data (binary code), stored in "CO\_P3\_test\_data1.txt" ~ "CO\_P3\_test\_data3.txt", are provided. The default test data is the first one. If you would like to use second test data, modify line 75 in the file "TestBench.v" as follows: \$readmemb("CO\_P3\_test\_data1.txt", cpu.IM.Instr\_Mem);

The Assembly codes of the test data are given as follows:

| CO_P3_test_data1.txt |          | CO_P3_test_data2.txt |            | CO_P3_test_data3.txt |           |
|----------------------|----------|----------------------|------------|----------------------|-----------|
| addi r1 r0 10        | #r1 = 10 | addi r6 r0 3         | #r6 = 3    | addi r1 r0 -5        | #r1 = -5  |
| addi r2 r0 4         | #r2 = 4  | addi r7 r0 14        | #r7 = 14   | addi r2 r0 5         | #r2 = 5   |
| slt r3 r1 r2         | #r3 = 0  | and r8 r6 r7         | #r8 = 2    | slt r3 r1 r2         | #r3 = 1   |
| add r4 r1 r2         | #r4 =14  | or r9 r6 r7          | #r9 = 15   | slt r4 r2 r1         | #r5 = 0   |
| sub r5 r1 r2         | #r5 = 6  | sll r10 r9 3         | #r10 = 120 | add r5 r1 r2         | #r5 = 0   |
| nor r5 r5 r0         | #r5 = -7 |                      |            | sub r6 r1 r2         | #r6 = -10 |

After the simulation of TestBench, you will get the file "CO\_P3\_result.txt". You can verify the result. If your design passes the test data, the following words would show in the Transcript windows.

Congratulation. You pass TA's pattern

#### 6. Grade

Please compress all \*.v source files and report(pdf) into one zip file. Please names your zip file as "Lab3\_ID". (e.g. "Lab3\_0716999.zip"). Other form of file will get -10%.

A. Total score: 110pts. COPY WILL GET A 0 POINT!

- B. Instruction score: 80 pts.
- C. Report: 20pts format is in StudentID report.pdf
- D. Bonus: 10pts
- E. Late Submission: 10 points off per day, if you are late over 3 days you will get 0 points.
- F. Plagiarism will get 0 points. Please write your homework by yourself.

### 7. Q&A

If you have any question, just send email to all TAs via new E3 platform.

### 8. Notice

- A. Use the modules provided to implement your Single Cycle CPU
- B. Do not modify any existing code except the input filename in TestBench.v
- C. Write your code in "/\*your code here\*/"
- D. In Lab3, the modules to be designed by students should be implemented as combination circuits. (Do not design as sequential circuits or Zero score will be given!)

## 9. Appendix

In lab3, you can use 32bits ALU.

Here is the example of 32bits ALU from textbook



FIGURE C.5.14 The symbol commonly used to represent an ALU, as shown in Figure C.5.12. This symbol is also used to represent an adder, so it is normally labeled either with ALU or Adder.

```
module MIPSALU (ALUCtl, A, B, ALUOut, Zero);
   input [3:0] ALUctl;
   input [31:0] A,B;
   output reg [31:0] ALUOut;
   output Zero:
   assign Zero - (ALUOut--0); //Zero is true if ALUOut is O
   always @(ALUctl, A. B) begin //reevaluate if these change
      case (ALUctl)
         0: ALUOut <= A & B:
         1: ALUOut <= A | B:
         2: ALUOut <= A + B;
         6: ALUOut <- A - B;
         7: ALUOut <- A < B ? 1 : D;
         12: ALUDut <= ~(A | B); // result is nor
         default: ALUOut <= 0;
      endcase
    end
endmodule
```

FIGURE C.5.15 A Verilog behavioral definition of a MIPS ALU.