Go to the documentation of this file.
45 #ifndef __MEM_CACHE_MSHR_QUEUE_HH__
46 #define __MEM_CACHE_MSHR_QUEUE_HH__
81 MSHRQueue(
const std::string &_label,
int num_entries,
int reserve,
82 int demand_reserve, std::string cache_name);
100 Tick when_ready,
Counter order,
bool alloc_on_fill);
168 #endif //__MEM_CACHE_MSHR_QUEUE_HH__
Miss Status and handling Register.
void moveToFront(MSHR *mshr)
Moves the MSHR to the front of the pending list if it is not in service.
bool havePending() const
Returns true if the pending list is not empty.
bool canPrefetch() const
Returns true if sufficient mshrs for prefetch.
MSHR ::List readyList
Holds pointers to entries that haven't been sent downstream.
void delay(MSHR *mshr, Tick delay_ticks)
Adds a delay to the provided MSHR and moves MSHRs that will be ready earlier than this entry to the t...
void markInService(MSHR *mshr, bool pending_modified_resp)
Mark the given MSHR as in service.
const int numReserve
The number of entries to hold as a temporary overflow space.
const int numEntries
The total number of entries in this queue.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
MSHR * allocate(Addr blk_addr, unsigned blk_size, PacketPtr pkt, Tick when_ready, Counter order, bool alloc_on_fill)
Allocates a new MSHR for the request and size.
const int demandReserve
The number of entries to reserve for future demand accesses.
A high-level queue interface, to be used by both the MSHR queue and the write buffer.
bool forceDeallocateTarget(MSHR *mshr)
Deallocate top target, possibly freeing the MSHR.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void markPending(MSHR *mshr)
Mark an in service entry as pending, used to resend a request.
void deallocate(MSHR *mshr) override
Deallocate a MSHR and its targets.
MSHRQueue(const std::string &_label, int num_entries, int reserve, int demand_reserve, std::string cache_name)
Create a queue with a given number of entries.
double Counter
All counters are of 64-bit values.
A Class for maintaining a list of pending and allocated memory requests.
int allocated
The number of currently allocated entries.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Generated on Thu Jun 16 2022 10:41:55 for gem5 by doxygen 1.8.17