Go to the documentation of this file.
   38 #ifndef __MEM_RUBY_NETWORK_SIMPLE_THROTTLE_HH__ 
   39 #define __MEM_RUBY_NETWORK_SIMPLE_THROTTLE_HH__ 
   62              int link_bandwidth_multiplier, 
int endpoint_bandwidth,
 
   87     void print(std::ostream& out) 
const;
 
   91               int endpoint_bandwidth);
 
   92     void operateVnet(
int vnet, 
int &bw_remainin, 
bool &schedule_wakeup,
 
  139 #endif // __MEM_RUBY_NETWORK_SIMPLE_THROTTLE_HH__ 
  
This is a simple scalar statistic, like a counter.
int m_link_bandwidth_multiplier
std::ostream & operator<<(std::ostream &os, const BoolVec &myvector)
void operateVnet(int vnet, int &bw_remainin, bool &schedule_wakeup, MessageBuffer *in, MessageBuffer *out)
void print(std::ostream &out) const
statistics::Vector * m_msg_counts[MessageSizeType_NUM]
const statistics::Scalar & getUtilization() const
A vector of scalar stats.
std::string csprintf(const char *format, const Args &...args)
void init(NodeID node, Cycles link_latency, int link_bandwidth_multiplier, int endpoint_bandwidth)
const statistics::Vector & getMsgCount(unsigned int type) const
Cycles is a wrapper class for representing cycle counts, i.e.
void addLinks(const std::vector< MessageBuffer * > &in_vec, const std::vector< MessageBuffer * > &out_vec)
std::vector< MessageBuffer * > m_in
Cycles getLatency() const
Throttle & operator=(const Throttle &obj)
std::vector< MessageBuffer * > m_out
gem5::ruby::Throttle::ThrottleStats throttleStats
double m_link_utilization_proxy
statistics::Scalar m_link_utilization
int getLinkBandwidth() const
std::vector< int > m_units_remaining
Throttle(int sID, RubySystem *rs, NodeID node, Cycles link_latency, int link_bandwidth_multiplier, int endpoint_bandwidth, Switch *em)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
statistics::Formula * m_msg_bytes[MessageSizeType_NUM]
ThrottleStats(statistics::Group *parent, const NodeID &nodeID)
RubySystem * m_ruby_system
Generated on Wed May 4 2022 12:14:01 for gem5 by  doxygen 1.8.17