Go to the documentation of this file.
   46 #ifndef __MEM_CACHE_TAGS_FA_LRU_HH__ 
   47 #define __MEM_CACHE_TAGS_FA_LRU_HH__ 
   52 #include <unordered_map> 
   63 #include "params/FALRU.hh" 
  102     std::string 
print() 
const override;
 
  127         template <
class T1, 
class T2>
 
  130             return std::hash<T1>()(
p.first) ^ std::hash<T2>()(
p.second);
 
  134     typedef std::unordered_map<TagHashKey, FALRUBlk *, PairHash> 
TagHash;
 
  221                          const std::size_t 
size,
 
  264             if (visitor(
blks[
i])) {
 
  376 #endif // __MEM_CACHE_TAGS_FA_LRU_HH__ 
  
This is a simple scalar statistic, like a counter.
statistics::Vector hits
Hits in each cache.
const CachesMask inAllCachesMask
A mask for all cache being tracked.
std::size_t operator()(const std::pair< T1, T2 > &p) const
const unsigned blkSize
The size of the cache block.
ReplaceableEntry * findBlockBySetAndWay(int set, int way) const override
Find a block given set and way.
FALRUBlk BlkType
Typedef the block type used in this class.
statistics::Scalar accesses
Total number of accesses.
const int numTrackedCaches
The number of different size caches being tracked.
void moveToHead(FALRUBlk *blk)
Move a cache block to the MRU position.
std::string print() const override
Pretty-print inCachesMask and other CacheBlk information.
FALRU(const Params &p)
Construct and initialize this cache tagstore.
A vector of scalar stats.
virtual Addr getTag() const
Get tag associated to this block.
void invalidate(CacheBlk *blk) override
Invalidate a cache block.
const unsigned minTrackedSize
The smallest cache we are tracking.
Cycles is a wrapper class for representing cycle counts, i.e.
statistics::Vector misses
Misses in each cache.
FALRUBlk * blks
The cache blocks.
CacheBlk * findBlock(Addr addr, bool is_secure) const override
Find the block in the cache, do not update the replacement data.
Hash table type mapping addresses to cache block pointers.
void recordAccess(FALRUBlk *blk)
Notify of a block access.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
void init(FALRUBlk *head, FALRUBlk *tail)
Initialiaze cache blocks and the tracking mechanism.
void moveBlockToHead(FALRUBlk *blk)
Update boundaries as a block will be moved to the MRU.
Addr extractTag(Addr addr) const override
Generate the tag from the addres.
std::pair< Addr, bool > TagHashKey
FALRUBlk * head
The MRU block.
std::unordered_map< TagHashKey, FALRUBlk *, PairHash > TagHash
CachesMask inCachesMask
A bit mask of the caches that fit this block.
CacheTracking cacheTracking
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Addr regenerateBlkAddr(const CacheBlk *blk) const override
Regenerate the block address from the tag.
std::vector< FALRUBlk * > boundaries
Array of pointers to blocks at the cache boundaries.
FALRUBlk * next
The next block in LRU order.
CacheBlk * accessBlock(const PacketPtr pkt, Cycles &lat, CachesMask *in_cache_mask)
Access block and update replacement data.
Mechanism that allows us to simultaneously collect miss statistics for multiple caches.
bool anyBlk(std::function< bool(CacheBlk &)> visitor) override
Find if any of the blocks satisfies a condition.
TagHash tagHash
The address hash table.
void moveBlock(CacheBlk *src_blk, CacheBlk *dest_blk) override
Move a block's metadata to another location decided by the replacement policy.
FALRUBlk * tail
The LRU block.
FALRUBlk * prev
The previous block in LRU order.
A replaceable entry is a basic entry in a 2d table-like structure that needs to have replacement func...
void moveBlockToTail(FALRUBlk *blk)
Update boundaries as a block will be moved to the LRU.
void insertBlock(const PacketPtr pkt, CacheBlk *blk) override
Insert the new block into the cache and update replacement data.
CacheBlk * findVictim(Addr addr, const bool is_secure, const std::size_t size, std::vector< CacheBlk * > &evict_blks) override
Find replacement victim based on address.
void forEachBlk(std::function< void(CacheBlk &)> visitor) override
Visit each block in the tags and apply a visitor.
A fully associative LRU cache.
void moveToTail(FALRUBlk *blk)
Move a cache block to the LRU position.
CacheTracking(unsigned min_size, unsigned max_size, unsigned block_size, statistics::Group *parent)
void check(const FALRUBlk *head, const FALRUBlk *tail) const
Check that the tracking mechanism is in consistent state.
void tagsInit() override
Initialize blocks as FALRUBlk instances.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
A fully associative cache block.
Generated on Tue Sep 21 2021 12:25:30 for gem5 by  doxygen 1.8.17