gem5 v23.0.0.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
fa_lru.hh
Go to the documentation of this file.
1/*
2 * Copyright (c) 2012-2013,2016,2018 ARM Limited
3 * All rights reserved.
4 *
5 * The license below extends only to copyright in the software and shall
6 * not be construed as granting a license to any other intellectual
7 * property including but not limited to intellectual property relating
8 * to a hardware implementation of the functionality of the software
9 * licensed hereunder. You may use the software subject to the license
10 * terms below provided that you ensure that this notice is replicated
11 * unmodified and in its entirety in all distributions of the software,
12 * modified or unmodified, in source code or in binary form.
13 *
14 * Copyright (c) 2003-2005 The Regents of The University of Michigan
15 * All rights reserved.
16 *
17 * Redistribution and use in source and binary forms, with or without
18 * modification, are permitted provided that the following conditions are
19 * met: redistributions of source code must retain the above copyright
20 * notice, this list of conditions and the following disclaimer;
21 * redistributions in binary form must reproduce the above copyright
22 * notice, this list of conditions and the following disclaimer in the
23 * documentation and/or other materials provided with the distribution;
24 * neither the name of the copyright holders nor the names of its
25 * contributors may be used to endorse or promote products derived from
26 * this software without specific prior written permission.
27 *
28 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
29 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
30 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
31 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
32 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
33 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
34 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
35 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
36 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
37 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
38 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
39 */
40
46#ifndef __MEM_CACHE_TAGS_FA_LRU_HH__
47#define __MEM_CACHE_TAGS_FA_LRU_HH__
48
49#include <cstdint>
50#include <functional>
51#include <string>
52#include <unordered_map>
53#include <vector>
54
55#include "base/bitfield.hh"
56#include "base/intmath.hh"
57#include "base/logging.hh"
58#include "base/statistics.hh"
59#include "base/types.hh"
62#include "mem/packet.hh"
63#include "params/FALRU.hh"
64
65namespace gem5
66{
67
68// Uncomment to enable sanity checks for the FALRU cache and the
69// TrackedCaches class
70//#define FALRU_DEBUG
71
72class BaseCache;
73class ReplaceableEntry;
74
75// A bitmask of the caches we are keeping track of. Currently the
76// lowest bit is the smallest cache we are tracking, as it is
77// specified by the corresponding parameter. The rest of the bits are
78// for exponentially growing cache sizes.
79typedef uint32_t CachesMask;
80
84class FALRUBlk : public CacheBlk
85{
86 public:
87 FALRUBlk() : CacheBlk(), prev(nullptr), next(nullptr), inCachesMask(0) {}
88
93
96
102 std::string print() const override;
103};
104
109class FALRU : public BaseTags
110{
111 public:
114
115 protected:
118
123
125 struct PairHash
126 {
127 template <class T1, class T2>
128 std::size_t operator()(const std::pair<T1, T2> &p) const
129 {
130 return std::hash<T1>()(p.first) ^ std::hash<T2>()(p.second);
131 }
132 };
134 typedef std::unordered_map<TagHashKey, FALRUBlk *, PairHash> TagHash;
135
138
144 void moveToHead(FALRUBlk *blk);
145
151 void moveToTail(FALRUBlk *blk);
152
153 public:
154 typedef FALRUParams Params;
155
159 FALRU(const Params &p);
160 ~FALRU();
161
165 void tagsInit() override;
166
171 void invalidate(CacheBlk *blk) override;
172
184 CacheBlk* accessBlock(const PacketPtr pkt, Cycles &lat,
185 CachesMask *in_cache_mask);
186
190 CacheBlk* accessBlock(const PacketPtr pkt, Cycles &lat) override;
191
199 CacheBlk* findBlock(Addr addr, bool is_secure) const override;
200
208 ReplaceableEntry* findBlockBySetAndWay(int set, int way) const override;
209
220 CacheBlk* findVictim(Addr addr, const bool is_secure,
221 const std::size_t size,
222 std::vector<CacheBlk*>& evict_blks) override;
223
230 void insertBlock(const PacketPtr pkt, CacheBlk *blk) override;
231
232 void moveBlock(CacheBlk *src_blk, CacheBlk *dest_blk) override;
233
240 Addr extractTag(Addr addr) const override
241 {
242 return blkAlign(addr);
243 }
244
251 Addr regenerateBlkAddr(const CacheBlk* blk) const override
252 {
253 return blk->getTag();
254 }
255
256 void forEachBlk(std::function<void(CacheBlk &)> visitor) override {
257 for (int i = 0; i < numBlocks; i++) {
258 visitor(blks[i]);
259 }
260 }
261
262 bool anyBlk(std::function<bool(CacheBlk &)> visitor) override {
263 for (int i = 0; i < numBlocks; i++) {
264 if (visitor(blks[i])) {
265 return true;
266 }
267 }
268 return false;
269 }
270
271 private:
279 {
280 public:
281 CacheTracking(unsigned min_size, unsigned max_size,
282 unsigned block_size, statistics::Group *parent);
283
292 void init(FALRUBlk *head, FALRUBlk *tail);
293
303 void moveBlockToHead(FALRUBlk *blk);
304
314 void moveBlockToTail(FALRUBlk *blk);
315
326 void recordAccess(FALRUBlk *blk);
327
338 void check(const FALRUBlk *head, const FALRUBlk *tail) const;
339
340 private:
342 const unsigned blkSize;
344 const unsigned minTrackedSize;
351
352 protected:
366
370 };
372};
373
374} // namespace gem5
375
376#endif // __MEM_CACHE_TAGS_FA_LRU_HH__
Defines global host-dependent types: Counter, Tick, and (indirectly) {int,uint}{8,...
Definitions of a simple cache block class.
A common base class of Cache tagstore objects.
Definition base.hh:74
Addr blkAlign(Addr addr) const
Align an address to the block size.
Definition base.hh:215
const unsigned size
The size of the cache.
Definition base.hh:81
const unsigned numBlocks
the number of blocks in the cache
Definition base.hh:100
A Basic Cache block.
Definition cache_blk.hh:71
Cycles is a wrapper class for representing cycle counts, i.e.
Definition types.hh:79
A fully associative cache block.
Definition fa_lru.hh:85
FALRUBlk * next
The next block in LRU order.
Definition fa_lru.hh:92
FALRUBlk * prev
The previous block in LRU order.
Definition fa_lru.hh:90
std::string print() const override
Pretty-print inCachesMask and other CacheBlk information.
Definition fa_lru.cc:62
CachesMask inCachesMask
A bit mask of the caches that fit this block.
Definition fa_lru.hh:95
Mechanism that allows us to simultaneously collect miss statistics for multiple caches.
Definition fa_lru.hh:279
void check(const FALRUBlk *head, const FALRUBlk *tail) const
Check that the tracking mechanism is in consistent state.
Definition fa_lru.cc:335
void recordAccess(FALRUBlk *blk)
Notify of a block access.
Definition fa_lru.cc:441
const CachesMask inAllCachesMask
A mask for all cache being tracked.
Definition fa_lru.hh:348
void moveBlockToHead(FALRUBlk *blk)
Update boundaries as a block will be moved to the MRU.
Definition fa_lru.cc:390
void moveBlockToTail(FALRUBlk *blk)
Update boundaries as a block will be moved to the LRU.
Definition fa_lru.cc:416
std::vector< FALRUBlk * > boundaries
Array of pointers to blocks at the cache boundaries.
Definition fa_lru.hh:350
const unsigned blkSize
The size of the cache block.
Definition fa_lru.hh:342
const unsigned minTrackedSize
The smallest cache we are tracking.
Definition fa_lru.hh:344
const int numTrackedCaches
The number of different size caches being tracked.
Definition fa_lru.hh:346
A fully associative LRU cache.
Definition fa_lru.hh:110
std::pair< Addr, bool > TagHashKey
Definition fa_lru.hh:133
void moveToTail(FALRUBlk *blk)
Move a cache block to the LRU position.
Definition fa_lru.cc:260
std::unordered_map< TagHashKey, FALRUBlk *, PairHash > TagHash
Definition fa_lru.hh:134
CacheBlk * accessBlock(const PacketPtr pkt, Cycles &lat, CachesMask *in_cache_mask)
Access block and update replacement data.
Definition fa_lru.cc:140
TagHash tagHash
The address hash table.
Definition fa_lru.hh:137
Addr extractTag(Addr addr) const override
Generate the tag from the addres.
Definition fa_lru.hh:240
bool anyBlk(std::function< bool(CacheBlk &)> visitor) override
Find if any of the blocks satisfies a condition.
Definition fa_lru.hh:262
FALRUBlk BlkType
Typedef the block type used in this class.
Definition fa_lru.hh:113
void forEachBlk(std::function< void(CacheBlk &)> visitor) override
Visit each block in the tags and apply a visitor.
Definition fa_lru.hh:256
ReplaceableEntry * findBlockBySetAndWay(int set, int way) const override
Find a block given set and way.
Definition fa_lru.cc:186
void moveBlock(CacheBlk *src_blk, CacheBlk *dest_blk) override
Move a block's metadata to another location decided by the replacement policy.
Definition fa_lru.cc:227
void invalidate(CacheBlk *blk) override
Invalidate a cache block.
Definition fa_lru.cc:114
void moveToHead(FALRUBlk *blk)
Move a cache block to the MRU position.
Definition fa_lru.cc:233
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.
Definition fa_lru.cc:193
Addr regenerateBlkAddr(const CacheBlk *blk) const override
Regenerate the block address from the tag.
Definition fa_lru.hh:251
CacheBlk * findBlock(Addr addr, bool is_secure) const override
Find the block in the cache, do not update the replacement data.
Definition fa_lru.cc:167
CacheTracking cacheTracking
Definition fa_lru.hh:371
void tagsInit() override
Initialize blocks as FALRUBlk instances.
Definition fa_lru.cc:87
FALRUBlk * tail
The LRU block.
Definition fa_lru.hh:122
FALRUParams Params
Definition fa_lru.hh:154
FALRUBlk * head
The MRU block.
Definition fa_lru.hh:120
void insertBlock(const PacketPtr pkt, CacheBlk *blk) override
Insert the new block into the cache and update replacement data.
Definition fa_lru.cc:206
FALRUBlk * blks
The cache blocks.
Definition fa_lru.hh:117
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
Definition packet.hh:295
A replaceable entry is a basic entry in a 2d table-like structure that needs to have replacement func...
virtual Addr getTag() const
Get tag associated to this block.
Statistics container.
Definition group.hh:93
This is a simple scalar statistic, like a counter.
A vector of scalar stats.
STL pair class.
Definition stl.hh:58
STL vector class.
Definition stl.hh:37
statistics::Vector hits
Hits in each cache.
Definition fa_lru.hh:361
statistics::Vector misses
Misses in each cache.
Definition fa_lru.hh:363
statistics::Scalar accesses
Total number of accesses.
Definition fa_lru.hh:365
Declaration of a common base class for cache tagstore objects.
Bitfield< 7 > i
Definition misc_types.hh:67
Bitfield< 12, 11 > set
Bitfield< 0 > p
Bitfield< 3 > addr
Definition types.hh:84
const FlagsType init
This Stat is Initialized.
Definition info.hh:55
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Definition types.hh:147
uint32_t CachesMask
Definition fa_lru.hh:79
Declaration of the Packet class.
Declaration of Statistics objects.
Hash table type mapping addresses to cache block pointers.
Definition fa_lru.hh:126
std::size_t operator()(const std::pair< T1, T2 > &p) const
Definition fa_lru.hh:128

Generated on Mon Jul 10 2023 14:24:32 for gem5 by doxygen 1.9.7