

CMP

**Key:**u(<): Unsigned less than
u(>=): Unsigned greater than equal to



# JMP Logic



# Forwarding Unit Logic

### Inputs:

idex\_ireg\_out.rs1 idex\_ireg\_out.rs2 exmem\_ireg\_out.rd memwb\_ireg\_out.rd

### **Outputs:**

rs1forw\_mux\_sel rs2forw mux sel

#### Defaults:

rs1forw\_mux\_sel = forw\_mux::idex\_rs1reg\_out rs2forw mux sel = forw mux::idex rs1reg out

```
if exmem ctrlreg out.regfile Id & (exmem ireg out.rd!= 0)
& (exmem irea out.rd = idex irea out.rs1))
& (exmem ireg out.rd = idex ireg out.rs1))
     rs1forw mux sel = forw mux::exmem alureg out
if exmem ctrlreg out.regfile Id & (exmem ireg out.rd != 0)
& (exmem ireg out.rd = idex ireg out.rs2))
     rs2forw mux sel = forw mux::exmem alureg out
if (memwb ctrlreg out.reafile Id & (memwb ireg out.rd!= 0)
&!(exmem ctrlreg out.regfile Id & (exmem ireg out.rd!= 0)
& (exmem ireg out.rd != idex ireg out.rs1))
& (memwb_ireg_out.rd = idex_ireg_out.rs1))
     rs1forw mux sel = forw mux::regfile wdata
if (memwb ctrlreg out.regfile Id & (memwb ireg out.rd != 0)
&!(exmem_ctrlreg_out.regfile_ld & (exmem_ireg_out.rd!= 0)
& (exmem ireg out.rd != idex ireg out.rs1))
& (memwb_ireg_out.rd = idex_ireg_out.rs1))
     rs1forw mux sel = forw mux::regfile wdata
```

# **Memory Hierarchy**



## **Arbiter**



### **Arbiter Control Unit State Machine**



### Bit representation in State Machine (L to R):

Bit 0: icache read Bit 1: dcache read

Bit 2: dcache write

Bit 3: mem resp

### Output at each state:

### do nothina

- mem read = 0
- mem write = 0
- addr sel = addr mux::icache address
- rdata sel = rdata mux::icache rdata
- -icache resp = 0
- dcache resp = 0

### icache read

- mem read = 1
- mem write = 0
- addr sel = addr mux::icache address
- rdata sel = rdata mux::icache rdata
- icache resp = mem resp
- dcache resp = 0

### dcache read

- mem read = 1
- mem write = 0
- addr sel = addr mux::dcache address
- rdata sel = rdata mux::dcache rdata
- dcache resp = mem resp
- icache resp = 0

### dcache write

- mem read = 0
- mem write = 1
- addr sel = addr mux::dcache address
- rdata sel = rdata mux::dcache rdata
- dcache resp = mem resp
- icache resp = 0