cache_ctrl.sv: fix two bugs in WB data cache controller
Created by: niwis
This PR resolves two bugs within the write-back data cache controller. Specifically:
Safely kill in-flight miss requests
If we already issued a miss request and are waiting for the critical word to arrive when receiving a kill request, we want to wait for the miss handler to complete before returning to the IDLE
state. Hence, when a miss request might be in-flight (we are in WAIT_REFILL_GNT
or WAIT_CRITICAL_WORD
, do not abort immediately but remember that the request was killed, and discard the critical word after it arrives.
tag_valid
Wait for The load unit can send the tag only after it has translated the virtual address. Depending on the state of the TLB and the time it takes to walk the page table, the tag may be available many cycles after the load request was issued to the cache. Therefore, the cache needs to wait for the req_port_i.tag_valid
signal before it can know whether we have a hit or a miss.
WAIT_TAG
Wait for memory grant if we loose it in It is possible that we loose the memory grant while we wait for a valid tag. So we introduce two more states, WAIT_GNT
and WAIT_GNT_SAVED
. WAIT_GNT
is reached when the memory grant is lost while we wait for a valid tag. It returns to WAIT_TAG
once we have a memory grant again. If the valid tag arrives while we wait for a memory grant in WAIT_GNT
, it is saved and we continue in WAIT_GNT_SAVED
and eventually WAIT_TAG_SAVED
.