# CDA 3103: Study Set 6

DATAPATH, CONTROL SIGNALS, PIPELINING

The MIPS ISA is called a RISC (reduced instruction set computer). We only developed the datapath for some of the MIPS instructions we know.

**RISC Instruction Set:** 

R-Types: Add, Subtract, And, Or, Slt

I-Types: Add Immediate, And Immediate, Or Immediate, Load Word, Store Word, Branch if Equal

J-Types: Jump

In the single cycle datapath each instruction is fetched and processed in one clock cycle.

The Program Counter (PC) is a register that contains our current address in instruction memory. This is the location of our next instruction.

The instruction comes out of memory on a 32-bit bus. We split the wires of this bus to several different locations. The six most significant bits [bits 31-26] for all instructions types are the opcode, we send these bits to the control unit.



The next five bits [bits 25-21] are sent to the register file to identify the first register we will be reading from. We always do this, even if the instruction does not need to read any registers.

The same is true for the following five bits [bits 20-16]. In most of our instructions (add, sub, and, or, slt, sw, and beq) we will need the data from these two registers.

For a lw instruction, these five bits specify the destination. So we also send these five bits through a multiplexor to the write register.



The next five bits [bits 15-11] are sent to the write register multiplexor. In R-Type instructions, this will be the register that receives a new value.

The 16 least significant bits [bits 15-0] are also sent to the sign extension unit to form a sign-extended immediate when its needed (addi, lw, sw, and beq).

The 6 least significant bits [bits 5-0] are also sent to the ALU control. These will only be used for decoding R-Type instructions.



At this point, we add 4 to the PC to get set up for the next instruction.

If our current instruction is a branch or a jump, this value might change a second time.

In a jump, the 26 least significant bits [bits 25-0] will be shifted twice to the left. This is the same as multiplying by 4 and results in a 28 bit jump address.

We then copy over the four most significant bits from the PC [bits 31-28] to form a complete new PC.



The register file will produce two values along the read data 1 and read data 2 buses. Read data 1 is always sent to the Arithmetic Logic Unit (ALU).

The second input to the ALU depends on the instruction. R-Type instructions and BEQ use both register values. I-Type instructions other than BEQ use only one register and the other input to the ALU is the immediate value. We use the multiplexor between the register file and the ALU to choose between these two values.



The ALU will produce a result based on the inputs provided and the ALU operation signal from the ALU control unit.

For most instructions, we send this result "around" the data memory and back to the register file.

For lw and sw, this result is our memory access address. In a sw, we take the value from the read data 2 bus and store into data memory.



In a lw instruction, we take a value out of memory and send it back to the register. This creates two possible values for write data. We use a multiplexor to choose between ALU result and read data.



In a BEQ instruction, we calculate a branch target address by shifting our sign-extended immediate to the left twice. This is the same as multiplying it by four.

We then add this to the new PC value. If the two registers we are comparing actually are equal, then the Zero signal from the ALU will be asserted.

If both Branch and Zero are true, we select this branch target address to be our new Program Counter.



All of the decisions to be made on the datapath are controlled by multiplexors and control signals (shown in blue).

The Control Unit sets each of these signals based on the opcode in the instruction. These signals give the processor permission to read from data memory, write to data memory, and write to the register file. They also specify when to use read data 2 versus the sign extended immediate, which register to write to, when to use memory data versus the ALU result. They also determine where the next PC will come from.





The Control Unit sets all the control signals based on the Opcode.

RegDst chooses which set of bits will determine the write register.

If RegDst is 0 (deasserted) we use bits 25-21 to determine the write register. We want to do this for I-Type instructions that write to the register file (addi, andi, ori, and Iw).

If RegDst is 1 (asserted) we use bits 15-11 to determine the write register. We want to do this for all R-Type instructions.



Jump determines our next Program Counter.

We want to assert Jump whenever our current instruction is a jump. Jump should be deasserted for all other instructions.

Branch is also used to determined the next Program counter.

