From 67e45b872a0bd268e3ce4158c25c6f27e8b0d42e Mon Sep 17 00:00:00 2001 From: Daniel Date: Sun, 11 Nov 2018 11:55:37 +0100 Subject: mem-cache: Cleanup prefetchers Prefetcher code had extra variables, dependencies that could be removed, code duplication, and missing overrides. Change-Id: I6e9fbf67a0bdab7eb591893039e088261f52d31a Signed-off-by: Daniel Reviewed-on: https://gem5-review.googlesource.com/c/14355 Reviewed-by: Nikos Nikoleris Maintainer: Nikos Nikoleris --- src/mem/cache/prefetch/Prefetcher.py | 6 ++++++ src/mem/cache/prefetch/base.cc | 19 +++++++------------ src/mem/cache/prefetch/base.hh | 23 +++++++++++------------ src/mem/cache/prefetch/queued.cc | 5 ++--- src/mem/cache/prefetch/queued.hh | 14 ++++++-------- src/mem/cache/prefetch/stride.cc | 3 --- src/mem/cache/prefetch/stride.hh | 2 +- src/mem/cache/prefetch/tagged.cc | 2 +- src/mem/cache/prefetch/tagged.hh | 4 ++-- 9 files changed, 36 insertions(+), 42 deletions(-) (limited to 'src') diff --git a/src/mem/cache/prefetch/Prefetcher.py b/src/mem/cache/prefetch/Prefetcher.py index 316a6d0ba..09717dff7 100644 --- a/src/mem/cache/prefetch/Prefetcher.py +++ b/src/mem/cache/prefetch/Prefetcher.py @@ -65,6 +65,9 @@ class BasePrefetcher(ClockedObject): ] sys = Param.System(Parent.any, "System this prefetcher belongs to") + # Get the block size from the parent (system) + block_size = Param.Int(Parent.cache_line_size, "Block size in bytes") + on_miss = Param.Bool(False, "Only notify prefetcher on misses") on_read = Param.Bool(True, "Notify prefetcher on reads") on_write = Param.Bool(True, "Notify prefetcher on writes") @@ -109,6 +112,9 @@ class StridePrefetcher(QueuedPrefetcher): cxx_class = 'StridePrefetcher' cxx_header = "mem/cache/prefetch/stride.hh" + # Do not consult stride prefetcher on instruction accesses + on_inst = False + max_conf = Param.Int(7, "Maximum confidence level") thresh_conf = Param.Int(4, "Threshold confidence level") min_conf = Param.Int(0, "Minimum confidence level") diff --git a/src/mem/cache/prefetch/base.cc b/src/mem/cache/prefetch/base.cc index 41c02ac72..3f5b67e6a 100644 --- a/src/mem/cache/prefetch/base.cc +++ b/src/mem/cache/prefetch/base.cc @@ -63,11 +63,10 @@ BasePrefetcher::PrefetchListener::notify(const PacketPtr &pkt) } BasePrefetcher::BasePrefetcher(const BasePrefetcherParams *p) - : ClockedObject(p), listeners(), cache(nullptr), blkSize(0), lBlkSize(0), - system(p->sys), onMiss(p->on_miss), onRead(p->on_read), + : ClockedObject(p), listeners(), cache(nullptr), blkSize(p->block_size), + lBlkSize(floorLog2(blkSize)), onMiss(p->on_miss), onRead(p->on_read), onWrite(p->on_write), onData(p->on_data), onInst(p->on_inst), - masterId(system->getMasterId(this)), - pageBytes(system->getPageBytes()), + masterId(p->sys->getMasterId(this)), pageBytes(p->sys->getPageBytes()), prefetchOnAccess(p->prefetch_on_access) { } @@ -77,6 +76,8 @@ BasePrefetcher::setCache(BaseCache *_cache) { assert(!cache); cache = _cache; + + // If the cache has a different block size from the system's, save it blkSize = cache->getBlockSize(); lBlkSize = floorLog2(blkSize); } @@ -121,19 +122,13 @@ BasePrefetcher::observeAccess(const PacketPtr &pkt) const bool BasePrefetcher::inCache(Addr addr, bool is_secure) const { - if (cache->inCache(addr, is_secure)) { - return true; - } - return false; + return cache->inCache(addr, is_secure); } bool BasePrefetcher::inMissQueue(Addr addr, bool is_secure) const { - if (cache->inMissQueue(addr, is_secure)) { - return true; - } - return false; + return cache->inMissQueue(addr, is_secure); } bool diff --git a/src/mem/cache/prefetch/base.hh b/src/mem/cache/prefetch/base.hh index 394c85c94..813d1b9a4 100644 --- a/src/mem/cache/prefetch/base.hh +++ b/src/mem/cache/prefetch/base.hh @@ -60,7 +60,6 @@ class BaseCache; struct BasePrefetcherParams; -class System; class BasePrefetcher : public ClockedObject { @@ -90,26 +89,23 @@ class BasePrefetcher : public ClockedObject /** log_2(block size of the parent cache). */ unsigned lBlkSize; - /** System we belong to */ - System* system; - /** Only consult prefetcher on cache misses? */ - bool onMiss; + const bool onMiss; /** Consult prefetcher on reads? */ - bool onRead; + const bool onRead; /** Consult prefetcher on reads? */ - bool onWrite; + const bool onWrite; /** Consult prefetcher on data accesses? */ - bool onData; + const bool onData; /** Consult prefetcher on instruction accesses? */ - bool onInst; + const bool onInst; /** Request id for prefetches */ - MasterID masterId; + const MasterID masterId; const Addr pageBytes; @@ -147,7 +143,7 @@ class BasePrefetcher : public ClockedObject virtual ~BasePrefetcher() {} - virtual void setCache(BaseCache *_cache); + void setCache(BaseCache *_cache); /** * Notify prefetcher of cache access (may be any access or just @@ -159,7 +155,10 @@ class BasePrefetcher : public ClockedObject virtual Tick nextPrefetchReadyTime() const = 0; - virtual void regStats(); + /** + * Register local statistics. + */ + void regStats() override; /** * Register probe points for this object. diff --git a/src/mem/cache/prefetch/queued.cc b/src/mem/cache/prefetch/queued.cc index f9a036d45..ce14b5ac5 100644 --- a/src/mem/cache/prefetch/queued.cc +++ b/src/mem/cache/prefetch/queued.cc @@ -91,9 +91,8 @@ QueuedPrefetcher::notify(const PacketPtr &pkt) // Queue up generated prefetches for (AddrPriority& pf_info : addresses) { - // Block align prefetch address - pf_info.first &= ~(Addr)(blkSize - 1); + pf_info.first = blockAddress(pf_info.first); pfIdentified++; DPRINTF(HWPrefetch, "Found a pf candidate addr: %#x, " @@ -131,7 +130,7 @@ QueuedPrefetcher::getPacket() return pkt; } -std::list::const_iterator +QueuedPrefetcher::const_iterator QueuedPrefetcher::inPrefetch(Addr address, bool is_secure) const { for (const_iterator dp = pfq.begin(); dp != pfq.end(); dp++) { diff --git a/src/mem/cache/prefetch/queued.hh b/src/mem/cache/prefetch/queued.hh index 811818fdc..774e6ede8 100644 --- a/src/mem/cache/prefetch/queued.hh +++ b/src/mem/cache/prefetch/queued.hh @@ -98,11 +98,9 @@ class QueuedPrefetcher : public BasePrefetcher const bool tagPrefetch; using const_iterator = std::list::const_iterator; - std::list::const_iterator inPrefetch(Addr address, - bool is_secure) const; + const_iterator inPrefetch(Addr address, bool is_secure) const; using iterator = std::list::iterator; - std::list::iterator inPrefetch(Addr address, - bool is_secure); + iterator inPrefetch(Addr address, bool is_secure); // STATS Stats::Scalar pfIdentified; @@ -116,19 +114,19 @@ class QueuedPrefetcher : public BasePrefetcher virtual ~QueuedPrefetcher(); void notify(const PacketPtr &pkt) override; + PacketPtr insert(AddrPriority& info, bool is_secure); - // Note: This should really be pure virtual, but doesnt go well with params virtual void calculatePrefetch(const PacketPtr &pkt, std::vector &addresses) = 0; - PacketPtr getPacket(); + PacketPtr getPacket() override; - Tick nextPrefetchReadyTime() const + Tick nextPrefetchReadyTime() const override { return pfq.empty() ? MaxTick : pfq.front().tick; } - void regStats(); + void regStats() override; }; #endif //__MEM_CACHE_PREFETCH_QUEUED_HH__ diff --git a/src/mem/cache/prefetch/stride.cc b/src/mem/cache/prefetch/stride.cc index efe982af2..3cea78ed7 100644 --- a/src/mem/cache/prefetch/stride.cc +++ b/src/mem/cache/prefetch/stride.cc @@ -69,9 +69,6 @@ StridePrefetcher::StridePrefetcher(const StridePrefetcherParams *p) degree(p->degree), pcTable(pcTableAssoc, pcTableSets, name()) { - // Don't consult stride prefetcher on instruction accesses - onInst = false; - assert(isPowerOf2(pcTableSets)); } diff --git a/src/mem/cache/prefetch/stride.hh b/src/mem/cache/prefetch/stride.hh index 55cdbc86d..03ceec584 100644 --- a/src/mem/cache/prefetch/stride.hh +++ b/src/mem/cache/prefetch/stride.hh @@ -119,7 +119,7 @@ class StridePrefetcher : public QueuedPrefetcher StridePrefetcher(const StridePrefetcherParams *p); void calculatePrefetch(const PacketPtr &pkt, - std::vector &addresses); + std::vector &addresses) override; }; #endif // __MEM_CACHE_PREFETCH_STRIDE_HH__ diff --git a/src/mem/cache/prefetch/tagged.cc b/src/mem/cache/prefetch/tagged.cc index abe6b9dca..7561633da 100644 --- a/src/mem/cache/prefetch/tagged.cc +++ b/src/mem/cache/prefetch/tagged.cc @@ -47,7 +47,7 @@ void TaggedPrefetcher::calculatePrefetch(const PacketPtr &pkt, std::vector &addresses) { - Addr blkAddr = pkt->getAddr() & ~(Addr)(blkSize-1); + Addr blkAddr = pkt->getBlockAddr(blkSize); for (int d = 1; d <= degree; d++) { Addr newAddr = blkAddr + d*(blkSize); diff --git a/src/mem/cache/prefetch/tagged.hh b/src/mem/cache/prefetch/tagged.hh index 95162aa45..8dd8b77b4 100644 --- a/src/mem/cache/prefetch/tagged.hh +++ b/src/mem/cache/prefetch/tagged.hh @@ -44,7 +44,7 @@ struct TaggedPrefetcherParams; class TaggedPrefetcher : public QueuedPrefetcher { protected: - int degree; + const int degree; public: TaggedPrefetcher(const TaggedPrefetcherParams *p); @@ -52,7 +52,7 @@ class TaggedPrefetcher : public QueuedPrefetcher ~TaggedPrefetcher() {} void calculatePrefetch(const PacketPtr &pkt, - std::vector &addresses); + std::vector &addresses) override; }; #endif // __MEM_CACHE_PREFETCH_TAGGED_HH__ -- cgit v1.2.3