Go to the documentation of this file.
35 #include "debug/RubyNetwork.hh"
53 m_virtual_networks(
p.virt_nets), m_vc_per_vnet(
p.vcs_per_vnet),
54 m_num_vcs(m_virtual_networks * m_vc_per_vnet), m_bit_width(
p.
width),
55 m_network_ptr(nullptr), routingUnit(this), switchAllocator(this),
78 for (
int inport = 0; inport <
m_input_unit.size(); inport++) {
88 for (
int outport = 0; outport <
m_output_unit.size(); outport++) {
104 " not match that of Router%d(%d). Consider inserting SerDes "
117 m_input_unit.push_back(std::shared_ptr<InputUnit>(input_unit));
126 CreditLink *credit_link, uint32_t consumerVcs)
129 " Consider inserting SerDes Units");
142 m_output_unit.push_back(std::shared_ptr<OutputUnit>(output_unit));
206 .
name(
name() +
".crossbar_activity")
211 .
name(
name() +
".sw_input_arbiter_activity")
216 .
name(
name() +
".sw_output_arbiter_activity")
253 float fault_vector[num_fault_types];
255 out <<
"Router-" <<
m_id <<
" fault vector: " << std::endl;
256 for (
int fault_type_index = 0; fault_type_index < num_fault_types;
257 fault_type_index++) {
258 out <<
" - probability of (";
262 out << fault_vector[fault_type_index] << std::endl;
270 float aggregate_fault_prob;
272 &aggregate_fault_prob);
273 out <<
"Router-" <<
m_id <<
" fault probability: ";
274 out << aggregate_fault_prob << std::endl;
280 uint32_t num_functional_writes = 0;
284 num_functional_writes +=
m_input_unit[
i]->functionalWrite(pkt);
291 return num_functional_writes;
CrossbarSwitch crossbarSwitch
Tick curTick()
The universal simulation clock.
GarnetNetwork * m_network_ptr
void addOutPort(PortDirection outport_dirn, NetworkLink *link, std::vector< NetDest > &routing_table_entry, int link_weight, CreditLink *credit_link, uint32_t consumerVcs)
bool get_fault_vector(int temperature, float fault_vector[])
void addInPort(PortDirection inport_dirn, NetworkLink *link, CreditLink *credit_link)
std::string PortDirection
bool get_aggregate_fault_probability(int temperature, float *aggregate_fault_prob)
std::string fault_type_to_string(int fault_type_index)
statistics::Scalar m_crossbar_activity
statistics::Scalar m_sw_input_arbiter_activity
const FlagsType nozero
Don't print if this is zero.
void init()
init() is called after all C++ SimObjects have been created and all ports are connected.
void resetStats()
Callback to reset stats.
void setLinkConsumer(Consumer *consumer)
int outportCompute(RouteInfo route, int inport, PortDirection inport_dirn)
uint32_t m_virtual_networks
statistics::Scalar m_buffer_writes
int route_compute(RouteInfo route, int inport, PortDirection direction)
Cycles is a wrapper class for representing cycle counts, i.e.
virtual void setVcsPerVnet(uint32_t consumerVcs)
double get_output_arbiter_activity()
Derived & name(const std::string &name)
Set the name and marks this stat to print at the end of simulation.
double get_crossbar_activity()
virtual std::string name() const
void scheduleEvent(Cycles timeDelta)
void addWeight(int link_weight)
void addInDirection(PortDirection inport_dirn, int inport)
statistics::Scalar m_buffer_reads
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
void regStats()
Callback to set stat parameters.
statistics::Scalar m_sw_output_arbiter_activity
void set_out_link(NetworkLink *link)
flitBuffer * getOutQueue()
PortDirection getOutportDirection(int outport)
void set_credit_link(CreditLink *credit_link)
void grant_switch(int inport, flit *t_flit)
void printFaultVector(std::ostream &out)
double get_input_arbiter_activity()
uint32_t functionalWrite(Packet *pkt)
void addOutDirection(PortDirection outport_dirn, int outport)
#define BASELINE_TEMPERATURE_CELCIUS
virtual void regStats()
Callback to set stat parameters.
Tick clockEdge(Cycles cycles=Cycles(0)) const
Determine the tick when a cycle begins, by default the current one, but the argument also enables the...
void setSourceQueue(flitBuffer *src_queue, ClockedObject *srcClockObject)
GarnetRouterParams Params
PortDirection getInportDirection(int inport)
void addRoute(std::vector< NetDest > &routing_table_entry)
void init()
init() is called after all C++ SimObjects have been created and all ports are connected.
uint32_t get_vc_per_vnet()
std::vector< std::shared_ptr< OutputUnit > > m_output_unit
std::vector< std::shared_ptr< InputUnit > > m_input_unit
std::string getPortDirectionName(PortDirection direction)
void schedule_wakeup(Cycles time)
void printAggregateFaultProbability(std::ostream &out)
Derived & flags(Flags _flags)
Set the flags and marks this stat to print at the end of simulation.
void update_sw_winner(int inport, flit *t_flit)
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
uint32_t functionalWrite(Packet *)
SwitchAllocator switchAllocator
Generated on Wed Jul 13 2022 10:39:25 for gem5 by doxygen 1.8.17