



# ECE3700J Mid RC Data Hazard

Presenter: Ruan Renjian 阮仁剑





## **Data Hazard in ALU Instructions**









# Solution with adding NOP/Stall



nop # no operation, pseudo-instruction
# addi x0, x0, 0

EX Hazard: +2 NOP

MEM Hazard: +1 NOP







# Solution with forwarding



Forwarding Unit

### Forwarding Scheme











# Solution with forwarding



Forwarding detection and MUXes







### **Load-use Data Hazard**









### **Load-use Data Hazard**





```
if (ID/EX.MemRead && (ID/EX.rd == IF/ID.rs1 || ID/EX.rd == IF/ID.rs2)) {
    PCWrite = 0;
    IF/IDWrite = 0;
    Hazard = 1;
}
else {
    PCWrite = 1;
    IF/IDWrite = 1;
    Hazard = 0;
}
```





# Very Important !!! (Slide 31-37)



| CC1           | PC<br>Write | IF/ID<br>Write  | Hazard  |                | EX.<br>nRead    | IF/ID<br>.Rs1 | IF/ID<br>.Rs2 | ID/EX.<br>Rd  |  |
|---------------|-------------|-----------------|---------|----------------|-----------------|---------------|---------------|---------------|--|
| lw x2, 20(x1) | 1           | 1               | X       |                | X               | X             | Х             | X             |  |
| CC2           |             | F/ID H<br>Vrite | Hazard  | ID/EX.<br>MemR |                 |               | IF/ID.<br>Rs2 | ID/EX.<br>Rd  |  |
| and x4,x2,x5  | 1<br>lw x   | 1<br><2, 20(x1  | x<br>I) | х              |                 | 1             | 20            | X             |  |
| CC3           | PC<br>Write | IF/ID<br>Write  | Hazard  |                | X.<br>nRead     | IF/ID.<br>Rs1 | IF/ID.<br>Rs2 | ID/EX<br>Rd   |  |
|               | 0           | 0 1             |         | 1              |                 | 2             | 5             | 2             |  |
| or x8,x2,x6   | and         | and x4,x2,x5    |         |                |                 | w x2, 20(x1)  |               |               |  |
| CC4           | PC<br>Write | IF/ID<br>Write  |         |                | ID/EX.<br>MemRo |               |               | IF/ID.<br>Rs2 |  |
|               | 1           | 1               |         | 0              | 0               |               | 2             | 5             |  |
| or x8,x2,x6   | and         | and x4,x2,x5    |         |                | nop (and)       |               | lw x2, 20(x1) |               |  |



### **TIPS**



- ■Slide and homework are VERY Important!
- ■Understand how processor functions at different stages (Your Vivado Labs can help you well)
- ■Be careful



# **TIPS**

Thank You and Good Luck:D

