36#include "debug/HWPrefetch.hh" 
   37#include "params/SmsPrefetcher.hh" 
   63    std::pair <Addr,Addr> pc_offset = 
AGTPC[region_base];
 
   64    if (
AGT.find(region_base) != 
AGT.end()) {
 
   66        if (
PHT.find(pc_offset) != 
PHT.end()) {
 
   67            PHT[pc_offset].clear();
 
   70        for (std::set<Addr>::iterator it = 
AGT[region_base].begin();
 
   71         it != 
AGT[region_base].end(); it ++) {
 
   72            PHT[pc_offset].insert(*it);
 
   74        lruPHT.push_front(pc_offset);
 
   82    AGTPC.erase(region_base);
 
   83    AGT.erase(region_base);
 
 
   92        DPRINTF(HWPrefetch, 
"Ignoring request with no PC.\n");
 
  102    if (
AGT.find(region_base) != 
AGT.end()) {
 
  103        assert (
FT.find(region_base) == 
FT.end());
 
  107        for (std::deque <Addr>::iterator lit = 
lruAGT.begin();
 
  108         lit != 
lruAGT.end(); lit ++) {
 
  109            if ((*lit) == region_base) {
 
  111                lruAGT.push_front(region_base);
 
  115    } 
else if (
FT.find(region_base) != 
FT.end()) {
 
  117        AGT[region_base].insert(
FT[region_base].second);
 
  118        AGTPC[region_base] = 
FT[region_base];
 
  119        lruAGT.push_front(region_base);
 
  123        FT.erase(region_base);
 
  133        fifoFT.push_front(region_base);
 
  141    std::pair <Addr, Addr> pc_offset = std::make_pair(
pc,
offset);
 
  142    if (
PHT.find(pc_offset) != 
PHT.end()) {
 
  143        for (std::set<Addr>::iterator it = 
PHT[pc_offset].begin();
 
  144         it != 
PHT[pc_offset].end(); it ++) {
 
  150            if ((*lit) == pc_offset) {
 
  152                    lruPHT.push_front(pc_offset);
 
 
Class containing the information needed by the prefetch to train and generate new prefetch requests.
Addr getPC() const
Returns the program counter that generated this request.
Addr getAddr() const
Obtains the address value of this Prefetcher address.
bool hasPC() const
Returns true if the associated program counter is valid.
Addr blockAddress(Addr a) const
Determine the address of the block in which a lays.
std::list< DeferredPacket >::iterator iterator
Queued(const QueuedPrefetcherParams &p)
std::pair< Addr, int32_t > AddrPriority
std::map< Addr, std::pair< Addr, Addr > > AGTPC
void calculatePrefetch(const PrefetchInfo &pfi, std::vector< AddrPriority > &addresses, const CacheAccessor &cache) override
Sms(const SmsPrefetcherParams &p)
CacheDataUpdateProbeArg EvictionInfo
std::map< Addr, std::pair< Addr, Addr > > FT
std::deque< std::pair< Addr, Addr > > lruPHT
std::deque< Addr > lruAGT
std::map< std::pair< Addr, Addr >, std::set< Addr > > PHT
void notifyEvict(const EvictionInfo &info) override
Notify prefetcher of cache eviction.
std::deque< Addr > fifoFT
std::map< Addr, std::set< Addr > > AGT
const uint64_t MAX_PHTSize
static constexpr T roundDown(const T &val, const U &align)
This function is used to align addresses in memory.
Copyright (c) 2024 Arm Limited All rights reserved.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Describes a SMS prefetcher.
Provides generic cache lookup functions.
Addr addr
The updated block's address.