We want to assert Branch whenever our current instruction is BEQ. Branch should be deasserted for all other instructions.



MemRead gives the processor permission to read from Data Memory.

We want to assert MemRead whenever the current instruction is a load word. It should be desasserted for all other instructions.

MemWrite gives the processor permission to write to Data Memory.

We want to assert MemWrite whenever the current instruction is a store word. It should be desasserted for all other instructions.



MemtoReg determines which result we are going to send back to the register file.

When MemtoReg is set to 0 (deasserted), the ALU result from the Arithmetic Logic Unit will be sent to the write data input of the register file. We want to do this for all R-Type instructions and any I-Type instructions that write to the register file.

When MemtoReg is asserted, the value from data memory will be sent to the register file. We want to do this if the instruction is a load word.



ALUSrc stands for ALU source. This determines the second input for the Arithmetic Logic Unit. It has to choose between read data 2 and the signextended immediate value.

If ALUSrc is set to 0 (deasserted) then we will choose read data 2. We want to do this for all R-Types and BEQ.

If ALUSrc is set to 1 (asserted) then we will choose the sign-extended immediate value. We want to do this for the remaining I-Types (addi, andi, ori, lw, and sw).



RegWrite gives the processor permission to write to the register file.

We want to assert this control signal whenever we need to write to the register file:

- All R-Types
- Add Immediate
- And Immediate
- Or Immediate
- Load Word

We want to deassert this signal for all other instructions.



How should the control signals be set <u>Given</u>: for an addi instruction?



How should the control signals be set for an addi instruction?

The first control signal is RegDst. Our instruction – addi – is an I-Type instruction with the following format:

Partial Credit 1:

Given:

| ор     | rs     | rt     | constant |
|--------|--------|--------|----------|
| 6 hits | 5 hits | 5 hits | 16 hits  |

This tells us the destination register is specified by bits 20-16. So we should set RegDst to 0 to let bits 20-16 specify the write register.

$$RegDst = 0$$

Solution 1:



How should the control signals be set for an addi instruction?

The next control signal is Jump. Since our instruction – addi – is not a jump instruction, this signal should be set to 0.

Jump = 0.

Solution 2:

Given:

Partial

Credit 2:



How should the control signals be set for an addi instruction?

The next control signal is Branch. Since our instruction – addi – is not a branch instruction, this signal should be set to 0.

Branch = 0.

Solution 3:

Given:



How should the control signals be set for an addi instruction?

The next control signal is MemRead. Since our instruction – addi – is not a load word instruction, this signal should be set to 0.

MemRead = 0.

Solution 4:

Given:

Partial

Credit 4:



How should the control signals be set for an addi instruction?

The next control signal is MemtoReg. Since our instruction – addi – is not a load word instruction, this signal should be set to 0.

MemtoReg = 0.

Solution 5:

Given:

Partial

Credit 5:



How should the control signals be set for an addi instruction?

The next control signal is ALUOp. For this signal we need to consider what action the ALU should perform. With an addi instruction, we expect the ALU to perform an addition operation.

Partial Credit 6:

Solution 6:

Given:

ALUOp = add.



How should the control signals be set for an addi instruction?

The next control signal is MemWrite. Since our instruction – addi – is not a store word instruction, this signal should be set to 0.



Given:

#### MemWrite = 0.

Solution 7:

How should the control signals be set for an addi instruction?

The next control signal is ALUSrc. Since our instruction – addi – seeks to add a register and a constant value together we should send the sign-extended immediate as the second input to the ALU. To do this we need to set ALUSrc to 1.







Solution 8:

Given:

Partial

Credit 8:



How should the control signals be set for an addi instruction?

The last control signal is RegWrite. Since our instruction – addi – seeks to store the result of the add in the register file, we should assert this signal. This allows the processor to write to the register file.



Given:

RegWrite = 1.

Solution 9:



How should the control signals be set <u>Given</u>: for a lw instruction?



How should the control signals be set for a lw instruction?

