gem5  v21.0.0.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
Classes | Public Member Functions | Public Attributes | Private Member Functions | Private Attributes | List of all members
Profiler Class Reference

#include <Profiler.hh>

Classes

struct  ProfilerStats
 

Public Member Functions

 Profiler (const RubySystemParams &params, RubySystem *rs)
 
 ~Profiler ()
 
void wakeup ()
 
void regStats ()
 
void collateStats ()
 
AddressProfilergetAddressProfiler ()
 
AddressProfilergetInstructionProfiler ()
 
void addAddressTraceSample (const RubyRequest &msg, NodeID id)
 
bool getHotLines () const
 
bool getAllInstructions () const
 

Public Attributes

RubySystemm_ruby_system
 
ProfilerStats rubyProfilerStats
 

Private Member Functions

 Profiler (const Profiler &obj)
 
Profileroperator= (const Profiler &obj)
 

Private Attributes

AddressProfilerm_address_profiler_ptr
 
AddressProfilerm_inst_profiler_ptr
 
const bool m_hot_lines
 
const bool m_all_instructions
 
const uint32_t m_num_vnets
 

Detailed Description

Definition at line 65 of file Profiler.hh.

Constructor & Destructor Documentation

◆ Profiler() [1/2]

Profiler::Profiler ( const RubySystemParams &  params,
RubySystem rs 
)

◆ ~Profiler()

Profiler::~Profiler ( )

Definition at line 99 of file Profiler.cc.

◆ Profiler() [2/2]

Profiler::Profiler ( const Profiler obj)
private

Member Function Documentation

◆ addAddressTraceSample()

void Profiler::addAddressTraceSample ( const RubyRequest msg,
NodeID  id 
)

◆ collateStats()

void Profiler::collateStats ( )

Definition at line 358 of file Profiler.cc.

References Stats::DistBase< Derived, Stor >::add(), AddressProfiler::collateStats(), Profiler::ProfilerStats::delayHistogram, Profiler::ProfilerStats::delayVCHistogram, AbstractController::getCPUSequencer(), AbstractController::getDelayHist(), AbstractController::getDelayVCHist(), GPUCoalescer::getFirstResponseToCompletionDelayHist(), GPUCoalescer::getForwardRequestToFirstResponseHist(), AbstractController::getGPUCoalescer(), Sequencer::getHitLatencyHist(), Sequencer::getHitMachLatencyHist(), Sequencer::getHitTypeLatencyHist(), Sequencer::getHitTypeMachLatencyHist(), Sequencer::getIncompleteTimes(), GPUCoalescer::getInitialToForwardDelayHist(), Sequencer::getIssueToInitialDelayHist(), GPUCoalescer::getIssueToInitialDelayHist(), Sequencer::getLatencyHist(), GPUCoalescer::getLatencyHist(), Sequencer::getMissLatencyHist(), GPUCoalescer::getMissLatencyHist(), Sequencer::getMissMachLatencyHist(), GPUCoalescer::getMissMachLatencyHist(), Sequencer::getMissTypeLatencyHist(), GPUCoalescer::getMissTypeLatencyHist(), Sequencer::getMissTypeMachLatencyHist(), GPUCoalescer::getMissTypeMachLatencyHist(), Sequencer::getOutstandReqHist(), GPUCoalescer::getOutstandReqHist(), Sequencer::getTypeLatencyHist(), GPUCoalescer::getTypeLatencyHist(), ArmISA::i, ArmISA::j, MipsISA::k, RubySystem::m_abstract_controls, m_address_profiler_ptr, m_all_instructions, Profiler::ProfilerStats::PerMachineTypeStats::m_FirstResponseToCompletionDelayHistCoalsr, Profiler::ProfilerStats::PerMachineTypeStats::m_FirstResponseToCompletionDelayHistSeqr, Profiler::ProfilerStats::PerMachineTypeStats::m_ForwardToFirstResponseDelayHistCoalsr, Profiler::ProfilerStats::PerMachineTypeStats::m_ForwardToFirstResponseDelayHistSeqr, Profiler::ProfilerStats::m_hitLatencyHistSeqr, Profiler::ProfilerStats::PerMachineTypeStats::m_hitMachLatencyHistSeqr, Profiler::ProfilerStats::PerRequestTypeStats::m_hitTypeLatencyHistSeqr, Profiler::ProfilerStats::PerRequestTypeMachineTypeStats::m_hitTypeMachLatencyHistSeqr, Profiler::ProfilerStats::PerMachineTypeStats::m_IncompleteTimesSeqr, Profiler::ProfilerStats::PerMachineTypeStats::m_InitialToForwardDelayHistCoalsr, Profiler::ProfilerStats::PerMachineTypeStats::m_InitialToForwardDelayHistSeqr, m_inst_profiler_ptr, Profiler::ProfilerStats::PerMachineTypeStats::m_IssueToInitialDelayHistCoalsr, Profiler::ProfilerStats::PerMachineTypeStats::m_IssueToInitialDelayHistSeqr, Profiler::ProfilerStats::m_latencyHistCoalsr, Profiler::ProfilerStats::m_latencyHistSeqr, Profiler::ProfilerStats::m_missLatencyHistCoalsr, Profiler::ProfilerStats::m_missLatencyHistSeqr, Profiler::ProfilerStats::PerMachineTypeStats::m_missMachLatencyHistCoalsr, Profiler::ProfilerStats::PerMachineTypeStats::m_missMachLatencyHistSeqr, Profiler::ProfilerStats::PerRequestTypeStats::m_missTypeLatencyHistCoalsr, Profiler::ProfilerStats::PerRequestTypeStats::m_missTypeLatencyHistSeqr, Profiler::ProfilerStats::PerRequestTypeMachineTypeStats::m_missTypeMachLatencyHistCoalsr, Profiler::ProfilerStats::PerRequestTypeMachineTypeStats::m_missTypeMachLatencyHistSeqr, m_num_vnets, Profiler::ProfilerStats::m_outstandReqHistCoalsr, Profiler::ProfilerStats::m_outstandReqHistSeqr, m_ruby_system, Profiler::ProfilerStats::PerRequestTypeStats::m_typeLatencyHistCoalsr, Profiler::ProfilerStats::PerRequestTypeStats::m_typeLatencyHistSeqr, Profiler::ProfilerStats::perMachineTypeStats, Profiler::ProfilerStats::perRequestTypeMachineTypeStats, Profiler::ProfilerStats::perRequestTypeStats, and rubyProfilerStats.

