64 fatal_if(
p.data_msg_size >
p.ruby_system->getBlockSizeBytes(),
65 "%s: data message size > cache line size",
name());
76 std::unordered_map<MachineType, std::vector<NodeID>> localNodeVersions;
77 for (
auto &it :
params().ext_links) {
85 for (
int i = 0;
i < MachineType_base_level(MachineType_NUM); ++
i) {
86 MachineType mach =
static_cast<MachineType
>(
i);
87 if (localNodeVersions.count(mach)) {
88 for (
auto &ver : localNodeVersions.at(mach)) {
106 p.ext_links,
p.int_links,
125 i !=
p.ext_links.end(); ++
i) {
130 if (!ranges.empty()) {
143 for (
auto &it :
dynamic_cast<Network *
>(
this)->
params().ext_links) {
144 it->params().ext_node->initNetQueues();
150 for (
int node = 0; node <
m_nodes; node++) {
169 case MessageSizeType_Control:
170 case MessageSizeType_Request_Control:
171 case MessageSizeType_Reissue_Control:
172 case MessageSizeType_Response_Control:
173 case MessageSizeType_Writeback_Control:
174 case MessageSizeType_Broadcast_Control:
175 case MessageSizeType_Multicast_Control:
176 case MessageSizeType_Forwarded_Control:
177 case MessageSizeType_Invalidate_Control:
178 case MessageSizeType_Unblock_Control:
179 case MessageSizeType_Persistent_Control:
180 case MessageSizeType_Completion_Control:
182 case MessageSizeType_Data:
183 case MessageSizeType_Response_Data:
184 case MessageSizeType_ResponseLocal_Data:
185 case MessageSizeType_ResponseL2hit_Data:
186 case MessageSizeType_Writeback_Data:
189 panic(
"Invalid range for type MessageSizeType");
197 std::string vnet_type)
241 const auto &matching_ranges =
addrMap.equal_range(mtype);
242 for (
auto it = matching_ranges.first; it != matching_ranges.second; it++) {
244 auto &ranges = node.
ranges;
246 if (range.contains(
addr)) {
The AddrRange class encapsulates an address range, and supports a number of tests to check if two ran...
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
ClockedObjectParams Params
Parameters of ClockedObject.
virtual std::string name() const
void initNetworkPtr(Network *net_ptr)
MachineID getMachineID() const
const AddrRangeList & getAddrRanges() const
MachineType getType() const
NodeID getVersion() const
void setToNetQueue(NodeID global_id, bool ordered, int netNumber, std::string vnet_type, MessageBuffer *b)
virtual void setFromNetQueue(NodeID global_id, bool ordered, int netNumber, std::string vnet_type, MessageBuffer *b)
int MachineType_base_number(const MachineType &obj)
std::unordered_multimap< MachineType, AddrMapNode > addrMap
std::vector< bool > m_ordered
RubySystem * m_ruby_system
static uint32_t m_data_msg_size
static uint32_t m_control_msg_size
Topology * m_topology_ptr
virtual void checkNetworkAllocation(NodeID local_id, bool ordered, int network_num, std::string vnet_type)
static uint32_t m_virtual_networks
static uint32_t MessageSizeType_to_int(MessageSizeType size_type)
std::vector< std::vector< MessageBuffer * > > m_fromNetQueues
std::unordered_map< NodeID, NodeID > globalToLocalMap
NodeID getLocalNodeID(NodeID global_id) const
bool getRandomization() const
bool getWarmupEnabled() const
virtual void collateStats()=0
NodeID addressToNodeID(Addr addr, MachineType mtype)
Map an address to the correct NodeID.
std::vector< std::vector< MessageBuffer * > > m_toNetQueues
std::vector< std::string > m_vnet_type_names
void registerNetwork(Network *)
int MachineType_base_number(const MachineType &obj)
int MachineType_base_count(const MachineType &obj)
#define panic(...)
This implements a cprintf based panic() function.
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
const Params & params() const
void registerDumpCallback(const std::function< void()> &callback)
Register a callback that should be called whenever statistics are about to be dumped.
Copyright (c) 2024 Arm Limited All rights reserved.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
MachineType getType() const