Go to the documentation of this file.
   80     Tick arrival_time = current_time + delta;
 
   81     assert(arrival_time > current_time);
 
   83     Message* msg_ptr = message.get();
 
   88             scheduleEventAbsolute(arrival_time);
 
   90         panic(
"No Consumer for WireBuffer! %s\n", *
this);
 
   99         std::greater<MsgPtr>());
 
  107     assert(msg_ptr != NULL);
 
  121             std::greater<MsgPtr>());
 
  123     Tick future_time = current_time + recycle_latency;
 
  124     node->setLastEnqueueTime(future_time);
 
  128         std::greater<MsgPtr>());
 
  130         scheduleEventAbsolute(future_time);
 
  
void recycle(Tick current_time, Tick recycle_latency)
std::shared_ptr< Message > MsgPtr
std::ostream & operator<<(std::ostream &os, const BoolVec &myvector)
void print(std::ostream &out) const
std::vector< MsgPtr > m_message_queue
RubyWireBufferParams Params
void enqueue(MsgPtr message, Tick current_time, Tick delta)
Consumer * m_consumer_ptr
uint64_t Tick
Tick count type.
void dequeue(Tick current_time)
void init()
init() is called after all C++ SimObjects have been created and all ports are connected.
Abstract superclass for simulation objects.
bool isReady(Tick current_time)
void setLastEnqueueTime(const Tick &time)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
WireBuffer(const Params &p)
#define panic(...)
This implements a cprintf based panic() function.
Generated on Thu Jul 28 2022 13:32:36 for gem5 by  doxygen 1.8.17