## Modified Cache FSM with Basic OLB Prefetching

### Default Signals:

way\_sel = 0 tag\_sel = 0 read\_from\_mem = 0 write\_to\_mem = 0 load\_cache = 0 load\_lru = 0 source\_sel = 0 read\_cache\_data = 1

#### Idle

-Used for nothing (no read or write)

#### Read\_cache\_data

-After receiving a request to read/write, we must read from the cache to have tag/data/dirty/valid available

read\_cache\_data = 1 read\_lru = 1

#### Write\_back (same for prefetch + regular)

-Used when cache is full and data must be written to mem (dirty=1) before getting new data block from memory

write\_to\_mem = 1 way\_sel = lru\_out tag\_sel = 0

### Respond\_to\_CPU

-Once we know we have a hit, write to cache if needed, and respond to cpu

mem\_resp = 1

way\_sel = hit\_0

load\_lru = 1

load\_cache = mem\_write

source\_sel = 0 (cpu)

Load\_Data\_From\_Mem (same for prefetch +

-If we have a miss, we need to load a block of memory into the cache

read\_from\_mem = 1 way\_sel = lru\_out tag\_sel = 1

# Load\_Data\_Into\_Cache (same for prefetch + regular)

-Need a cycle to put memory into cache

load\_cache = 1 source\_sel = 1 (memory)

#### **Check Cache for Prefetch Data**

-As title. Uses default signals like Idle