The first control signal is RegDst. Our instruction – Iw – is an I-Type instruction with the following format:

Partial Credit 1:

Given:

| ор     | rs     | rt     | constant |
|--------|--------|--------|----------|
| 6 hits | 5 hits | 5 hits | 16 hits  |

This tells us the destination register is specified by bits 20-16. So we should set RegDst to 0 to let bits 20-16 specify the write register.

$$RegDst = 0$$

Solution 1:



How should the control signals be set for a lw instruction?

The next control signal is Jump. Since our instruction - lw - is not a jump instruction, this signal should be set to 0.

Jump = 0.

Solution 2:

Given:

Partial

Credit 2:



How should the control signals be set for a lw instruction?

The next control signal is Branch. Since our instruction - lw - is not a branch instruction, this signal should be set to 0.

Branch = 0.

Solution 3:

Given:



How should the control signals be set for a lw instruction?

The next control signal is MemRead. Since this is a load word instruction, this signal should be set to 1.

Partial Credit 4:

Given:

MemRead = 1.

Solution 4:



How should the control signals be set for a lw instruction?

The next control signal is MemtoReg. Since our instruction is a load word instruction, this signal should be set to 1. This tells the processor to send the value obtained from memory back to the register file.

Partial Credit 5:

Given:

MemtoReg = 1.

Solution 5:



How should the control signals be set for a lw instruction?

Given:

Partial

Credit 6:

Solution 6:

The next control signal is ALUOp. For this signal we need to consider what action the ALU should perform. With a lw instruction, we expect the ALU to perform an addition operation in order to add the base address and the offset together to get our final memory address.

ALUOp = add.



How should the control signals be set for a lw instruction?

The next control signal is MemWrite. Since our instruction - lw - is not a store word instruction, this signal should be set to 0.



Given:

#### MemWrite = 0.

Solution 7:



How should the control signals be set for a lw instruction?

The next control signal is ALUSrc. Since our instruction – Iw – seeks to add a register and a constant value together to form a memory address we should send the sign-extended immediate as the second input to the ALU. To do this we need to set ALUSrc to 1.

AIUSrc = 1.

Partial Credit 8:

Solution 8:

Given:

### **Example: Control Signals**



How should the control signals be set for a lw instruction?

The last control signal is RegWrite. Since our instruction – lw – seeks to store the value obtained from memory in the register file, we should assert this signal. This allows the processor to write to the register file.

RegWrite = 1.

Partial Credit 9:

Solution 9:

Given:

Pipelining allows us to overlap instructions in execution. When an instruction finishes the first stage and moves on to the second stage, the next instruction can start the first stage.

This increases our throughput: the number of instructions we can complete in a certain amount of time.



- Instruction Fetch (IF)
- Instruction Decode (ID)
- Execution (Ex)
- Memory Access (Mem)
- Write Back (WB)



- Instruction Fetch (IF)
  - During this stage, we fetch the next instruction located in Instruction Memory at PC. We send this along to the pipeline register to wait for the next stage.
  - Also in this stage, we update PC by adding 4 to the current PC value.
- Instruction Decode (ID)
- Execution (Ex)
- Memory Access (Mem)
- Write Back (WB)



- Instruction Fetch (IF)
- Instruction Decode (ID)
  - In this stage, we send the opcode to the Control Unit and determine the control signals for the rest of the datapath.
  - We also read from the register file in this stage: setting up read data 1 and read data 2 for the next stage.
  - We also send our 16 least significant bits to the sign-extension unit.
- Execution (Ex)
- Memory Access (Mem)
- Write Back (WB)



- Instruction Fetch (IF)
- Instruction Decode (ID)
- Execution (Ex)
  - In this stage we do several computations. The arithmetic logic unit will perform an action based on the opcode: add, subtract, and, or, slt.
  - We also calculate a branch target address and determine the location for the ALU result.
- Memory Access (Mem)
- Write Back (WB)



