Go to the documentation of this file.
31 #include "debug/HWPrefetch.hh"
32 #include "params/SBOOEPrefetcher.hh"
43 sequentialPrefetchers(
p.sequential_prefetchers),
44 scoreThreshold((
p.sandbox_entries*
p.score_threshold_pct)/100),
45 latencyBuffer(
p.latency_buffer_size),
46 averageAccessLatency(0), latencyBufferSum(0),
62 if (entry.valid && entry.line ==
addr) {
64 if (entry.expectedArrivalTick >
curTick()) {
132 const bool evaluationFinished =
access(pfi_line);
Addr getAddr() const
Obtains the address value of this Prefetcher address.
Tick curTick()
The universal simulation clock.
Tick latencyBufferSum
Holds the current sum of the latency buffer latency.
unsigned int lateScore
Hits in the sandbox that wouldn't have been filled on time.
bool access(Addr line)
Process an access to the specified line address and update the sandbox counters counters.
std::pair< Addr, int32_t > AddrPriority
const Sandbox * bestSandbox
Current best sandbox.
const int sequentialPrefetchers
Prefetcher parameters.
void access(Addr line, Tick tick)
Update score and insert the line address being accessed into the FIFO queue of the sandbox.
unsigned int score() const
Calculate the useful score.
std::unordered_map< Addr, Tick > demandAddresses
Holds the current demand addresses and tick.
Tick averageAccessLatency
Holds the current average access latency.
void push_back(typename std::vector< T >::value_type val)
Pushes an element at the end of the queue.
bool full() const
Is the queue full? A queue is full if the head is the 0^{th} element and the tail is the (size-1)^{th...
CircularQueue< Tick > latencyBuffer
The latency buffer holds the elapsed ticks between the demand and the fill in the cache for the lates...
CircularQueue< SandboxEntry > entries
FIFO queue containing the sandbox entries.
SBOOE(const SBOOEPrefetcherParams &p)
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
unsigned int sandboxScore
Accesses during the eval period that were present in the sandbox.
uint64_t Tick
Tick count type.
unsigned int accesses
Number of accesses notified to the prefetcher.
Tick expectedArrivalTick
Tick when the simulated prefetch is expected to be filled.
std::vector< Sandbox > sandboxes
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
GEM5_DEPRECATED_NAMESPACE(GuestABI, guest_abi)
const unsigned int scoreThreshold
Threshold used to issue prefetchers.
unsigned lBlkSize
log_2(block size of the parent cache).
bool valid
To indicate if it was initialized.
void calculatePrefetch(const PrefetchInfo &pfi, std::vector< AddrPriority > &addresses) override
void notifyFill(const PacketPtr &pkt) override
Update the latency buffer after a prefetch fill.
const int stride
Sequential stride for this prefetcher.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Class containing the information needed by the prefetch to train and generate new prefetch requests.
Addr line
Cache line predicted by the candidate prefetcher.
Generated on Wed May 4 2022 12:13:59 for gem5 by doxygen 1.8.17