# **HW4 Report**

| ∷ 分類                   |                       |
|------------------------|-----------------------|
| <ul><li>Date</li></ul> | @May 17, 2024 8:55 PM |
| ☑ Review               |                       |

## **Experiment Result**

#### 1. Waveform



#### 1. Other test case

• test if addi can work properly by the following test case:

```
addi $t3 $t4 100
add $t5 $t4 $t3
```

• test for lw and beq (required additional stall condition ):

```
lw $t4, 8($gp)
nop
beq $t3, $t4, end
```

### Questions

- 1. The equation and the false in text book
  - EX hazard:

• MEM hazard:

False

If EX\_MEM\_rd is derived directly from ID\_EX\_rd, than is is wrong. However, I set the following condition, making the EX\_MEM\_rd can fit the formula provided in text\_book.

```
if (ID_EX_EX[3]) EX_MEM_rd <= ID_EX_rd;
else EX_MEM_rd <= ID_EX_rt;</pre>
```

- 2. Is forwarding form MEM\_WB needed?
  - We try to use reduce the branch delay, so we need to forward the read data from MEM\_WB to ID stage.
  - Considering the following situation:



- The correct value of \$1 will be write back to ID stage in WB stage, but it should take more time to derive data from memory; that is, the ID stage may not able to reach the correct write back data in time. Adding forwarding will solve the problem.
- This cause additional stall or forwarding.

#### 3. insert 2 stalls

```
always @(*)begin
    if (branch_read_reg_after_load)begin
        nxt_stall <= 2;</pre>
    end
    else if (branch_read_reg_after_ALU || stall_condition)beg
        nxt_stall <= 1;</pre>
    end
end
always @(posedge clk && rstn)begin
    if(nxt_stall > 0)begin
        nxt_stall <= nxt_stall - 1;</pre>
    end
    else begin
        nxt_stall <= 0;
    end
end
always @(negedge rstn) begin
```

```
nxt_stall <= 0;
end</pre>
```

• use a register "nxt\_stall" to record the remaining stall(not yet down), and

```
assign stall = (nxt_stall > 0) ;
```

• when a stall is taken, do

```
nxt_stall <= nxt_stall - 1</pre>
```

- stall\_condition including additional stall-needed condition including addi.
- 4. sw right after lw with no stall:
  - We can add a forwarding:

```
#1 sw $1 $addr
#2 lw $2 $addr
```



- if ( MEM\_WB\_rd == EX\_MEM\_rd ) && ( MEM\_WB\_offset == EX\_MEM\_offset ):
  - forward #1 MEM\_read\_data from MEM\_WB to replace the #2 MEM\_read\_data