40 #ifndef __MEM_RUBY_NETWORK_SIMPLE_SWITCH_HH__ 41 #define __MEM_RUBY_NETWORK_SIMPLE_SWITCH_HH__ 52 #include "mem/ruby/protocol/MessageSizeType.hh" 53 #include "params/Switch.hh" 69 const NetDest& routing_table_entry,
70 Cycles link_latency,
int bw_multiplier);
78 void print(std::ostream& out)
const;
110 #endif // __MEM_RUBY_NETWORK_SIMPLE_SWITCH_HH__ void addInPort(const std::vector< MessageBuffer *> &in)
Switch & operator=(const Switch &obj)
Cycles is a wrapper class for representing cycle counts, i.e.
void addOutPort(const std::vector< MessageBuffer *> &out, const NetDest &routing_table_entry, Cycles link_latency, int bw_multiplier)
std::vector< MessageBuffer * > m_port_buffers
std::list< Throttle > throttles
void resetStats()
Callback to reset stats.
bool functionalRead(Packet *)
void init_net_ptr(SimpleNetwork *net_ptr)
void print(std::ostream &out) const
uint32_t functionalWrite(Packet *)
Stats::Formula m_msg_bytes[MessageSizeType_NUM]
void init()
init() is called after all C++ SimObjects have been created and all ports are connected.
SimpleNetwork * m_network_ptr
void regStats()
Callback to set stat parameters.
unsigned m_num_connected_buffers
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
Stats::Formula m_avg_utilization
PerfectSwitch perfectSwitch
Stats::Formula m_msg_counts[MessageSizeType_NUM]
Declaration of the Packet class.
const Stats::Formula & getMsgCount(unsigned int type) const
std::ostream & operator<<(std::ostream &out, const Switch &obj)