45#ifndef __DEV_NET_ETHERLINK_HH__ 
   46#define __DEV_NET_ETHERLINK_HH__ 
   54#include "params/EtherLink.hh" 
Defines global host-dependent types: Counter, Tick, and (indirectly) {int,uint}{8,...
virtual void sendDone()=0
const std::string & name() const
Return port name (for DPRINTF).
bool recvPacket(EthPacketPtr packet)
void unserialize(const std::string &base, CheckpointIn &cp)
const std::string objName
void serialize(const std::string &base, CheckpointOut &cp) const
std::deque< std::pair< Tick, EthPacketPtr > > txQueue
Maintain a queue of in-flight packets.
EventFunctionWrapper txQueueEvent
const double ticksPerByte
const std::string name() const
bool transmit(EthPacketPtr packet)
void setRxInt(Interface *i)
void setTxInt(Interface *i)
EventFunctionWrapper doneEvent
void txComplete(EthPacketPtr packet)
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
void serialize(CheckpointOut &cp) const override
Serialize an object.
Ports are used to interface objects to each other.
Abstract superclass for simulation objects.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
const PortID InvalidPortID
std::ostream CheckpointOut
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
uint64_t Tick
Tick count type.
std::shared_ptr< EthPacketData > EthPacketPtr