Go to the documentation of this file.
35 #include "debug/RubyNetwork.hh"
56 int link_bandwidth_multiplier,
int endpoint_bandwidth,
59 m_switch_id(sID), m_switch(
em), m_node(node),
61 throttleStats(
em, node)
65 assert(link_bandwidth_multiplier > 0);
79 assert(in_vec.size() == out_vec.size());
81 for (
int vnet = 0; vnet < in_vec.size(); ++vnet) {
87 m_in.push_back(in_ptr);
88 m_out.push_back(out_ptr);
92 std::string desc =
"[Queue to Throttle " +
101 if (out ==
nullptr || in ==
nullptr) {
108 while (bw_remaining > 0 && (in->
isReady(current_time) ||
116 Message *net_msg_ptr = msg_ptr.get();
120 DPRINTF(RubyNetwork,
"throttle: %d my bw %d bw spent "
121 "enqueueing net msg %d time: %lld.\n",
127 out->
enqueue(msg_ptr, current_time,
133 DPRINTF(RubyNetwork,
"%s\n", *out);
139 bw_remaining = std::max(0, -diff);
142 if (bw_remaining > 0 && (in->
isReady(current_time) ||
145 DPRINTF(RubyNetwork,
"vnet: %d", vnet);
149 schedule_wakeup =
true;
161 bool schedule_wakeup =
false;
164 bool iteration_direction =
false;
170 iteration_direction =
true;
173 if (iteration_direction) {
174 for (
int vnet = 0; vnet <
m_vnets; ++vnet) {
179 for (
int vnet =
m_vnets-1; vnet >= 0; --vnet) {
195 if (bw_remaining > 0 && !schedule_wakeup) {
199 DPRINTF(RubyNetwork,
"%s not scheduled again\n", *
this);
201 DPRINTF(RubyNetwork,
"%s scheduled again\n", *
this);
212 for (MessageSizeType
type = MessageSizeType_FIRST;
213 type < MessageSizeType_NUM; ++
type) {
216 csprintf(
"msg_count.%s", MessageSizeType_to_string(
type)).c_str());
224 csprintf(
"msg_bytes.%s", MessageSizeType_to_string(
type)).c_str());
260 assert(net_msg_ptr != NULL);
274 : statistics::
Group(parent,
csprintf(
"throttle%02i", nodeID).c_str()),
275 m_link_utilization(this,
"link_utilization")
static uint32_t getNumberOfVirtualNetworks()
int m_link_bandwidth_multiplier
std::shared_ptr< Message > MsgPtr
const int MESSAGE_SIZE_MULTIPLIER
Cycles curCycle() const
Determine the current cycle, corresponding to a tick aligned to a clock edge.
static uint32_t MessageSizeType_to_int(MessageSizeType size_type)
const FlagsType nozero
Don't print if this is zero.
const std::string to_string(sc_enc enc)
void operateVnet(int vnet, int &bw_remainin, bool &schedule_wakeup, MessageBuffer *in, MessageBuffer *out)
void print(std::ostream &out) const
void enqueue(MsgPtr message, Tick curTime, Tick delta)
virtual const MessageSizeType & getMessageSize() const
statistics::Vector * m_msg_counts[MessageSizeType_NUM]
A vector of scalar stats.
std::string csprintf(const char *format, const Args &...args)
Tick dequeue(Tick current_time, bool decrement_messages=true)
Updates the delay cycles of the message at the head of the queue, removes it from the queue and retur...
void init(NodeID node, Cycles link_latency, int link_bandwidth_multiplier, int endpoint_bandwidth)
void ccprintf(cp::Print &print)
const MsgPtr & peekMsgPtr() const
static int network_message_to_size(Message *net_msg_ptr)
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)
const int PRIORITY_SWITCH_LIMIT
std::vector< MessageBuffer * > m_in
Tick cyclesToTicks(Cycles c) const
void scheduleEvent(Cycles timeDelta)
uint64_t Tick
Tick count type.
std::vector< MessageBuffer * > m_out
gem5::ruby::Throttle::ThrottleStats throttleStats
double m_link_utilization_proxy
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 setConsumer(Consumer *consumer)
bool isReady(Tick current_time) const
statistics::Scalar m_link_utilization
bool areNSlotsAvailable(unsigned int n, Tick curTime)
int getLinkBandwidth() const
std::vector< int > m_units_remaining
virtual const NetDest & getDestination() const
Throttle(int sID, RubySystem *rs, NodeID node, Cycles link_latency, int link_bandwidth_multiplier, int endpoint_bandwidth, Switch *em)
const int BROADCAST_SCALING
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