# No Forwarding



Chapter 4 — The Processor — 8

# Solving EXE hazard



## Solving MEM hazard



### Solving Double hazard



sub \$2, x, x

and \$4, \$2, x

or\$4, \$4, \$2

add \$9, \$4, \$2



### **Load-Use Data Hazard**



#### **Stall for Branch Taken**



### Stall for J

#### **Data Hazards for Branches**

If a comparison register is a destination of 2<sup>nd</sup> or 3<sup>rd</sup> preceding ALU instruction



Can resolve using forwarding

#### **Data Hazards for Branches**

- If a comparison register is a destination of preceding ALU instruction or 2<sup>nd</sup> preceding load instruction
  - Need 1 stall cycle



#### **Data Hazards for Branches**

- If a comparison register is a destination of immediately preceding load instruction
  - Need 2 stall cycles