- Instruction Fetch (IF)
- Instruction Decode (ID)
- Execution (Ex)
- Memory Access (Mem)
  - In this stage we can access the Data Memory. We will do this if the current instruction is either a load word or store word.
  - We also resolve any branch decisions in this stage.
- Write Back (WB)



- Instruction Fetch (IF)
- Instruction Decode (ID)
- Execution (Ex)
- Memory Access (Mem)
- Write Back (WB)
  - In the last stage, we update the register file, if needed. We need to carry the write destination register along with the instruction to each pipeline stage to make sure we write the result to correct location.



Pipelining introduces Hazards to the datapath. These occur whenever the next instruction cannot continue as expected. There are three situation where that might happen:

Structure hazard

• A required resource is busy

Data hazard

Need to wait for previous instruction to complete its data read/write

Control hazard

• Deciding on control action depends on previous instruction

Structural Hazards have been dealt with in the MIPS datapath by duplicating several structural units. We have separate instruction and data memories so that stage 1 and stage 4 do not have to compete. There are several shifters and adders to manipulate different target addresses, so that our next Program Counter will be ready when we need it.

Data Hazards occur whenever our current instruction has to wait for a previous instruction to complete. Consider the following example:

add \$t0, \$s1, \$s2

add \$s0, \$t0, \$zero

The second add instruction has \$t0 as one of the sources, but the first add instruction has \$t0 as it's result. The first add instruction will not be writing the result to \$t0 until it reaches stage 5 (write back). But the second add instruction would normally be reading when the first instruction is in stage 3 (execution).

Data Hazard:

add \$t0, \$s1, \$s2

add \$s0, \$t0, \$zero

There are a couple ways to address this. The easiest method is to stall the pipeline until the first instruction has completed enough for the second instruction to begin. The write back stage of the first instruction can overlap with the instruction decode stage of the second instruction.

WB IE E. ID EX MEM bubble, bubble bubble bubble, bubble a n bubble bubble, bubble, bubble bubble WB F ID EX MEM

1600

Control Hazards occur whenever we have a branch instruction. Remember that our RISC system only supports BEQ.

We won't know until the end of stage 3 whether or not the two values are actually equal to each other.

Therefore, we cannot set our next PC until the BEQ instruction reaches stage 4. We won't fetch the next instruction until our BEQ instruction is in stage 4.



Similar to data hazards, the easiest method is to stall until the branch has been resolved.



<u>Given</u>:

Consider the following assembly language code:

| IO: | sub | \$t4, \$t1, \$s2 |
|-----|-----|------------------|
| I1: | add | \$s3, \$s2, \$t4 |
| I2: | add | \$t1, \$t0, \$s0 |
| I3: | add | \$t1, \$t0, \$s0 |
| I4: | sub | \$t4, \$t1, \$s2 |
| I5: | Iw  | \$t5, 0(\$t1)    |
| I6: | slt | \$t0 \$s0 \$s1   |
| l6: | slt | \$t0, \$s0, \$s1 |
| l7: | sw  | \$s2, 0(\$s0)    |

For each instruction, identify whether or not a hazard should be detected. If so, identify the type of hazard as structure, data, or control. Assume the instructions are being processed on a MIPS pipelined datapath without forwarding.





<u>Given</u>:

Consider the following assembly language code:

| 0: | sub | \$t4, \$t1, \$s2 |
|----|-----|------------------|
| 1: | add | \$s3, \$s2, \$t4 |
| 2: | add | \$t1, \$t0, \$s0 |
| 3: | add | \$t1, \$t0, \$s0 |
| 4: | sub | \$t4, \$t1, \$s2 |
| 5: | lw  | \$t5, 0(\$t1)    |
| 6: | slt | \$t0, \$s0, \$s1 |
| 7: | SW  | \$s2, 0(\$s0)    |

For each instruction, identify whether or not a hazard should be detected. If so, identify the type of hazard as structure, data, or control. Assume the instructions are being processed on a MIPS pipelined datapath without forwarding.

