



#### Transition signal descriptions

$$\text{hit} = \text{hit\_0} \cdot \text{vic\_flop} + \text{hit\_1} \cdot \text{vic\_flop}$$

$$\text{hit\_valid} = (\text{hit\_0} \wedge \text{valid\_0}) \vee (\text{hit\_1} \wedge \text{valid\_1})$$

$$\text{dirty} = \text{dirty\_0} \cdot \text{vic\_flop} + \text{dirty\_1} \cdot \text{vic\_flop}$$

$$\text{valid} = \text{valid\_0} \cdot \text{vic\_flop} + \text{valid\_1} \cdot \text{vic\_flop}$$

$$\text{wr\_done} = \text{writing to mem is done}$$

$$\text{rd\_done} = \text{reading to mem is done}$$

$$\text{ur\_done\_cache} = \text{done writing to cache}$$

$$\text{rd\_done\_cache} = \text{done reading from cache}$$

vicinuiflop = 0 or 1.  
 invert on rega or  
 write. 0 victimizes  
 cache 0. 1 victimizes  
 cache 1.

#### state descriptions

- compare read: compare read will victimize the cache and find the victim blk in the victim cache accordingly
- compare write: compare write will victimize the cache and find the victim blk in the victim cache accordingly

- victim cache can be cache\_0 or cache\_1 due to replacement policy