Referenced by RubySystem::collateStats().

◆ getAddressProfiler()

AddressProfiler* Profiler::getAddressProfiler ( )
inline

Definition at line 77 of file Profiler.hh.

References m_address_profiler_ptr.

◆ getAllInstructions()

bool Profiler::getAllInstructions ( ) const
inline

Definition at line 84 of file Profiler.hh.

References m_all_instructions.

Referenced by printSorted().

◆ getHotLines()

bool Profiler::getHotLines ( ) const
inline

Definition at line 83 of file Profiler.hh.

References m_hot_lines.

◆ getInstructionProfiler()

AddressProfiler* Profiler::getInstructionProfiler ( )
inline

Definition at line 78 of file Profiler.hh.

References m_inst_profiler_ptr.

◆ operator=()

Profiler& Profiler::operator= ( const Profiler obj)
private

◆ regStats()

void Profiler::regStats ( )

◆ wakeup()

void Profiler::wakeup ( )

Member Data Documentation

◆ m_address_profiler_ptr

AddressProfiler* Profiler::m_address_profiler_ptr
private

Definition at line 91 of file Profiler.hh.

Referenced by addAddressTraceSample(), collateStats(), getAddressProfiler(), and Profiler().

◆ m_all_instructions

const bool Profiler::m_all_instructions
private

Definition at line 185 of file Profiler.hh.

Referenced by collateStats(), getAllInstructions(), and Profiler().

◆ m_hot_lines

const bool Profiler::m_hot_lines
private

Definition at line 184 of file Profiler.hh.

Referenced by getHotLines(), and Profiler().

◆ m_inst_profiler_ptr

AddressProfiler* Profiler::m_inst_profiler_ptr
private

Definition at line 92 of file Profiler.hh.

Referenced by collateStats(), getInstructionProfiler(), and Profiler().

◆ m_num_vnets

const uint32_t Profiler::m_num_vnets
private

Definition at line 186 of file Profiler.hh.

Referenced by collateStats(), and Profiler::ProfilerStats::ProfilerStats().

◆ m_ruby_system

RubySystem* Profiler::m_ruby_system

Definition at line 71 of file Profiler.hh.

Referenced by collateStats().

◆ rubyProfilerStats

ProfilerStats Profiler::rubyProfilerStats

Definition at line 190 of file Profiler.hh.

Referenced by collateStats().


The documentation for this class was generated from the following files:

Generated on Tue Mar 23 2021 19:41:39 for gem5 by doxygen 1.8.17