| Solution 1: | 10: | n |
|-------------|-----|---|
|             | 11: |   |
|             | 12: |   |
|             | 13: |   |
|             | 14: |   |
|             | 15: |   |

16:

17:

| - | no hazard |
|---|-----------|
| - |           |
| - |           |
| - |           |



Since hazards are situations that prevent an instruction from running, we assume the first instruction cannot experience a hazard as there is nothing prior to it.

We show the stages of instruction zero in the chart to track when \$t4 – the destination register – will be updated.

<u>Given</u>:

Consider the following assembly language code:

| 0:<br>1:<br>2:<br>3:<br>4:<br>5:<br>6:<br>7: | sub<br>add<br>add<br>add<br>sub<br>lw<br>slt | \$t4, \$t1, \$s2<br>\$s3, \$s2, \$t4<br>\$t1, \$t0, \$s0<br>\$t1, \$t0, \$s0<br>\$t4, \$t1, \$s2<br>\$t5, 0(\$t1)<br>\$t0, \$s0, \$s1<br>\$s2, 0(\$s0) |
|----------------------------------------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:                                           | SW                                           | \$s2, 0(\$s0)                                                                                                                                          |

For each instruction, identify whether or not a hazard should be detected. If so, identify the type of hazard as structure, data, or control. Assume the instructions are being processed on a MIPS pipelined datapath without forwarding.

| Sol | lution | <u>2</u> : |
|-----|--------|------------|
|     |        |            |

10:

|1: |2:

13:

14: 15:

16:

17:

| <br>_no hazaro<br>_data haza | d<br>ard |      |
|------------------------------|----------|------|
| <br>                         |          | <br> |
| <br>                         |          |      |
|                              |          |      |



In instruction one, we are trying to add \$t4 and \$s2 together. However, \$t4 is being written by the previous instruction – instruction zero. In the chart we can see that this value does not reach the register file until T4. Since we write in the first half of the clock cycle and read in the second, we can overlap the WB stage of I0 and the ID stage of I1.

<u>Given</u>:

Consider the following assembly language code:

| 0: | sub | \$t4, \$t1, \$s2 |
|----|-----|------------------|
| 1: | add | \$s3, \$s2, \$t4 |
| 2: | add | \$t1, \$t0, \$s0 |
| 3: | add | \$t1, \$t0, \$s0 |
| 4: | sub | \$t4, \$t1, \$s2 |
| 5: | lw  | \$t5, 0(\$t1)    |
| 6: | slt | \$t0, \$s0, \$s1 |
| 7: | sw  | \$s2, 0(\$s0)    |

For each instruction, identify whether or not a hazard should be detected. If so, identify the type of hazard as structure, data, or control. Assume the instructions are being processed on a MIPS pipelined datapath without forwarding.

Solution 3:

10:

|1: |2:

13:

14: 15: 16: 17:

| no hazard<br>data hazard<br>no hazard |  |
|---------------------------------------|--|
|                                       |  |
|                                       |  |



In instruction two, we are trying to add \$t0 and \$s0 together. Neither of these registers have been modified by our segment of assembly code, so this instruction should be able to proceed without a hazard.

<u>Given</u>:

Consider the following assembly language code:

| 0:<br>1: | sub<br>add | \$t4, \$t1, \$s2<br>\$s3, \$s2, \$t4 |
|----------|------------|--------------------------------------|
| 2:       | add        | \$t1, \$t0, \$s0                     |
| 3:       | add        | \$t1, \$t0, \$s0                     |
| 4:       | sub        | \$t4, \$t1, \$s2                     |
| 5:       | lw         | \$t5, 0(\$t1)                        |
| 6:       | slt        | \$t0, \$s0, \$s1                     |
| 7:       | SW         | \$s2, 0(\$s0)                        |

For each instruction, identify whether or not a hazard should be detected. If so, identify the type of hazard as structure, data, or control. Assume the instructions are being processed on a MIPS pipelined datapath without forwarding.

