52 #ifndef __MEM_RUBY_NETWORK_NETWORK_HH__ 53 #define __MEM_RUBY_NETWORK_NETWORK_HH__ 57 #include <unordered_map> 68 #include "mem/ruby/protocol/LinkDirection.hh" 69 #include "mem/ruby/protocol/MessageSizeType.hh" 70 #include "params/RubyNetwork.hh" 82 {
return dynamic_cast<const Params *
>(
_params); }
99 int network_num, std::string vnet_type);
102 const NetDest& routing_table_entry) = 0;
104 const NetDest& routing_table_entry) = 0;
106 const NetDest& routing_table_entry,
111 virtual void print(std::ostream& out)
const = 0;
119 {
fatal(
"Functional read not implemented.\n"); }
121 {
fatal(
"Functional write not implemented.\n"); }
184 std::unordered_multimap<MachineType, AddrMapNode>
addrMap;
195 #endif // __MEM_RUBY_NETWORK_NETWORK_HH__
Ports are used to interface objects to each other.
Network & operator=(const Network &obj)
std::unordered_multimap< MachineType, AddrMapNode > addrMap
#define fatal(...)
This implements a cprintf based fatal() function.
virtual void makeExtInLink(NodeID src, SwitchID dest, BasicLink *link, const NetDest &routing_table_entry)=0
std::vector< std::vector< MessageBuffer * > > m_toNetQueues
const PortID InvalidPortID
StatsCallback(Network *_ctr)
void setToNetQueue(NodeID id, bool ordered, int netNumber, std::string vnet_type, MessageBuffer *b)
static uint32_t getNumberOfVirtualNetworks()
Callback class used for collating statistics from all the controller of this type.
virtual bool functionalRead(Packet *pkt)
virtual void collateStats()=0
std::vector< bool > m_ordered
virtual void makeExtOutLink(SwitchID src, NodeID dest, BasicLink *link, const NetDest &routing_table_entry)=0
std::vector< std::string > m_vnet_type_names
static RubyDummyPort & instance()
virtual void checkNetworkAllocation(NodeID id, bool ordered, int network_num, std::string vnet_type)
const Params * params() const
Topology * m_topology_ptr
static uint32_t m_control_msg_size
Port & getPort(const std::string &, PortID idx=InvalidPortID) override
Get a port with a given name and index.
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
std::string PortDirection
ClockedObject declaration and implementation.
virtual void setFromNetQueue(NodeID id, bool ordered, int netNumber, std::string vnet_type, MessageBuffer *b)
Defines global host-dependent types: Counter, Tick, and (indirectly) {int,uint}{8,16,32,64}_t.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
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.
virtual void makeInternalLink(SwitchID src, SwitchID dest, BasicLink *link, const NetDest &routing_table_entry, PortDirection src_outport, PortDirection dst_inport)=0
Declaration of the Packet class.
virtual uint32_t functionalWrite(Packet *pkt)
const SimObjectParams * _params
Cached copy of the object parameters.
NodeID addressToNodeID(Addr addr, MachineType mtype)
Map an address to the correct NodeID.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
virtual void print(std::ostream &out) const =0
static uint32_t m_virtual_networks
std::ostream & operator<<(std::ostream &out, const Network &obj)
std::vector< std::vector< MessageBuffer * > > m_fromNetQueues
void process()
virtual process function that is invoked when the callback queue is executed.