#### Cambios en la ruta de datos:

- Se añaden los registros de fase: BusA\_MEM, BusA\_WB, PC4\_MEM, PC4\_WB
- Se añade un multiplexor 2:1 antes de la memoria de datos con ALU\_out\_MEM (0) y BusA\_MEM (1) con una señal de control MemSrc\_MEM.
- Se amplía el multiplexor MemtoReg\_WB a 4:1, añadiendo PC4\_WB (2).
- Se modifica el banco de registros para que sea un banco con doble puerto de escritura, por lo que se añaden las entradas busW2 y RW2. Se conecta busW2 con ALU\_out\_WB y RW2 con BusA\_WB.
- Se amplía el multiplexor PCSrc a 4:1, añadiendo BusA\_WB (2).

# Ruta de datos modificada:



## Acciones RTL y señales por etapa:

- fetch: PC4\_ID <- PC4\_F, IR<-IR\_F, Señales IF/ID.</li>
- Decode: Señales ID/EX.

### LW:

- Execute: Mux\_Rt\_Rd = 0, ALUSrc\_EX = 1, Señales EX/MEM.
- Memory: MDR <-MEM(BR(rs)) = MEM(BusA\_MEM); MemSrc\_MEM = 1, MEM/WB.
- Write: BR(RW\_WR) <-MDR, BR(ALU\_out\_MEM) <- BusA\_MEM; MEmToReg = 1.</li>

### jal:

- Execute: Señales EX/MEM
- Memory: Señales MEM/WB
- Write: BR(RW\_WR) <-PC4\_WB; MemtoReq = 2

#### ret:

- Execute: Señales EX/MEM
- Memory: Señales MEM/WB
- Write: PC <-PC4\_WB; PCSrc = 2