### DATA PATH Y CONTROL DEL PIPELINE 1/26 DATA PATH



### DATA PATH Y CONTROL DEL PIPELINE 2/26 DATA PATH

- IF: Instruction fetch
- ID: Instruction decode and register file read
- 3. EX: Execution or address calculation
- MEM: Data memory access
- WB: Write back

### DATA PATH Y CONTROL DEL PIPELINE 3/26 DATA PATH



# DATA PATH Y CONTROL DEL PIPELINE 4/26 DATA PATH



# DATA PATH Y CONTROL DEL PIPELINE 5/26 DATA PATH



# DATA PATH Y CONTROL DEL PIPELINE 6/26 DATA PATH



## DATA PATH Y CONTROL DEL PIPELINE 7/26 DATA PATH



# DATA PATH Y CONTROL DEL PIPELINE 8/26 DATA PATH



# DATA PATH Y CONTROL DEL PIPELINE 9/26 DATA PATH



# DATA PATH Y CONTROL DEL PIPELINE 10/26 DATA PATH



# DATA PATH Y CONTROL DEL PIPELINE 11/26 DATA PATH



## DATA PATH Y CONTROL DEL PIPELINE 12/26 DATA PATH



# DATA PATH Y CONTROL DEL PIPELINE 13/26 DATA PATH



# DATA PATH Y CONTROL DEL PIPELINE 14/26 DATA PATH



## DATA PATH Y CONTROL DEL PIPELINE 15/26 DATA PATH CORRECTO



# DATA PATH Y CONTROL DEL PIPELINE 16/26 DATA PATH



#### DATA PATH Y CONTROL DEL PIPELINE 17/26 REPRESENTACIÓN GRÁFICA

| 1 W | \$10, | 20(\$1)  |
|-----|-------|----------|
| sub | \$11, | \$2, \$3 |
| add | \$12, | \$3, \$4 |
| Tw  | \$13, | 24(\$1)  |
| add | \$14. | \$5, \$6 |

#### DATA PATH Y CONTROL DEL PIPELINE 18/26 REPRESENTACIÓN GRÁFICA





#### DATA PATH Y CONTROL DEL PIPELINE 19/26 REPRESENTACIÓN GRÁFICA



#### DATA PATH Y CONTROL DEL PIPELINE 20/26 REPRESENTACIÓN GRÁFICA



# DATA PATH Y CONTROL DEL PIPELINE 20/26 CONTROL DEL PIPELINE

| Field                          | 0                    | rs    | rt    | rd    | shomt   | funct |  |
|--------------------------------|----------------------|-------|-------|-------|---------|-------|--|
| Bit positions                  | 31:26                | 25:21 | 20:16 | 15:11 | 10:6    | 5:0   |  |
| . R-type i                     | nstruction           |       |       |       |         |       |  |
| Field                          | 35 or 43             | rs    | rt    |       | address |       |  |
| <u>lablo</u> (100 benaga munco | 04.00                | 00.04 | 00.42 | 15:0  |         |       |  |
| Bit positions                  | 31:26                | 25:21 | 20:16 |       | 15:0    |       |  |
|                                | 31:26<br>store instr |       | 20:16 |       | 15:0    |       |  |
| Bit positions  Load or  Field  |                      |       | 20:16 |       | address |       |  |

### DATA PATH Y CONTROL DEL PIPELINE 20/26 CONTROL DEL PIPELINE



### DATA PATH Y CONTROL DEL PIPELINE 21/26 CONTROL DEL PIPELINE

| Instruction opcode | ALUOp | Instruction operation | Function code | Desired<br>ALU action | ALU control<br>input |
|--------------------|-------|-----------------------|---------------|-----------------------|----------------------|
| UW                 | 00    | load word             | XXXXXX        | add                   | 0010                 |
| SW                 | 00    | store word            | XXXXXX        | add                   | 0010                 |
|                    | 01    | branch equal          | XXXXXX        | subtract              | 0110                 |
| Branch equal       | 10    | add                   | 100000        | add                   | 0010                 |
| R-type             | 10    | subtract              | 100010        | subtract              | 0110                 |
| R-type             | 10    | AND                   | 100100        | AND                   | 0000                 |
| R-type             | 10    | OR                    | 100101        | OR                    | 0001                 |
| R-type<br>R-type   | 10    | set on less than      | 101010        | set on less than      | 0111                 |

# DATA PATH Y CONTROL DEL PIPELINE 22/26 CONTROL DEL PIPELINE

| Signal name | Effect when deasserted (0)                                                                   | Effect when asserted (1)                                                                                |  |  |  |  |
|-------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|--|--|--|--|
| RegDst      | The register destination number for the Write register comes from the rt field (bits 20:16). | The register destination number for the Write register comes from the rd field (bits 15:11).            |  |  |  |  |
| RegWrite    | None.                                                                                        | the instruction.                                                                                        |  |  |  |  |
| ALUSIC      | The second ALU operand comes from the second register file output (Read data 2).             |                                                                                                         |  |  |  |  |
| PCSrc       | The PC is replaced by the output of the adder that computes the value of PC + 4.             |                                                                                                         |  |  |  |  |
| MemRead     | None.                                                                                        | Data memory contents designated by the address input are<br>put on the Read data output.                |  |  |  |  |
| MemWrite    | None.                                                                                        | Data memory contents designated by the address input are replaced by the value on the Write data input. |  |  |  |  |
| MemtoReg    | The value fed to the register Write data input comes from the ALU.                           | The value fed to the register Write data input comes from the data memory.                              |  |  |  |  |

### DATA PATH Y CONTROL DEL PIPELINE 23/26 CONTROL DEL PIPELINE

| E HER             | Execution/address calculation stage control lines |        |        |        | Memory access stage control lines |              |               | Write-back stage<br>control lines |               |
|-------------------|---------------------------------------------------|--------|--------|--------|-----------------------------------|--------------|---------------|-----------------------------------|---------------|
| Instruction RegDs | RegDst                                            | ALUOp1 | ALUOp0 | ALUSTO | Branch                            | Mem-<br>Read | Mem-<br>Write | Reg-<br>Write                     | Memto-<br>Reg |
| R-format          | 1                                                 | 1      | 0      | 0      | 0                                 | 0            | 0             | 1                                 | 0             |
|                   | -                                                 | -      | 0      | 1      | 0                                 | 1            | 0             | 1                                 | 1             |
| lw                | U                                                 | U      | U      | 1      |                                   |              | и             | 0                                 | Y             |
| SW                | X                                                 | 0      | 0      | 1      | 0                                 | U            |               |                                   | ^             |
| beg               | х                                                 | 0      | 1      | 0      | 1                                 | Ō            | 0             | 0                                 | Х             |

# DATA PATH Y CONTROL DEL PIPELINE 24/26 CONTROL DEL PIPELINE



## DATA PATH Y CONTROL DEL PIPELINE 25/26 CONTROL DEL PIPELINE

