60 m_nodes = MachineType_base_number(MachineType_NUM);
81 params()->ruby_system->registerNetwork(
this);
85 i != p->ext_links.end(); ++
i) {
90 if (!ranges.empty()) {
103 for (
auto &it : dynamic_cast<Network *>(
this)->
params()->ext_links) {
104 it->params()->ext_node->initNetQueues();
110 for (
int node = 0; node <
m_nodes; node++) {
135 case MessageSizeType_Control:
136 case MessageSizeType_Request_Control:
137 case MessageSizeType_Reissue_Control:
138 case MessageSizeType_Response_Control:
139 case MessageSizeType_Writeback_Control:
140 case MessageSizeType_Broadcast_Control:
141 case MessageSizeType_Multicast_Control:
142 case MessageSizeType_Forwarded_Control:
143 case MessageSizeType_Invalidate_Control:
144 case MessageSizeType_Unblock_Control:
145 case MessageSizeType_Persistent_Control:
146 case MessageSizeType_Completion_Control:
148 case MessageSizeType_Data:
149 case MessageSizeType_Response_Data:
150 case MessageSizeType_ResponseLocal_Data:
151 case MessageSizeType_ResponseL2hit_Data:
152 case MessageSizeType_Writeback_Data:
155 panic(
"Invalid range for type MessageSizeType");
163 std::string vnet_type)
203 const auto &matching_ranges =
addrMap.equal_range(mtype);
204 for (
auto it = matching_ranges.first; it != matching_ranges.second; it++) {
206 auto &ranges = node.
ranges;
208 if (range.contains(addr)) {
213 return MachineType_base_count(mtype);
#define panic(...)
This implements a cprintf based panic() function.
std::unordered_multimap< MachineType, AddrMapNode > addrMap
MachineType getType() const
std::vector< std::vector< MessageBuffer * > > m_toNetQueues
void setToNetQueue(NodeID id, bool ordered, int netNumber, std::string vnet_type, MessageBuffer *b)
Callback class used for collating statistics from all the controller of this type.
const Params * params() const
const AddrRangeList & getAddrRanges() const
std::vector< bool > m_ordered
std::vector< std::string > m_vnet_type_names
virtual void checkNetworkAllocation(NodeID id, bool ordered, int network_num, std::string vnet_type)
const Params * params() const
Topology * m_topology_ptr
The AddrRange class encapsulates an address range, and supports a number of tests to check if two ran...
static uint32_t m_control_msg_size
MachineID getMachineID() const
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
virtual void setFromNetQueue(NodeID id, bool ordered, int netNumber, std::string vnet_type, MessageBuffer *b)
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void registerDumpCallback(Callback *cb)
Register a callback that should be called whenever statistics are about to be dumped.
static uint32_t MessageSizeType_to_int(MessageSizeType size_type)
static uint32_t m_data_msg_size
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
NodeID addressToNodeID(Addr addr, MachineType mtype)
Map an address to the correct NodeID.
void initNetworkPtr(Network *net_ptr)
static uint32_t m_virtual_networks
std::vector< std::vector< MessageBuffer * > > m_fromNetQueues
static uint32_t getBlockSizeBytes()