

# DLX TOP



DLX memory is a byte addressable memory in BIG ENDIAN



## DATAPATH



## FILES





## Fetch unit



The register of the fetch unit is made of D-FF



## Decode unit

### Block diagram



Register file (2R 1W implementation)



type Reg\_array is array of vector

Signal Registers: Reg\_array = Ø

Write : (address different from Ø) and (write\_enable = 1)

Read :

if (Write\_enable=1) and (Read-one\_address = Write\_address) and (Read-two\_address = Write\_address)

Now we write all the possible combinations of addresses





| OPCODE | RS1   | RS2   | RDST  | FUNC  |   |
|--------|-------|-------|-------|-------|---|
| 31     | 26 25 | 21 20 | 16 15 | 11 10 | 0 |

## Execute write

alu\_forwarding\_one  
mem\_forwarding\_one  
alu\_forwarding\_two  
mem\_forwarding\_two  
alu\_forwarding\_value  
mem\_forwarding\_value  
mpc\_im  
a\_req\_im  
b\_req\_im  
imm\_req\_im  
rd\_req\_im  
mux\_one\_control  
mux\_two\_control  
alu\_control



execution\_stage\_out

b\_req\_out

rd\_req\_out

Merk 21

Register - generie

ALU





## Memory unit



to\_mem\_stage\_req

memory\_stage\_out



## Write Back unit



Datapath

C.U.





IRAM

DRAM

IF



mpc\_out\_bp is an output for datapath.vhd, but an input for fetch\_unit

ID



| OPCODE | RS1   | RS2   | RDST  | FUNC    |
|--------|-------|-------|-------|---------|
| 31     | 26 25 | 21 20 | 16 15 | 11 10 0 |

## Hazard detection

