Go to the documentation of this file.
35 #include "debug/RubyNetwork.hh"
50 int link_bandwidth_multiplier,
int endpoint_bandwidth,
53 m_switch_id(sID), m_switch(
em), m_node(node),
55 throttleStats(
em, node)
59 assert(link_bandwidth_multiplier > 0);
73 assert(in_vec.size() == out_vec.size());
75 for (
int vnet = 0; vnet < in_vec.size(); ++vnet) {
81 m_in.push_back(in_ptr);
82 m_out.push_back(out_ptr);
86 std::string desc =
"[Queue to Throttle " +
95 if (out ==
nullptr || in ==
nullptr) {
102 while (bw_remaining > 0 && (in->
isReady(current_time) ||
110 Message *net_msg_ptr = msg_ptr.get();
114 DPRINTF(RubyNetwork,
"throttle: %d my bw %d bw spent "
115 "enqueueing net msg %d time: %lld.\n",
121 out->
enqueue(msg_ptr, current_time,
127 DPRINTF(RubyNetwork,
"%s\n", *out);
133 bw_remaining = std::max(0, -diff);
136 if (bw_remaining > 0 && (in->
isReady(current_time) ||
139 DPRINTF(RubyNetwork,
"vnet: %d", vnet);
143 schedule_wakeup =
true;
155 bool schedule_wakeup =
false;
158 bool iteration_direction =
false;
164 iteration_direction =
true;
167 if (iteration_direction) {
168 for (
int vnet = 0; vnet <
m_vnets; ++vnet) {
173 for (
int vnet =
m_vnets-1; vnet >= 0; --vnet) {
189 if (bw_remaining > 0 && !schedule_wakeup) {
193 DPRINTF(RubyNetwork,
"%s not scheduled again\n", *
this);
195 DPRINTF(RubyNetwork,
"%s scheduled again\n", *
this);
206 for (MessageSizeType
type = MessageSizeType_FIRST;
207 type < MessageSizeType_NUM; ++
type) {
210 csprintf(
"msg_count.%s", MessageSizeType_to_string(
type)).c_str());
218 csprintf(
"msg_bytes.%s", MessageSizeType_to_string(
type)).c_str());
254 assert(net_msg_ptr != NULL);
268 :
Stats::Group(parent,
csprintf(
"throttle%02i", nodeID).c_str()),
269 m_link_utilization(this,
"link_utilization")
const int MESSAGE_SIZE_MULTIPLIER
std::vector< MessageBuffer * > m_out
Stats::Formula * m_msg_bytes[MessageSizeType_NUM]
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...
virtual const NetDest & getDestination() const
double m_link_utilization_proxy
const std::string to_string(sc_enc enc)
int m_link_bandwidth_multiplier
uint64_t Tick
Tick count type.
static int network_message_to_size(Message *net_msg_ptr)
Throttle(int sID, RubySystem *rs, NodeID node, Cycles link_latency, int link_bandwidth_multiplier, int endpoint_bandwidth, Switch *em)
void print(std::ostream &out) const
virtual const MessageSizeType & getMessageSize() const
void setConsumer(Consumer *consumer)
void enqueue(MsgPtr message, Tick curTime, Tick delta)
A vector of scalar stats.
const MsgPtr & peekMsgPtr() const
ThrottleStats(Stats::Group *parent, const NodeID &nodeID)
Tick cyclesToTicks(Cycles c) const
const int PRIORITY_SWITCH_LIMIT
RubySystem * m_ruby_system
bool isReady(Tick current_time) const
Cycles curCycle() const
Determine the current cycle, corresponding to a tick aligned to a clock edge.
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...
static uint32_t MessageSizeType_to_int(MessageSizeType size_type)
const int BROADCAST_SCALING
static uint32_t getNumberOfVirtualNetworks()
std::shared_ptr< Message > MsgPtr
bool areNSlotsAvailable(unsigned int n, Tick curTime)
const FlagsType nozero
Don't print if this is zero.
Stats::Vector * m_msg_counts[MessageSizeType_NUM]
Throttle::ThrottleStats throttleStats
std::vector< MessageBuffer * > m_in
void ccprintf(cp::Print &print)
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)
int getLinkBandwidth() const
void operateVnet(int vnet, int &bw_remainin, bool &schedule_wakeup, MessageBuffer *in, MessageBuffer *out)
std::vector< int > m_units_remaining
std::string csprintf(const char *format, const Args &...args)
void init(NodeID node, Cycles link_latency, int link_bandwidth_multiplier, int endpoint_bandwidth)
void scheduleEvent(Cycles timeDelta)
Stats::Scalar m_link_utilization
Generated on Tue Jun 22 2021 15:28:30 for gem5 by doxygen 1.8.17