## Exercise2



Execution has five stages IF, ID, MEM, WB during each clock cycle one instruction will complete a stage, the previous instruction will complete the next stage, and the following will complete the previous stage.

a)

For pipeline execution diagram for third iteration of the loop:

- ❖ Include the previous instructions from the 2<sup>nd</sup> iteration that are still executing when the 3<sup>rd</sup> iteration starts
- ❖ End the execution diagram on the clock cycle where the fourth iteration can start
- ❖ The LW instruction needs a stall since R1 which the previous add instruction uses
- ❖ The LW instruction needs a stall since R2 which the previous load instruction uses

| MIPS<br>CODE  | 1  | 2   | 3   | 4   | 5     |    |       |
|---------------|----|-----|-----|-----|-------|----|-------|
| 2: LW         | WB |     |     |     |       |    |       |
| 2: <b>SLT</b> | EX | MEM | WB  |     |       |    |       |
| 2: <b>BEQ</b> | ID | EX  | MEM | WB  |       |    |       |
|               | ID | EX  | MEM | WB  |       |    |       |
|               |    |     |     |     |       |    |       |
| <b>3: ADD</b> | IF | ID  | EX  | MEM | WB    |    |       |
| 3: LW         |    | IF  | ID  | EX  | MEM   |    |       |
| 3: LW         |    |     | IF  | ID  | STALL | EX | MEM   |
| <b>3: SLT</b> |    |     |     | IF  | STALL | ID | STALL |
| <b>3: BEQ</b> |    |     |     |     |       | IF | STALL |

b)

For pipeline execution diagram for third iteration of the loop:

- ❖ Include the previous instructions from the 2<sup>nd</sup> iteration that are still executing when the 3<sup>rd</sup> iteration starts
- ❖ End the execution diagram on the clock cycle where the fourth iteration can start
- ❖ The AND instruction needs a stall since R1 which the previous load instruction uses
- ❖ Each instruction uses the R1 register so each instruction needs a stall so that next instruction does not use R1 until the current instruction is finished with it.

| MIPS CODE   | 1  | 2     | 3  | 4   | 5     | 6  | 7   | 8     | 9  |
|-------------|----|-------|----|-----|-------|----|-----|-------|----|
| LW R1,0(R1) | WB |       |    |     |       |    |     |       |    |
| LW R1,0(R1) | EX | MEM   | WB |     |       |    |     |       |    |
| BEQ R1, R0, | ID | STALL | EX | MEM | WB    |    |     |       |    |
| LOOP        |    |       |    |     |       |    |     |       |    |
|             |    |       |    |     |       |    |     |       |    |
| LW R1,0(R1) | IF | STALL | ID | EX  | MEM   | WB |     |       |    |
| AND R1,     |    |       | IF | ID  | STALL | EX | MEM | WB    |    |
| R1,R2       |    |       |    |     |       |    |     |       |    |
| LW R1,0(R1) |    |       |    | IF  | STALL | ID | EX  | MEM   | WB |
| LW R1,0(R1) |    |       |    |     |       | IF | ID  | STALL |    |
| BEQ         |    |       |    |     |       |    | IF  | STALL |    |
| R1,R0,LOOP  |    |       |    |     |       |    |     |       |    |