34 #include "debug/RubyNetwork.hh" 41 :
Consumer(router), m_router(router), m_id(id), m_direction(direction),
42 m_vc_per_vnet(m_router->get_vc_per_vnet())
46 for (
int i = 0;
i < m_num_vcs;
i++) {
54 DPRINTF(RubyNetwork,
"Router %d OutputUnit %d decrementing credit for " 55 "outvc %d at time: %lld\n",
64 DPRINTF(RubyNetwork,
"Router %d OutputUnit %d incrementing credit for " 65 "outvc %d at time: %lld\n",
void set_out_link(NetworkLink *link)
Cycles is a wrapper class for representing cycle counts, i.e.
void decrement_credit(int out_vc)
CreditLink * m_credit_link
flitBuffer * getOutQueue()
void scheduleEventAbsolute(Tick timeAbs)
bool has_credit(int out_vc)
std::vector< OutVcState > outVcState
std::string PortDirection
GarnetNetwork * get_net_ptr()
Cycles curCycle() const
Determine the current cycle, corresponding to a tick aligned to a clock edge.
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
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 set_credit_link(CreditLink *credit_link)
bool has_free_vc(int vnet)
bool isReady(Cycles curTime)
int M5_CLASS_VAR_USED m_id
void increment_credit(int out_vc)
OutputUnit(int id, PortDirection direction, Router *router)
bool is_vc_idle(int vc, Cycles curTime)
uint32_t functionalWrite(Packet *pkt)
void set_vc_state(VC_state_type state, int vc, Cycles curTime)
int select_free_vc(int vnet)
void insert_flit(flit *t_flit)
uint32_t functionalWrite(Packet *pkt)