Go to the documentation of this file.
31 #include "debug/HWPrefetch.hh"
32 #include "params/BOPPrefetcher.hh"
43 scoreMax(
p.score_max), roundMax(
p.round_max),
44 badScore(
p.bad_score), rrEntries(
p.rr_size),
45 tagMask((1 <<
p.tag_bits) - 1),
46 delayQueueEnabled(
p.delay_queue_enable),
47 delayQueueSize(
p.delay_queue_size),
48 delayTicks(cyclesToTicks(
p.delay_queue_cycles)),
50 issuePrefetchRequests(
false), bestOffset(1), phaseBestOffset(0),
51 bestScore(0), round(0)
54 fatal(
"%s: number of RR entries is not power of 2\n",
name());
57 fatal(
"%s: cache line size is not power of 2\n",
name());
59 if (!(
p.negative_offsets_enable && (
p.offset_list_size % 2 == 0))) {
60 fatal(
"%s: negative offsets enabled with odd offset list size\n",
64 rrLeft.resize(rrEntries);
65 rrRight.resize(rrEntries);
69 const int factors[] = { 2, 3, 5 };
73 while (
i <
p.offset_list_size)
77 for (
int n : factors) {
84 offsetsList.push_back(OffsetListEntry(offset_i, 0));
88 if (
p.negative_offsets_enable) {
89 offsetsList.push_back(OffsetListEntry(-offset_i, 0));
97 offsetsListIterator = offsetsList.begin();
191 Addr offset_addr = (*offsetsListIterator).first;
192 Addr lookup_addr =
x - offset_addr;
195 if (
testRR(lookup_addr)) {
196 DPRINTF(HWPrefetch,
"Address %#lx found in the RR table\n",
x);
197 (*offsetsListIterator).second++;
198 if ((*offsetsListIterator).second >
bestScore) {
199 bestScore = (*offsetsListIterator).second;
251 DPRINTF(HWPrefetch,
"Generated prefetch %#lx\n", prefetch_addr);
Addr getAddr() const
Obtains the address value of this Prefetcher address.
Tick curTick()
The universal simulation clock.
#define fatal(...)
This implements a cprintf based fatal() function.
const unsigned int badScore
Addr bestOffset
Current best offset to issue prefetches.
unsigned int bestScore
Max score found so far.
std::deque< DelayQueueEntry > delayQueue
void insertIntoDelayQueue(Addr addr)
Insert the specified address into the delay queue.
std::pair< Addr, int32_t > AddrPriority
const unsigned int tagMask
std::vector< OffsetListEntry > offsetsList
In a first implementation of the BO prefetcher, both banks of the RR were written simultaneously when...
static constexpr std::enable_if_t< std::is_integral_v< T >, int > floorLog2(T x)
unsigned int hash(Addr addr, unsigned int way) const
Generate a hash for the specified address to index the RR table.
void schedule(Event &event, Tick when)
static constexpr bool isPowerOf2(const T &n)
void insertIntoRR(Addr addr, unsigned int way)
Insert the specified address into the RR table.
void calculatePrefetch(const PrefetchInfo &pfi, std::vector< AddrPriority > &addresses) override
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
void notifyFill(const PacketPtr &pkt) override
Update the RR right table after a prefetch fill.
BOP(const BOPPrefetcherParams &p)
const unsigned int delayTicks
uint64_t Tick
Tick count type.
const unsigned int scoreMax
Learning phase parameters.
bool isHWPrefetch() const
Addr phaseBestOffset
Current best offset found in the learning phase.
const unsigned int delayQueueSize
std::vector< Addr > rrRight
bool testRR(Addr) const
Test if @X-O is hitting in the RR table to update the offset score.
MemCmd cmd
The command field of the packet.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void delayQueueEventWrapper()
Event to handle the delay queue processing.
GEM5_DEPRECATED_NAMESPACE(GuestABI, guest_abi)
const std::string & name()
const unsigned int rrEntries
Recent requests table parameteres.
unsigned lBlkSize
log_2(block size of the parent cache).
const unsigned int roundMax
EventFunctionWrapper delayQueueEvent
void resetScores()
Reset all the scores from the offset list.
const bool delayQueueEnabled
Delay queue parameters.
unsigned int round
Current round.
void bestOffsetLearning(Addr)
Learning phase of the BOP.
unsigned blkSize
The block size of the parent cache.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
std::vector< Addr > rrLeft
std::vector< OffsetListEntry >::iterator offsetsListIterator
Current test offset index.
Addr tag(Addr addr) const
Generate the tag for the specified address based on the tag bits and the block size.
Class containing the information needed by the prefetch to train and generate new prefetch requests.
bool scheduled() const
Determine if the current event is scheduled.
bool issuePrefetchRequests
Hardware prefetcher enabled.
Generated on Wed Jul 13 2022 10:39:23 for gem5 by doxygen 1.8.17