Go to the documentation of this file.
   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" 
  102                                        int network_num, std::string vnet_type);
 
  114     virtual void print(std::ostream& out) 
const = 0;
 
  122     { 
fatal(
"Functional read not implemented.\n"); }
 
  124     { 
fatal(
"Masked functional read not implemented.\n"); }
 
  126     { 
fatal(
"Functional write not implemented.\n"); }
 
  174     std::unordered_multimap<MachineType, AddrMapNode> 
addrMap;
 
  192 #endif // __MEM_RUBY_NETWORK_NETWORK_HH__ 
  
#define fatal(...)
This implements a cprintf based fatal() function.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
static uint32_t getNumberOfVirtualNetworks()
static uint32_t m_virtual_networks
virtual void makeExtOutLink(SwitchID src, NodeID dest, BasicLink *link, std::vector< NetDest > &routing_table_entry)=0
std::vector< bool > m_ordered
std::string PortDirection
Network & operator=(const Network &obj)
static uint32_t MessageSizeType_to_int(MessageSizeType size_type)
Port & getPort(const std::string &, PortID idx=InvalidPortID) override
Get a port with a given name and index.
std::ostream & operator<<(std::ostream &os, const BoolVec &myvector)
virtual void makeInternalLink(SwitchID src, SwitchID dest, BasicLink *link, std::vector< NetDest > &routing_table_entry, PortDirection src_outport, PortDirection dst_inport)=0
std::unordered_multimap< MachineType, AddrMapNode > addrMap
const PortID InvalidPortID
static RubyDummyPort & instance()
constexpr uint64_t mask(unsigned nbits)
Generate a 64-bit mask of 'nbits' 1s, right justified.
virtual bool functionalRead(Packet *pkt)
static uint32_t m_data_msg_size
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
virtual void makeExtInLink(NodeID src, SwitchID dest, BasicLink *link, std::vector< NetDest > &routing_table_entry)=0
virtual void checkNetworkAllocation(NodeID local_id, bool ordered, int network_num, std::string vnet_type)
virtual void setFromNetQueue(NodeID global_id, bool ordered, int netNumber, std::string vnet_type, MessageBuffer *b)
NodeID getLocalNodeID(NodeID global_id) const
std::vector< std::vector< MessageBuffer * > > m_fromNetQueues
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
virtual void collateStats()=0
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
std::vector< std::vector< MessageBuffer * > > m_toNetQueues
std::vector< std::string > m_vnet_type_names
virtual bool functionalRead(Packet *pkt, WriteMask &mask)
Topology * m_topology_ptr
Ports are used to interface objects to each other.
NodeID addressToNodeID(Addr addr, MachineType mtype)
Map an address to the correct NodeID.
std::unordered_map< NodeID, NodeID > globalToLocalMap
ClockedObjectParams Params
Parameters of ClockedObject.
static uint32_t m_control_msg_size
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
virtual uint32_t functionalWrite(Packet *pkt)
void setToNetQueue(NodeID global_id, bool ordered, int netNumber, std::string vnet_type, MessageBuffer *b)
virtual void print(std::ostream &out) const =0
Generated on Wed May 4 2022 12:14:01 for gem5 by  doxygen 1.8.17