Go to the documentation of this file.
   55 #include "debug/HWPrefetch.hh" 
   58 #include "params/StridePrefetcher.hh" 
   83     pcTableInfo(
p.table_assoc, 
p.table_entries, 
p.table_indexing_policy,
 
   84         p.table_replacement_policy)
 
  104     auto insertion_result = 
pcTables.insert(std::make_pair(context,
 
  109     DPRINTF(HWPrefetch, 
"Adding context %i with stride entries\n", context);
 
  112     return &(insertion_result.first->second);
 
  120         DPRINTF(HWPrefetch, 
"Ignoring request with no PC.\n");
 
  136     if (entry != 
nullptr) {
 
  140         int new_stride = pf_addr - entry->
lastAddr;
 
  141         bool stride_match = (new_stride == entry->
stride);
 
  144         if (stride_match && new_stride != 0) {
 
  150                 entry->
stride = new_stride;
 
  154         DPRINTF(HWPrefetch, 
"Hit: PC %x pkt_addr %x (%s) stride %d (%s), " 
  155                 "conf %d\n", 
pc, pf_addr, is_secure ? 
"s" : 
"ns",
 
  156                 new_stride, stride_match ? 
"match" : 
"change",
 
  169             int prefetch_stride = new_stride;
 
  170             if (abs(new_stride) < 
blkSize) {
 
  174             Addr new_addr = pf_addr + 
d * prefetch_stride;
 
  179         DPRINTF(HWPrefetch, 
"Miss: PC %x pkt_addr %x (%s)\n", 
pc, pf_addr,
 
  180                 is_secure ? 
"s" : 
"ns");
 
  193     const Addr hash1 = 
pc >> 1;
 
  195     return (hash1 ^ hash2) & 
setMask;
 
  
std::pair< Addr, int32_t > AddrPriority
StrideEntry(const SatCounter8 &init_confidence)
const bool useRequestorId
const unsigned setMask
Mask out all bits that aren't part of the set index.
unsigned blkSize
The block size of the parent cache.
Copyright (c) 2020 Inria All rights reserved.
Addr getPC() const
Returns the program counter that generated this request.
Copyright (c) 2018 Metempsy Technology Consulting All rights reserved.
PCTable * allocateNewContext(int context)
Create a PC table for the given context.
AssociativeSet< StrideEntry > PCTable
std::unordered_map< int, PCTable > pcTables
const double threshConf
Confidence threshold for prefetch generation.
void calculatePrefetch(const PrefetchInfo &pfi, std::vector< AddrPriority > &addresses) override
Entry * findEntry(Addr addr, bool is_secure) const
Find an entry within the set.
void accessEntry(Entry *entry)
Do an access to the entry, this is required to update the replacement information data.
uint32_t extractSet(const Addr addr) const override
Apply a hash function to calculate address set.
RequestorID getRequestorId() const
Gets the requestor ID that generated this address.
Copyright (c) 2018 Metempsy Technology Consulting All rights reserved.
void insertEntry(Addr addr, bool is_secure, Entry *entry)
Indicate that an entry has just been inserted.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Entry * findVictim(Addr addr)
Find a victim to be replaced.
PCTable * findTable(int context)
Try to find a table of entries for the given context.
bool isSecure() const
Returns true if the address targets the secure memory space.
const int tagShift
The amount to shift the address to get the tag.
Addr extractTag(const Addr addr) const override
Generate the tag from the given address.
virtual void invalidate()
Invalidate the block.
const struct Prefetcher::Stride::PCTableInfo pcTableInfo
Class containing the information needed by the prefetch to train and generate new prefetch requests.
Bitfield< 21, 20 > stride
const SatCounter8 initConfidence
Initial confidence counter value for the pc tables.
ReplacementPolicy::Base *const replacementPolicy
void invalidate() override
Invalidate the block.
double calcSaturation() const
Calculate saturation percentile of the current counter's value with regard to its maximum possible va...
Addr getAddr() const
Obtains the address value of this Prefetcher address.
bool hasPC() const
Returns true if the associated program counter is valid.
Stride(const StridePrefetcherParams &p)
BaseIndexingPolicy *const indexingPolicy
Generated on Tue Jun 22 2021 15:28:29 for gem5 by  doxygen 1.8.17