Go to the documentation of this file.
47 #include <sys/types.h>
57 #include "mem/ruby/protocol/MachineType.hh"
58 #include "mem/ruby/protocol/RubyRequest.hh"
80 using m5::stl_helpers::operator<<;
83 : m_ruby_system(
rs), m_hot_lines(
p.hot_lines),
84 m_all_instructions(
p.all_instructions),
85 m_num_vnets(
p.number_of_virtual_networks),
86 rubyProfilerStats(
rs, this)
105 :
Stats::Group(parent),
106 perRequestTypeStats(parent),
107 perMachineTypeStats(parent),
108 perRequestTypeMachineTypeStats(parent),
109 ADD_STAT(delayHistogram,
"delay histogram for all message"),
110 ADD_STAT(m_outstandReqHistSeqr,
""),
111 ADD_STAT(m_outstandReqHistCoalsr,
""),
115 ADD_STAT(m_missLatencyHistSeqr,
""),
116 ADD_STAT(m_missLatencyHistCoalsr,
"")
126 .name(
csprintf(
"delayVCHist.vnet_%i",
i))
127 .desc(
csprintf(
"delay histogram for vnet_%i",
i))
162 :
Stats::Group(parent,
"RequestType")
164 for (
int i = 0;
i < RubyRequestType_NUM;
i++) {
168 .name(
csprintf(
"%s.latency_hist_seqr", RubyRequestType(
i)))
175 .name(
csprintf(
"%s.latency_hist_coalsr", RubyRequestType(
i)))
182 .name(
csprintf(
"%s.hit_latency_hist_seqr", RubyRequestType(
i)))
189 .name(
csprintf(
"%s.miss_latency_hist_seqr", RubyRequestType(
i)))
196 .name(
csprintf(
"%s.miss_latency_hist_coalsr", RubyRequestType(
i)))
206 for (
int i = 0;
i < MachineType_NUM;
i++) {
210 .name(
csprintf(
"%s.hit_mach_latency_hist_seqr", MachineType(
i)))
217 .name(
csprintf(
"%s.miss_mach_latency_hist_seqr", MachineType(
i)))
224 .name(
csprintf(
"%s.miss_mach_latency_hist_coalsr",
233 "%s.miss_latency_hist_seqr.issue_to_initial_request",
242 "%s.miss_latency_hist_coalsr.issue_to_initial_request",
250 .name(
csprintf(
"%s.miss_latency_hist_seqr.initial_to_forward",
259 .name(
csprintf(
"%s.miss_latency_hist_coalsr.initial_to_forward",
270 "%s.miss_latency_hist_seqr.forward_to_first_response",
280 "%s.miss_latency_hist_coalsr.forward_to_first_response",
290 "%s.miss_latency_hist_seqr.first_response_to_completion",
300 "%s.miss_latency_hist_coalsr.first_response_to_completion",
307 ->name(
csprintf(
"%s.incomplete_times_seqr", MachineType(
i)))
316 :
Stats::
Group(parent,
"RequestTypeMachineType")
318 for (
int i = 0;
i < RubyRequestType_NUM;
i++) {
326 for (
int j = 0;
j < MachineType_NUM;
j++) {
331 .name(
csprintf(
"%s.%s.hit_type_mach_latency_hist_seqr",
332 RubyRequestType(
i), MachineType(
j)))
340 .name(
csprintf(
"%s.%s.miss_type_mach_latency_hist_seqr",
341 RubyRequestType(
i), MachineType(
j)))
349 .name(
csprintf(
"%s.%s.miss_type_mach_latency_hist_coalsr",
350 RubyRequestType(
i), MachineType(
j)))
368 for (uint32_t
i = 0;
i < MachineType_NUM;
i++) {
369 for (std::map<uint32_t, AbstractController*>::iterator it =
383 for (uint32_t
i = 0;
i < MachineType_NUM;
i++) {
384 for (std::map<uint32_t, AbstractController*>::iterator it =
404 for (uint32_t
i = 0;
i < MachineType_NUM;
i++) {
405 for (std::map<uint32_t, AbstractController*>::iterator it =
421 for (uint32_t
j = 0;
j < RubyRequestType_NUM; ++
j) {
437 for (uint32_t
j = 0;
j < MachineType_NUM; ++
j) {
456 ->getInitialToForwardDelayHist(MachineType(
j)));
461 ->getForwardRequestToFirstResponseHist(
468 ->getFirstResponseToCompletionDelayHist(
478 for (uint32_t
j = 0;
j < RubyRequestType_NUM;
j++) {
479 for (uint32_t
k = 0;
k < MachineType_NUM;
k++) {
501 for (uint32_t
j = 0;
j < RubyRequestType_NUM; ++
j) {
513 for (uint32_t
j = 0;
j < MachineType_NUM; ++
j) {
544 for (uint32_t
j = 0;
j < RubyRequestType_NUM;
j++) {
545 for (uint32_t
k = 0;
k < MachineType_NUM;
k++) {
561 if (msg.
getType() != RubyRequestType_IFETCH) {
Stats::Histogram & getLatencyHist()
Stats::Counter getIncompleteTimes(const MachineType t) const
Stats::Histogram & getTypeLatencyHist(uint32_t t)
Stats::Histogram & getMissMachLatencyHist(uint32_t t) const
std::vector< std::map< uint32_t, AbstractController * > > m_abstract_controls
Stats::Histogram & getOutstandReqHist()
Stats::Histogram & getHitLatencyHist()
Stats::Histogram & getMissTypeMachLatencyHist(uint32_t r, uint32_t t) const
std::vector< Stats::Scalar * > m_IncompleteTimesSeqr
Stats::Histogram & getHitMachLatencyHist(uint32_t t)
void setHotLines(bool hot_lines)
Stats::Histogram & getOutstandReqHist()
Stats::Histogram m_missLatencyHistSeqr
Histogram for holding latency profile of all requests that miss in the controller connected to this s...
Stats::Histogram & getInitialToForwardDelayHist(const MachineType t) const
std::vector< Stats::Histogram * > m_IssueToInitialDelayHistCoalsr
ProfilerStats rubyProfilerStats
Stats::Histogram delayHistogram
std::vector< std::vector< Stats::Histogram * > > m_missTypeMachLatencyHistCoalsr
Stats::Histogram & getIssueToInitialDelayHist(uint32_t t) const
std::vector< Stats::Histogram * > m_typeLatencyHistCoalsr
std::vector< Stats::Histogram * > m_missTypeLatencyHistSeqr
std::vector< Stats::Histogram * > delayVCHistogram
std::vector< Stats::Histogram * > m_missMachLatencyHistCoalsr
std::vector< std::vector< Stats::Histogram * > > m_missTypeMachLatencyHistSeqr
Histograms for profiling the latencies for requests that required external messages.
Stats::Histogram & getMissTypeLatencyHist(uint32_t t)
Derived & flags(Flags _flags)
Set the flags and marks this stat to print at the end of simulation.
Stats::Histogram m_hitLatencyHistSeqr
Histogram for holding latency profile of all requests that hit in the controller connected to this se...
This is a simple scalar statistic, like a counter.
Stats::Histogram m_outstandReqHistCoalsr
const RubyRequestType & getType() const
std::vector< Stats::Histogram * > m_ForwardToFirstResponseDelayHistCoalsr
Profiler::ProfilerStats::PerRequestTypeStats perRequestTypeStats
Addr getLineAddress() const
const FlagsType oneline
Print all values on a single line.
Stats::Histogram & getForwardRequestToFirstResponseHist(const MachineType t) const
Stats::Histogram & getIssueToInitialDelayHist(uint32_t t) const
#define ADD_STAT(n,...)
Convenience macro to add a stat to a statistics group.
std::vector< Stats::Histogram * > m_FirstResponseToCompletionDelayHistSeqr
AddressProfiler * m_inst_profiler_ptr
Stats::Histogram & getLatencyHist()
Profiler::ProfilerStats::PerMachineTypeStats perMachineTypeStats
std::vector< std::vector< Stats::Histogram * > > m_hitTypeMachLatencyHistSeqr
Histograms for profiling the latencies for requests that did not required external messages.
Stats::Histogram & getHitTypeMachLatencyHist(uint32_t r, uint32_t t)
PerRequestTypeMachineTypeStats(Stats::Group *parent)
std::vector< Stats::Histogram * > m_missMachLatencyHistSeqr
Histograms for profiling the latencies for requests that required external messages.
Stats::Histogram & getDelayVCHist(uint32_t index)
std::vector< Stats::Histogram * > m_InitialToForwardDelayHistCoalsr
Profiler::ProfilerStats::PerRequestTypeMachineTypeStats perRequestTypeMachineTypeStats
void setAllInstructions(bool all_instructions)
void addAddressTraceSample(const RubyRequest &msg, NodeID id)
std::vector< Stats::Histogram * > m_typeLatencyHistSeqr
PerMachineTypeStats(Stats::Group *parent)
Profiler(const RubySystemParams ¶ms, RubySystem *rs)
AddressProfiler * m_address_profiler_ptr
std::vector< Stats::Histogram * > m_InitialToForwardDelayHistSeqr
const uint32_t m_num_vnets
Stats::Histogram & getFirstResponseToCompletionDelayHist(const MachineType t) const
std::vector< Stats::Histogram * > m_hitTypeLatencyHistSeqr
const bool m_all_instructions
Stats::Histogram & getDelayHist()
const FlagsType nozero
Don't print if this is zero.
Stats::Histogram & getMissLatencyHist()
ProfilerStats(Stats::Group *parent, Profiler *profiler)
std::vector< Stats::Histogram * > m_IssueToInitialDelayHistSeqr
Histograms for recording the breakdown of miss latency.
const RubyAccessMode & getAccessMode() const
std::vector< Stats::Histogram * > m_hitMachLatencyHistSeqr
Histograms for profiling the latencies for requests that did not required external messages.
Stats::Histogram & getMissTypeLatencyHist(uint32_t t)
Stats::Histogram & getMissTypeMachLatencyHist(uint32_t r, uint32_t t) const
Stats::Histogram m_latencyHistSeqr
Histogram for holding latency profile of all requests.
std::vector< Stats::Histogram * > m_missTypeLatencyHistCoalsr
const FlagsType pdf
Print the percent of the total that this entry represents.
std::vector< Stats::Histogram * > m_ForwardToFirstResponseDelayHistSeqr
RubySystem * m_ruby_system
void add(DistBase &d)
Add the argument distribution to the this distribution.
PerRequestTypeStats(Stats::Group *parent)
Stats::Histogram m_latencyHistCoalsr
std::vector< Stats::Histogram * > m_FirstResponseToCompletionDelayHistCoalsr
Addr getProgramCounter() const
Stats::Histogram & getMissLatencyHist()
Stats::Histogram & getTypeLatencyHist(uint32_t t)
Histogram & init(size_type size)
Set the parameters of this histogram.
Stats::Histogram & getMissMachLatencyHist(uint32_t t) const
Stats::Histogram m_outstandReqHistSeqr
Histogram for number of outstanding requests per cycle.
virtual Sequencer * getCPUSequencer() const =0
std::string csprintf(const char *format, const Args &...args)
Stats::Histogram & getHitTypeLatencyHist(uint32_t t)
Stats::Histogram m_missLatencyHistCoalsr
virtual GPUCoalescer * getGPUCoalescer() const =0
Generated on Tue Mar 23 2021 19:41:28 for gem5 by doxygen 1.8.17