Solution 4:

10:

|1: |2:

13:

14: 15: 16: 17:

| no hazard<br>data hazard |  |
|--------------------------|--|
| no hazardno hazard       |  |
|                          |  |
|                          |  |

|    | то | T1 | т2 | тз  | Т4 | T5 | т6  | т7  | т8  | Т9 | T10 | T11 | T12 | T13 | T14 | T15 | Partial<br>Credit 4 |
|----|----|----|----|-----|----|----|-----|-----|-----|----|-----|-----|-----|-----|-----|-----|---------------------|
| 10 | IF | ID | EX | MEM | WB |    |     |     |     |    |     |     |     |     |     |     | <u>Clean</u>        |
| 11 |    |    |    | IF  | ID | EX | MEM | WB  |     |    |     |     |     |     |     |     |                     |
| 12 |    |    |    |     | IF | ID | EX  | MEM | WB  |    |     |     |     |     |     |     |                     |
| 13 |    |    |    |     |    | IF | ID  | EX  | MEM | WB |     |     |     |     |     |     |                     |
| 14 |    |    |    |     |    |    |     |     |     |    |     |     |     |     |     |     |                     |
| 15 |    |    |    |     |    |    |     |     |     |    |     |     |     |     |     |     |                     |
| 16 |    |    |    |     |    |    |     |     |     |    |     |     |     |     |     |     |                     |
| 17 |    |    |    |     |    |    |     |     |     |    |     |     |     |     |     |     |                     |

In instruction three, we are trying to add \$t0 and \$s0 together. Even though we read these in our previous instruction these registers have not been modified. So this instruction should be able to proceed without a hazard.

<u>Given</u>:

Consider the following assembly language code:

| 0: | sub | \$t4, \$t1, \$s2 |
|----|-----|------------------|
| 1: | add | \$s3, \$s2, \$t4 |
| 2: | add | \$t1, \$t0, \$s0 |
| 3: | add | \$t1, \$t0, \$s0 |
| 4: | sub | \$t4, \$t1, \$s2 |
| 5: | Iw  | \$t5, 0(\$t1)    |
| 6: | slt | \$t0, \$s0, \$s1 |
| 7: | SW  | \$s2, 0(\$s0)    |

For each instruction, identify whether or not a hazard should be detected. If so, identify the type of hazard as structure, data, or control. Assume the instructions are being processed on a MIPS pipelined datapath without forwarding.

Solution 5:

10:

|1: |2:

13: 14: 15:

16: 17:

| - | data h<br>no ha: |         | <br> |
|---|------------------|---------|------|
| _ | no ha            |         |      |
| _ | data h           | nazard_ |      |

|    | то | T1 | T2 | тз  | Т4 | Т5 | т6  | 77  | т8  | т9 | T10 | T11 | T12 | T13 | T14 | T15 | Partial<br>Credit 5: |
|----|----|----|----|-----|----|----|-----|-----|-----|----|-----|-----|-----|-----|-----|-----|----------------------|
| 10 | IF | ID | EX | MEM | WB |    |     |     |     |    |     |     |     |     |     |     | <u>create 5</u> .    |
| 11 |    |    |    | IF  | ID | EX | MEM | WB  |     |    |     |     |     |     |     |     |                      |
| 12 |    |    |    |     | IF | ID | EX  | MEM | WB  |    |     |     |     |     |     |     |                      |
| 13 |    |    |    |     |    | IF | ID  | EX  | MEM | WB |     |     |     |     |     |     |                      |
| 14 |    |    |    |     |    |    |     |     | IF  | ID | EX  | MEM | WB  |     |     |     |                      |
| 15 |    |    |    |     |    |    |     |     |     |    |     |     |     |     |     |     |                      |
| 16 |    |    |    |     |    |    |     |     |     |    |     |     |     |     |     |     |                      |
| 17 |    |    |    |     |    |    |     |     |     |    |     |     |     |     |     |     |                      |

