Go to the documentation of this file.
   34 #include "debug/RubyNetwork.hh" 
   51   : 
Consumer(router), m_router(router), m_id(
id), m_direction(direction),
 
   52     m_vc_per_vnet(consumerVcs)
 
   56     for (
int i = 0; 
i < m_num_vcs; 
i++) {
 
   64     DPRINTF(RubyNetwork, 
"Router %d OutputUnit %s decrementing credit:%d for " 
   76     DPRINTF(RubyNetwork, 
"Router %d OutputUnit %s incrementing credit:%d for " 
  
Tick curTick()
The universal simulation clock.
uint32_t functionalWrite(Packet *pkt)
GarnetNetwork * get_net_ptr()
int get_credit_count(int vc)
std::string PortDirection
Cycles curCycle() const
Determine the current cycle, corresponding to a tick aligned to a clock edge.
bool isReady(Tick curTime)
std::vector< OutVcState > outVcState
bool has_free_vc(int vnet)
void decrement_credit(int out_vc)
void insert_flit(flit *t_flit)
Cycles is a wrapper class for representing cycle counts, i.e.
virtual std::string name() const
void scheduleEvent(Cycles timeDelta)
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
bool has_credit(int out_vc)
void set_out_link(NetworkLink *link)
flitBuffer * getOutQueue()
void set_credit_link(CreditLink *credit_link)
void increment_credit(int out_vc)
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...
uint32_t functionalWrite(Packet *pkt)
OutputUnit(int id, PortDirection direction, Router *router, uint32_t consumerVcs)
CreditLink * m_credit_link
std::string getPortDirectionName(PortDirection direction)
void set_vc_state(VC_state_type state, int vc, Tick curTime)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
PortDirection get_direction()
int select_free_vc(int vnet)
void scheduleEventAbsolute(Tick timeAbs)
bool is_vc_idle(int vc, Tick curTime)
Generated on Thu Jul 28 2022 13:32:35 for gem5 by  doxygen 1.8.17