| gem5
    v22.1.0.0
    | 
Model for an Ethernet switch port. More...
#include <etherswitch.hh>
 
  
| Classes | |
| class | PortFifo | 
| struct | PortFifoEntry | 
| Public Member Functions | |
| Interface (const std::string &name, EtherSwitch *_etherSwitch, uint64_t outputBufferSize, Tick delay, Tick delay_var, double rate, unsigned id) | |
| bool | recvPacket (EthPacketPtr packet) | 
| When a packet is received from a device, route it through an (several) output queue(s)  More... | |
| void | enqueue (EthPacketPtr packet, unsigned senderId) | 
| enqueue packet to the outputFifo  More... | |
| void | sendDone () | 
| Tick | switchingDelay () | 
| Interface * | lookupDestPort (networking::EthAddr destAddr) | 
| void | learnSenderAddr (networking::EthAddr srcMacAddr, Interface *sender) | 
| void | serialize (CheckpointOut &cp) const | 
| Serialize an object.  More... | |
| void | unserialize (CheckpointIn &cp) | 
| Unserialize an object.  More... | |
|  Public Member Functions inherited from gem5::EtherInt | |
| EtherInt (const std::string &name, int idx=InvalidPortID) | |
| virtual | ~EtherInt () | 
| const std::string & | name () const | 
| Return port name (for DPRINTF).  More... | |
| void | bind (Port &peer) override | 
| Attach to a peer port.  More... | |
| void | unbind () override | 
| Dettach from a peer port.  More... | |
| void | setPeer (EtherInt *p) | 
| EtherInt * | getPeer () | 
| void | recvDone () | 
| bool | sendPacket (EthPacketPtr packet) | 
| bool | askBusy () | 
| virtual bool | isBusy () | 
|  Public Member Functions inherited from gem5::Port | |
| virtual | ~Port () | 
| Virtual destructor due to inheritance.  More... | |
| Port & | getPeer () | 
| Return a reference to this port's peer.  More... | |
| const std::string | name () const | 
| Return port name (for DPRINTF).  More... | |
| PortID | getId () const | 
| Get the port id.  More... | |
| bool | isConnected () const | 
| Is this port currently connected to a peer?  More... | |
| void | takeOverFrom (Port *old) | 
| A utility function to make it easier to swap out ports.  More... | |
|  Public Member Functions inherited from gem5::Serializable | |
| Serializable () | |
| virtual | ~Serializable () | 
| void | serializeSection (CheckpointOut &cp, const char *name) const | 
| Serialize an object into a new section.  More... | |
| void | serializeSection (CheckpointOut &cp, const std::string &name) const | 
| void | unserializeSection (CheckpointIn &cp, const char *name) | 
| Unserialize an a child object.  More... | |
| void | unserializeSection (CheckpointIn &cp, const std::string &name) | 
| Protected Member Functions | |
| void | transmit () | 
|  Protected Member Functions inherited from gem5::Port | |
| void | reportUnbound () const | 
| Port (const std::string &_name, PortID _id) | |
| Abstract base class for ports.  More... | |
| Protected Attributes | |
| PortFifo | outputFifo | 
| output fifo at each interface  More... | |
| EventFunctionWrapper | txEvent | 
|  Protected Attributes inherited from gem5::EtherInt | |
| std::string | portName | 
| EtherInt * | peer | 
|  Protected Attributes inherited from gem5::Port | |
| const PortID | id | 
| A numeric identifier to distinguish ports in a vector, and set to InvalidPortID in case this port is not part of a vector.  More... | |
| Port * | _peer | 
| A pointer to this port's peer.  More... | |
| bool | _connected | 
| Whether this port is currently connected to a peer port.  More... | |
| Private Attributes | |
| const double | ticksPerByte | 
| const Tick | switchDelay | 
| const Tick | delayVar | 
| const unsigned | interfaceId | 
| EtherSwitch * | parent | 
| Additional Inherited Members | |
|  Static Public Member Functions inherited from gem5::Serializable | |
| static const std::string & | currentSection () | 
| Gets the fully-qualified name of the active section.  More... | |
| static void | generateCheckpointOut (const std::string &cpt_dir, std::ofstream &outstream) | 
| Generate a checkpoint file so that the serialization can be routed to it.  More... | |
Model for an Ethernet switch port.
Definition at line 69 of file etherswitch.hh.
| gem5::EtherSwitch::Interface::Interface | ( | const std::string & | name, | 
| EtherSwitch * | _etherSwitch, | ||
| uint64_t | outputBufferSize, | ||
| Tick | delay, | ||
| Tick | delay_var, | ||
| double | rate, | ||
| unsigned | id | ||
| ) | 
Definition at line 126 of file etherswitch.cc.
References transmit().
| void gem5::EtherSwitch::Interface::enqueue | ( | EthPacketPtr | packet, | 
| unsigned | senderId | ||
| ) | 
enqueue packet to the outputFifo
Definition at line 165 of file etherswitch.cc.
References gem5::curTick().
Referenced by recvPacket().
| void gem5::EtherSwitch::Interface::learnSenderAddr | ( | networking::EthAddr | srcMacAddr, | 
| Interface * | sender | ||
| ) | 
Definition at line 237 of file etherswitch.cc.
References gem5::curTick(), DPRINTF, gem5::EtherSwitch::SwitchTableEntry::interface, gem5::EtherSwitch::SwitchTableEntry::lastUseTime, and gem5::EtherInt::name().
| EtherSwitch::Interface * gem5::EtherSwitch::Interface::lookupDestPort | ( | networking::EthAddr | destAddr | ) | 
Definition at line 213 of file etherswitch.cc.
References gem5::curTick(), and DPRINTF.
| 
 | virtual | 
When a packet is received from a device, route it through an (several) output queue(s)
Implements gem5::EtherInt.
Definition at line 138 of file etherswitch.cc.
References gem5::networking::EthAddr::broadcast(), DPRINTF, enqueue(), gem5::networking::EthAddr::multicast(), gem5::Named::name(), and gem5::EtherInt::name().
| 
 | inlinevirtual | 
Implements gem5::EtherInt.
Definition at line 84 of file etherswitch.hh.
| 
 | virtual | 
Serialize an object.
Output an object's state into the current checkpoint section.
| cp | Checkpoint state | 
Implements gem5::Serializable.
Definition at line 276 of file etherswitch.cc.
References SERIALIZE_SCALAR.
| Tick gem5::EtherSwitch::Interface::switchingDelay | ( | ) | 
Definition at line 202 of file etherswitch.cc.
References gem5::Random::random(), and gem5::random_mt.
| 
 | protected | 
Definition at line 181 of file etherswitch.cc.
References gem5::curTick(), DPRINTF, and gem5::sim_clock::as_int::ns.
Referenced by Interface().
| 
 | virtual | 
Unserialize an object.
Read an object's state from the current checkpoint section.
| cp | Checkpoint state | 
Implements gem5::Serializable.
Definition at line 289 of file etherswitch.cc.
References UNSERIALIZE_SCALAR.
| 
 | private | 
Definition at line 96 of file etherswitch.hh.
| 
 | private | 
Definition at line 97 of file etherswitch.hh.
| 
 | protected | 
output fifo at each interface
Definition at line 173 of file etherswitch.hh.
| 
 | private | 
Definition at line 99 of file etherswitch.hh.
| 
 | private | 
Definition at line 95 of file etherswitch.hh.
| 
 | private | 
Definition at line 94 of file etherswitch.hh.
| 
 | protected | 
Definition at line 175 of file etherswitch.hh.