Go to the documentation of this file.
   46 #ifndef __MEM_CACHE_CACHE_HH__ 
   47 #define __MEM_CACHE_CACHE_HH__ 
   50 #include <unordered_set> 
   92                             Tick request_time) 
override;
 
   96                              Tick request_time) 
override;
 
  119                         bool deferred_response = 
false,
 
  120                         bool pending_downgrade = 
false) 
override;
 
  123                                 bool already_copied, 
bool pending_inval);
 
  138                          bool is_timing, 
bool is_deferred, 
bool pending_inval);
 
  152                                bool is_whole_line_write) 
const override;
 
  177 #endif // __MEM_CACHE_CACHE_HH__ 
  
Miss Status and handling Register.
Cycles handleAtomicReqMiss(PacketPtr pkt, CacheBlk *&blk, PacketList &writebacks) override
Handle a request in atomic mode that missed in this cache.
bool sendMSHRQueuePacket(MSHR *mshr) override
Take an MSHR, turn it into a suitable downstream packet, and send it out.
Tick recvAtomic(PacketPtr pkt) override
Performs the access specified by the request.
PacketPtr evictBlock(CacheBlk *blk) override
Evict a cache block.
void recvTimingSnoopReq(PacketPtr pkt) override
Snoops bus transactions to maintain coherence.
void handleTimingReqMiss(PacketPtr pkt, CacheBlk *blk, Tick forward_time, Tick request_time) override
uint32_t handleSnoop(PacketPtr pkt, CacheBlk *blk, bool is_timing, bool is_deferred, bool pending_inval)
Perform an upward snoop if needed, and update the block state (possibly invalidating the block).
Cycles is a wrapper class for representing cycle counts, i.e.
Tick recvAtomicSnoop(PacketPtr pkt) override
Snoop for the provided request in the cache and return the estimated time taken.
Cache(const CacheParams &p)
Instantiates a basic cache object.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
void handleTimingReqHit(PacketPtr pkt, CacheBlk *blk, Tick request_time) override
void promoteWholeLineWrites(PacketPtr pkt)
Turn line-sized writes into WriteInvalidate transactions.
std::unordered_set< RequestPtr > outstandingSnoop
Store the outstanding requests that we are expecting snoop responses from so we can determine which s...
void serviceMSHRTargets(MSHR *mshr, const PacketPtr pkt, CacheBlk *blk) override
Service non-deferred MSHR targets using the received response.
A coherent cache that can be arranged in flexible topologies.
PacketPtr cleanEvictBlk(CacheBlk *blk)
Create a CleanEvict request for the given block.
PacketPtr createMissPacket(PacketPtr cpu_pkt, CacheBlk *blk, bool needs_writable, bool is_whole_line_write) const override
Create an appropriate downstream bus request packet.
void doWritebacks(PacketList &writebacks, Tick forward_time) override
Insert writebacks into the write buffer.
void recvTimingSnoopResp(PacketPtr pkt) override
Handle a snoop response.
const bool doFastWrites
This cache should allocate a block on a line-sized write miss.
void satisfyRequest(PacketPtr pkt, CacheBlk *blk, bool deferred_response=false, bool pending_downgrade=false) override
Perform any necessary updates to the block and perform any data exchange between the packet and the b...
bool access(PacketPtr pkt, CacheBlk *&blk, Cycles &lat, PacketList &writebacks) override
Does all the processing necessary to perform the provided request.
bool isCachedAbove(PacketPtr pkt, bool is_timing=true)
Send up a snoop request and find cached copies.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
void doWritebacksAtomic(PacketList &writebacks) override
Send writebacks down the memory hierarchy in atomic mode.
void doTimingSupplyResponse(PacketPtr req_pkt, const uint8_t *blk_data, bool already_copied, bool pending_inval)
void recvTimingReq(PacketPtr pkt) override
Performs the access specified by the request.
Generated on Wed May 4 2022 12:13:59 for gem5 by  doxygen 1.8.17