In instruction four, we are trying to subtract \$s2 from \$t1. \$t1 was most recently modified by instruction three, which will not write the value of \$t1 to the register file until T9. I4 must wait until the same clock cycle to read the correct value of \$t1. This is a data hazard.

<u>Given</u>:

Consider the following assembly language code:

| 0: | sub | \$t4, \$t1, \$s2 |
|----|-----|------------------|
| 1: | add | \$s3, \$s2, \$t4 |
| 2: | add | \$t1, \$t0, \$s0 |
| 3: | add | \$t1, \$t0, \$s0 |
| 4: | sub | \$t4, \$t1, \$s2 |
| 5: | lw  | \$t5, 0(\$t1)    |
| 6: | slt | \$t0, \$s0, \$s1 |
| 7: | sw  | \$s2, 0(\$s0)    |
| /: | SW  | \$s2, 0(\$s0)    |

For each instruction, identify whether or not a hazard should be detected. If so, identify the type of hazard as structure, data, or control. Assume the instructions are being processed on a MIPS pipelined datapath without forwarding.

Solution 6:

10:

|1: |2:

13: 14: 15:

16: 17:

| no hazard   |  |
|-------------|--|
| data hazard |  |
| no hazard   |  |
| no hazard   |  |
| data hazard |  |
| no hazard   |  |
|             |  |
|             |  |

|    | то | T1 | т2 | тз  | Т4 | Т5 | т6  | т7  | т8  | т9 | Т10 | T11 | T12 | T13 | T14 | T15 | <u>Partial</u><br>Credit 6: |
|----|----|----|----|-----|----|----|-----|-----|-----|----|-----|-----|-----|-----|-----|-----|-----------------------------|
| 10 | IF | ID | EX | MEM | WB |    |     |     |     |    |     |     |     |     |     |     | <u>Crean o</u> .            |
| 11 |    |    |    | IF  | ID | EX | MEM | WB  |     |    |     |     |     |     |     |     |                             |
| 12 |    |    |    |     | IF | ID | EX  | MEM | WB  |    |     |     |     |     |     |     |                             |
| 13 |    |    |    |     |    | IF | ID  | EX  | MEM | WB |     |     |     |     |     |     |                             |
| 14 |    |    |    |     |    |    |     |     | IF  | ID | EX  | MEM | WB  |     |     |     |                             |
| 15 |    |    |    |     |    |    |     |     |     | IF | ID  | EX  | MEM | WB  |     |     |                             |
| 16 |    |    |    |     |    |    |     |     |     |    |     |     |     |     |     |     |                             |
| 17 |    |    |    |     |    |    |     |     |     |    |     |     |     |     |     |     |                             |

In instruction five, we load a value from memory at the location \$t1 + 0 and store the result into \$t5. \$t1 has had time to become stable since being written by I3.

<u>Given</u>:

Consider the following assembly language code:

| 0:       | sub       | \$t4, \$t1, \$s2 |
|----------|-----------|------------------|
| 1:       | add       | \$s3, \$s2, \$t4 |
| 2:       | add       | \$t1, \$t0, \$s0 |
| 3:       | add       | \$t1, \$t0, \$s0 |
| 4:       | sub       | \$t4, \$t1, \$s2 |
| 5:       | Iw        | \$t5, 0(\$t1)    |
| 6:       | slt       | \$t0, \$s0, \$s1 |
| 6:<br>7: | SIT<br>SW | \$s2, 0(\$s0)    |

For each instruction, identify whether or not a hazard should be detected. If so, identify the type of hazard as structure, data, or control. Assume the instructions are being processed on a MIPS pipelined datapath without forwarding.

| Sol | lut | tio | n | 7 | : |
|-----|-----|-----|---|---|---|
|     |     |     |   |   |   |

10:

|1: |2:

13:

14: 15: 16: 17:

