Go to the documentation of this file.
50 #ifndef __MEM_RUBY_NETWORK_SIMPLE_THROTTLE_HH__
51 #define __MEM_RUBY_NETWORK_SIMPLE_THROTTLE_HH__
77 int link_bandwidth_multiplier,
int endpoint_bandwidth,
106 void print(std::ostream& out)
const;
110 int endpoint_bandwidth);
111 void operateVnet(
int vnet,
int channel,
int &total_bw_remaining,
112 bool &bw_saturated,
bool &output_blocked,
169 #endif // __MEM_RUBY_NETWORK_SIMPLE_THROTTLE_HH__
This is a simple scalar statistic, like a counter.
std::vector< int > m_link_bandwidth_multiplier
std::ostream & operator<<(std::ostream &os, const BoolVec &myvector)
statistics::Scalar total_bw_sat_cy
int getTotalLinkBandwidth() const
void print(std::ostream &out) const
A vector of scalar stats.
std::string csprintf(const char *format, const Args &...args)
statistics::Scalar total_stall_cy
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)
statistics::Scalar total_data_msg_bytes
std::vector< MessageBuffer * > m_in
Cycles getLatency() const
Throttle & operator=(const Throttle &obj)
std::vector< std::vector< int > > m_units_remaining
std::vector< MessageBuffer * > m_out
ThrottleStats(Switch *parent, const NodeID &nodeID)
statistics::Formula avg_useful_bandwidth
int getLinkBandwidth(int vnet) const
statistics::Formula link_utilization
const statistics::Formula & getUtilization() const
statistics::Formula * msg_bytes[MessageSizeType_NUM]
int getChannelCnt(int vnet) const
gem5::ruby::Throttle::ThrottleStats throttleStats
statistics::Formula avg_msg_wait_time
statistics::Scalar total_msg_bytes
std::vector< int > m_vnet_channels
statistics::Vector * msg_counts[MessageSizeType_NUM]
statistics::Formula avg_bandwidth
statistics::Scalar total_msg_wait_time
statistics::Scalar total_msg_count
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
statistics::Scalar acc_link_utilization
RubySystem * m_ruby_system
Throttle(int sID, RubySystem *rs, NodeID node, Cycles link_latency, int endpoint_bandwidth, Switch *em)
void operateVnet(int vnet, int channel, int &total_bw_remaining, bool &bw_saturated, bool &output_blocked, MessageBuffer *in, MessageBuffer *out)
Generated on Thu Jun 16 2022 10:41:57 for gem5 by doxygen 1.8.17