36#include "debug/HWPrefetch.hh"
37#include "params/SmsPrefetcher.hh"
46 :
Queued(
p), Max_Contexts(
p.ft_size), MAX_PHTSize(
p.pht_size),
47 Region_Size(
p.region_size)
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
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)
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.
A data contents update is composed of the updated block's address, the old contents,...
Addr addr
The updated block's address.