| no hazard   |  |
|-------------|--|
| data hazard |  |
| no hazard   |  |
| no hazard   |  |
| data hazard |  |
| no hazard   |  |
| no hazard   |  |
|             |  |

In instruction six, we check to see if \$s0 is less than \$s1. Neither of these registers have been modified by our segment of assembly code, so this instruction can proceed without hazards.

|    | то | T1 | т2 | тз  | Т4 | Т5 | т6  | т7  | т8  | т9 | T10 | T11 | T12 | T13 | T14 | T15 |
|----|----|----|----|-----|----|----|-----|-----|-----|----|-----|-----|-----|-----|-----|-----|
| 10 | IF | ID | EX | MEM | WB |    |     |     |     |    |     |     |     |     |     |     |
| 11 |    |    |    | IF  | ID | EX | MEM | WB  |     |    |     |     |     |     |     |     |
| 12 |    |    |    |     | IF | ID | EX  | MEM | WB  |    |     |     |     |     |     |     |
| 13 |    |    |    |     |    | IF | ID  | EX  | MEM | WB |     |     |     |     |     |     |
| 14 |    |    |    |     |    |    |     |     | IF  | ID | EX  | MEM | WB  |     |     |     |
| 15 |    |    |    |     |    |    |     |     |     | IF | ID  | EX  | MEM | WB  |     |     |
| 16 |    |    |    |     |    |    |     |     |     |    | IF  | ID  | EX  | MEM | WB  |     |
| 17 |    |    |    |     |    |    |     |     |     |    |     |     |     |     |     |     |

<u>Given</u>: Consider the following assembly language code:

| 10: | sub | \$t4, \$t1, \$s2 |
|-----|-----|------------------|
| 11: | add | \$s3, \$s2, \$t4 |
| 12: | add | \$t1, \$t0, \$s0 |
| 13: | add | \$t1, \$t0, \$s0 |
| 14: | sub | \$t4, \$t1, \$s2 |
| 15: | lw  | \$t5, 0(\$t1)    |
| 16: | slt | \$t0, \$s0, \$s1 |
| 17: | SW  | \$s2, 0(\$s0)    |

For each instruction, identify whether or not a hazard should be detected. If so, identify the type of hazard as structure, data, or control. Assume the instructions are being processed on a MIPS pipelined datapath without forwarding.

Solution 8:

10

|1 |2

17

|   | no hazard   |  |
|---|-------------|--|
| • | data hazard |  |
| • | no hazard   |  |
|   | no hazard   |  |
| • | data hazard |  |
|   | no hazard   |  |
|   | no hazard   |  |
| • | no hazard   |  |
|   |             |  |

|    | то | T1 | т2 | Т3  | Т4 | Т5 | т6  | т7  | т8  | т9 | т10 | T11 | T12 | T13 | T14 | T15 |
|----|----|----|----|-----|----|----|-----|-----|-----|----|-----|-----|-----|-----|-----|-----|
| 10 | IF | ID | EX | MEM | WB |    |     |     |     |    |     |     |     |     |     |     |
| 11 |    |    |    | IF  | ID | EX | MEM | WB  |     |    |     |     |     |     |     |     |
| 12 |    |    |    |     | IF | ID | EX  | MEM | WB  |    |     |     |     |     |     |     |
| 13 |    |    |    |     |    | IF | ID  | EX  | MEM | WB |     |     |     |     |     |     |
| 14 |    |    |    |     |    |    |     |     | IF  | ID | EX  | MEM | WB  |     |     |     |
| 15 |    |    |    |     |    |    |     |     |     | IF | ID  | EX  | MEM | WB  |     |     |
| 16 |    |    |    |     |    |    |     |     |     |    | IF  | ID  | EX  | MEM | WB  |     |
| 17 |    |    |    |     |    |    |     |     |     |    |     | IF  | ID  | EX  | MEM | WB  |

In instruction seven, we are trying to store the value of \$s2 into memory at the location \$s0 + 0. Neither of these registers have been modified by our segment of assembly code, so this instruction can proceed without hazards.