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 Jun 22 2021 15:28:30 for gem5 by  doxygen 1.8.17