**Week 3-2** COMP3211/COMP9211

# PIPELINED PROCESSOR (II) https://tutorcs.com

Lecturer: Hui Annie Guo WeChat: cstutorcs

h.guo@unsw.edu.au

K17-501F

#### Lecture overview

- Topics
  - Overview of pipeline hazards
  - · Design solutions to the Project at the Project at
  - Design solutions to data hazard https://tutorcs.com
- Suggested reading
  - H&P Chapter 4.7

#### **Hazards**

- Pipeline hazards are the situations where instruction execution cannot proceed in the pipeline.
  - Assignment Project Exam Help
    Structural hazard
    - Required resquires is busy res.com
  - Data hazard
    - Need to wait for prehiatuscintation to update its data.
  - Control hazard
    - The control decision cannot be made till the condition check by the previous instruction is completed.

#### Structural hazard

- Resource is not available
  - Example
    - In MIPS pipeline if a single memory is used for both instruction and data both Instruction Fetch and Load/Store will compete for memory access in the same clock cycle



#### **Data hazard**

#### Data is not available

Example

```
add $s0, $t0, $t1
sub A$signanoper Exam Help
```

https://tutorcs.com



#### **Control hazard**

- Next instruction is not available
  - Fetching next instruction depends on branch condition



#### Design solutions to structural hazard

- Structural hazards occur when one resource is to be used by more than one instruction in one cycle
- Solutions: Never access a resource more than once per cycle Assignment Project Exam Help
  - Allocate each resource to a single pipeline stage
     Duplicate resources if necessary e.g. IMEM/DMEM
  - · Every instruction must follow the same sequence of cycles/stages
    - Skipping a stage can introduce structural hazards
      - e.g R-type instructions cannot skip MEM stage
    - Unnecessary trailing cycles/stages can be dropped
      - e.g. BRA/JMP don't need to complete WB (or even MEM)

# Recall: Pipelined datapath and control



# In-class exercises (1)

If the connection line in green in the previous slide is removed and the R-type instruction is allowed to skip the Mem stage, how are the following Awis Instructions Executed in the pipeline?

https://tutorcs.com

# In-class exercises (2)

• Assume there is only one memory for both instruction and data in the pipelined processor. Assume there are 20% load/store instructions: what is the average of hazards? the torcs.com

WeChat: cstutorcs

#### **Data hazard**

- Data hazards are caused by data dependency
- There are four types of data dependency between instructions



Instr. seq
Inst 1
Inst 2
.
.
.
Inst i
.
Inst j
.

# In-class exercises (3)

Identify all data dependencies in the following code segment.

```
Assignment Project Exam Help $2, $5, $4 add $4, https://tutoscs.com

sw $5, Wellow($2) tutorcs add $3, $2, $4
```

#### Design solutions to data hazard

- Avoid some hazards by properly partitioning/scheduling "tasks" in the pipeline.
   For example,
  - eliminating WAR by always fetching operands early in the pipeline https://tutorcs.com
    - in ID stage
  - · eliminating WAW Chyatlointy talt WBs in order
    - single write stage
- Detect and resolve remaining ones (RAW)
  - stall
  - forward (if possible)

#### Data hazards in our pipeline

- Happen when there are RAW data dependencies between instructions executing in the pipalingnment Project Exam Help
  - Read the old (wrong) data https://tutorcs.com
     See example in the next slide

WeChat: cstutores

#### Data hazard example





# Handling data hazard

- Stalling pipeline
  - A basic solution
    - If the correct data is not available in the storage location, stall the instriction extection the probabilities.
- Forwarding https://tutorcs.com
  - A very effective approach
    - If the correct data is available in the pipeline, forward the data to where it is required in the pipeline.
  - See example in the next slide

## **Forwarding**





#### Forwarding implementation

- Detect data hazards
  - Check for data dependencies between each instruction and its preceding instructions in the pipeline Assignment Project Exam Help
- Forward the correct data to where it is required. For example
  - Ex stage WeChat: cstutorcs

## Detect data hazard for Ex stage (1)

- Based on the pipeline register field contents
  - Source register dependent on destination register of its first preceding instruction
    - · 1a. EX/MANSRegisterRdPrup/EX.RegisterRelp
    - 1b. EX/MEM.RegisterRd = ID/EX.RegisterRt

https://tutorcs.com



