Go to the documentation of this file.
40 #include "params/StackDistProbe.hh"
45 lineSize(
p.line_size),
46 disableLinearHists(
p.disable_linear_hists),
47 disableLogHists(
p.disable_log_hists),
51 fatal_if(
p.system->cacheLineSize() >
p.line_size,
52 "The stack distance probe must use a cache line size that is "
53 "larger or equal to the system's cahce line size.");
58 :
Stats::Group(parent),
64 "Number of requests with infinite stack distance")
66 using namespace Stats;
68 const StackDistProbeParams &
p =
69 dynamic_cast<const StackDistProbeParams &
>(parent->
params());
72 .
init(
p.linear_hist_bins)
76 .
init(
p.log_hist_bins)
80 .
init(
p.linear_hist_bins)
84 .
init(
p.log_hist_bins)
112 stats.readLinearHist.sample(
sd);
114 stats.writeLinearHist.sample(
sd);
122 stats.readLogHist.sample(sd_lg2);
124 stats.writeLogHist.sample(sd_lg2);
Stats::SparseHistogram readLogHist
T roundDown(const T &val, const U &align)
This function is used to align addresses in memory.
StackDistProbe(const StackDistProbeParams ¶ms)
const bool disableLogHists
Stats::Histogram writeLinearHist
Derived & flags(Flags _flags)
Set the flags and marks this stat to print at the end of simulation.
#define ADD_STAT(n,...)
Convenience macro to add a stat to a statistics group.
std::vector< Info * > stats
Stats::Histogram readLinearHist
std::pair< uint64_t, bool > calcStackDistAndUpdate(const Addr r_address, bool addNewNode=true)
Process the given address:
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Stats::SparseHistogram writeLogHist
const FlagsType nozero
Don't print if this is zero.
static constexpr uint64_t Infinity
A convenient way of refering to infinity.
const bool disableLinearHists
std::enable_if_t< std::is_integral< T >::value, int > floorLog2(T x)
const FlagsType pdf
Print the percent of the total that this entry represents.
SparseHistogram & init(size_type size)
Set the parameters of this histogram.
Histogram & init(size_type size)
Set the parameters of this histogram.
const Params & params() const
void handleRequest(const ProbePoints::PacketInfo &pkt_info) override
Callback to analyse intercepted Packets.
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
StackDistProbeStats(StackDistProbe *parent)
A struct to hold on to the essential fields from a packet, so that the packet and underlying request ...
Base class for memory system probes accepting Packet instances.
Generated on Tue Jun 22 2021 15:28:29 for gem5 by doxygen 1.8.17