Go to the documentation of this file.
33 #ifndef __DEV_ETHERSWITCH_HH__
34 #define __DEV_ETHERSWITCH_HH__
46 #include "params/EtherSwitch.hh"
73 uint64_t outputBufferSize,
Tick delay,
Tick delay_var,
74 double rate,
unsigned id);
134 std::set<PortFifoEntry, EntryOrder>
fifo;
198 #endif // __DEV_ETHERSWITCH_HH__
std::vector< Interface * > interfaces
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
const std::string objName
EtherSwitch(const Params &p)
Interface(const std::string &name, EtherSwitch *_etherSwitch, uint64_t outputBufferSize, Tick delay, Tick delay_var, double rate, unsigned id)
PortFifoEntry(EthPacketPtr pkt, Tick recv_tick, unsigned id)
const unsigned interfaceId
const PortID id
A numeric identifier to distinguish ports in a vector, and set to InvalidPortID in case this port is ...
PortFifo outputFifo
output fifo at each interface
void unserialize(CheckpointIn &cp) override
Unserialize an object.
void serialize(CheckpointOut &cp) const
Serialize an object.
std::map< uint64_t, SwitchTableEntry > forwardingTable
const std::string & name() const
Return port name (for DPRINTF).
const PortID InvalidPortID
const double ticksPerByte
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
EventFunctionWrapper txEvent
Basic support for object serialization.
std::shared_ptr< EthPacketData > EthPacketPtr
void serialize(CheckpointOut &cp) const
Serialize an object.
uint64_t Tick
Tick count type.
void serialize(CheckpointOut &cp) const
Serialization stuff.
void serialize(CheckpointOut &cp) const override
Serialize an object.
Abstract superclass for simulation objects.
bool push(EthPacketPtr ptr, unsigned senderId)
Push a packet into the fifo and sort the packets with same recv tick by port id.
void enqueue(EthPacketPtr packet, unsigned senderId)
enqueue packet to the outputFifo
void unserialize(CheckpointIn &cp)
Unserialize an object.
void unserialize(CheckpointIn &cp)
Unserialize an object.
Interface * lookupDestPort(networking::EthAddr destAddr)
void unserialize(CheckpointIn &cp)
Unserialize an object.
Ports are used to interface objects to each other.
bool operator()(const PortFifoEntry &lhs, const PortFifoEntry &rhs) const
Model for an Ethernet switch port.
std::ostream CheckpointOut
PortFifo(const std::string &name, int max)
void learnSenderAddr(networking::EthAddr srcMacAddr, Interface *sender)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
bool recvPacket(EthPacketPtr packet)
When a packet is received from a device, route it through an (several) output queue(s)
std::set< PortFifoEntry, EntryOrder > fifo
Generated on Thu Jun 16 2022 10:41:52 for gem5 by doxygen 1.8.17