## Detect data hazard for Ex stage (2)

- Based on the pipeline register field contents
  - Source register dependent on destination register of the second preceding instruction
    - · 2a. MEM/MBsRegisterRdPrdPtty.RegisterRelp
    - 2b. MEM/WB.RegisterRd = ID/EX.RegisterRt



# **Example**

**Dependent instructions: sub-and** 

Data hazard type: 1a

# **Example**

```
sub $2,$1,$3. IF ID EX ME WB and $12,$2,$1 sgnment From Let WB with the state of th
```

Dependent instructions: sub-and, sub-or

Data hazard type: 1a, 2b

# Detect data hazard for Ex stage (3)

- More considerations: preceding instructions must
  - 1. Write back a result Project Exam Help
  - 2. If they writh the stored, and hence needs not to be forwarded
    - Recall: \$0 is a special register in MIPS that always has value 0

#### Forwarding for Ex hazard (1) (cont.)

Data forwarded from Mem stage:

```
EX/MEM.RegWrite
IF
```

EX/MEM.RegisterRd!= 0 AND

EX/MEM.RegisterRd = ID/EX.RegisterRs
forward AEU result to first AEU op Help AND

```
EX/MEM. Retenviriteutores.com
IF
```

EX/MEM.RegisterRd!= 0 AND

EX/MEM.RegisterRt AND

forward ALU result to second ALU op

## Forwarding for EX hazard (2)

Data forwarded from WB stage:

```
IF
          MEM/WB.RegWrite
          MEM/WB.RegisterRd != 0
AND
          MEM/WB.RegisterRd = ID/EX.RegisterRs
ASSIGNMENT FIOTECT EXAMINITED
FORWARD MEM data to first ALU op
AND
```

MEM/WB.RegWrite IF

AND

MEM/WB.RegisterRd != 0 MEM/WB.RegisterRd = 1D/EX.RegisterRt AND

forward MEM data to second ALU op

#### Multiple data dependencies

What if a data is dependent on both the Mem and WB data?

add \$1, \$1, \$2 add \$1, \$1, \$3 add \$1, \$1, \$4 Assignment Project Exam Help

Forward the more recent results – the data from Mem

IF MEM/WB.RegWrite tutorcs.com

AND MEM/WB.RegisterRd != 0

AND EX/MEM.RegisterRd = ID/EX.RegisterRs

MEM/WB.RegisterRd = ID/EX.RegisterRs

forward WB data to first ALU op

IF MEM/WB.RegWrite

AND MEM/WB.RegisterRd != 0

AND EX/MEM.RegisterRd != ID/EX.RegisterRt AND MEM/WB.RegisterRd = ID/EX.RegisterRt

forward WB data to second ALU op

# Modified datapath with forwarding unit



# In-class exercise (4)

Identify all of the data dependencies in the following code. Which dependencies are data hazards that can be resolved by forwarding?

Assignment Project Exam Help

add \$2, htt\$5,//tu\$4cs.com add \$4, w\$2hat: \$5tutorcs sw \$5, 100(\$2) add \$3, \$2, \$4

#### When forwarding does not work → STALL

- Detect such a hazard
- Stall the pipeline (insert bubble)



#### Detect such a hazard

- Such a hazard happens when a load instruction is followed by an instruction dependent on the memory data (load-use hazard, on the load Project Exam Help
  - A hazard detection unit is needed to check the following condition: tutorcs.com

IF ID/EX:MemRead CStutorCS
AND (ID/EX:RegisterRt = IF/ID:RegisterRs
OR ID/EX:RegisterRt = IF/ID:RegisterRt)
stall the pipeline



#### Stall pipeline

- Prevent the PC and IF/ID registers from changing
  - · by not loading nawny altesect Exam Help
- Set the EX, MEM and WB control fields of the https://tutorcs.com a NO-OP
  - · since no state Woodates will to be sur
- See next slide

```
Program
               Time (in clock cycles)
execution
                   CC 1
                              CC 2
                                          CC3
                                                    CC 4
                                                                CC 5
                                                                           CC6
                                                                                      CC 7
                                                                                                 CC8
                                                                                                             CC9
order
(in instructions)
  lw $2, 20($1)
 and $4, $2, $5
 or $8, $2, $6
 add $9, $4, $2
```

#### Stall pipeline (cont.)



#### **Execution example of LUH**











