Go to the documentation of this file.
57 using stl_helpers::operator<<;
61 perfectSwitch(m_id, this,
p.virt_nets), m_num_connected_buffers(0),
65 for (
auto& buffer :
p.port_buffers) {
85 const NetDest& routing_table_entry,
86 Cycles link_latency,
int bw_multiplier)
90 throttles.size(), link_latency, bw_multiplier,
96 for (
int i = 0;
i < out.size(); ++
i) {
101 intermediateBuffers.push_back(buffer_ptr);
108 throttles.back().addLinks(intermediateBuffers, out);
125 for (
unsigned int type = MessageSizeType_FIRST;
126 type < MessageSizeType_NUM; ++
type) {
129 MessageSizeType_to_string(MessageSizeType(
type))).c_str());
136 MessageSizeType_to_string(MessageSizeType(
type))).c_str());
155 throttle.clearStats();
164 throttle.collateStats();
200 uint32_t num_functional_writes = 0;
204 return num_functional_writes;
209 : statistics::
Group(parent),
210 m_avg_utilization(this,
"percent_links_utilized")
void addInPort(const std::vector< MessageBuffer * > &in)
static uint32_t MessageSizeType_to_int(MessageSizeType size_type)
void resetStats()
Callback to reset stats.
unsigned m_num_connected_buffers
const FlagsType nozero
Don't print if this is zero.
std::vector< MessageBuffer * > m_port_buffers
void init()
init() is called after all C++ SimObjects have been created and all ports are connected.
uint32_t functionalWrite(Packet *)
std::string csprintf(const char *format, const Args &...args)
gem5::ruby::Switch::SwitchStats switchStats
statistics::Formula * m_msg_bytes[MessageSizeType_NUM]
constexpr uint64_t mask(unsigned nbits)
Generate a 64-bit mask of 'nbits' 1s, right justified.
Cycles is a wrapper class for representing cycle counts, i.e.
void regStats()
Callback to set stat parameters.
void addInPort(const std::vector< MessageBuffer * > &in)
bool functionalRead(Packet *)
const Params & params() const
void init(SimpleNetwork *)
SwitchStats(statistics::Group *parent)
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
statistics::Formula * m_msg_counts[MessageSizeType_NUM]
PerfectSwitch perfectSwitch
SimpleNetwork * m_network_ptr
void addOutPort(const std::vector< MessageBuffer * > &out, const NetDest &routing_table_entry, Cycles link_latency, int bw_multiplier)
statistics::Formula m_avg_utilization
void print(std::ostream &out) const
virtual void regStats()
Callback to set stat parameters.
int getEndpointBandwidth()
Derived & flags(Flags _flags)
Set the flags and marks this stat to print at the end of simulation.
void addOutPort(const std::vector< MessageBuffer * > &out, const NetDest &routing_table_entry)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
std::list< Throttle > throttles
void init()
init() is called after all C++ SimObjects have been created and all ports are connected.
Generated on Tue Sep 7 2021 14:53:49 for gem5 by doxygen 1.8.17