Go to the documentation of this file.
33 #ifndef __DEV_NET_I8254XGBE_HH__
34 #define __DEV_NET_I8254XGBE_HH__
43 #include "debug/EthernetDesc.hh"
44 #include "debug/EthernetIntr.hh"
51 #include "params/IGbE.hh"
100 "Posting RXT interrupt because RDTR timer expired\n");
110 "Posting RXT interrupt because RADV timer expired\n");
120 "Posting TXDW interrupt because TADV timer expired\n");
130 "Posting TXDW interrupt because TIDV timer expired\n");
187 virtual long descLen()
const = 0;
457 "Completion writeback Addr: %#x enabled: %d\n",
466 DPRINTF(EthernetDesc,
"Completion writeback complete\n");
483 void init()
override;
522 #endif //__DEV_NET_I8254XGBE_HH__
EventFunctionWrapper nullEvent
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
void wbComplete()
Called by event when dma to writeback descriptors is completed.
void getPacketData(EthPacketPtr p)
std::string annUsedCacheQ
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
virtual bool hasOutstandingEvents()
long descHead() const override
EventFunctionWrapper pktHdrEvent
EventFunctionWrapper headerEvent
Tick writeConfig(PacketPtr pkt) override
Write to the PCI config space data that is stored locally.
DrainState drainState() const
Return the current drain state of an object.
virtual long descLen() const =0
void postInterrupt(igbreg::IntTypes t, bool now=false)
Write an interrupt into the interrupt pending register and check mask and interrupt limit timer befor...
void completionWriteback(Addr a, bool enabled)
void unserialize(CheckpointIn &cp) override
Unserialize an object.
virtual void fetchAfterWb()=0
void areaChanged()
If the address/len/head change when we've got descriptors that are dirty that is very bad.
unsigned bytesCopied
Bytes of packet that have been copied, so we know when to set EOP.
void cpuClearInt()
Clear the interupt line to the cpu.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
virtual Addr descBase() const =0
unsigned descInBlock(unsigned num_desc)
Return the number of dsecriptors in a cache block for threshold operations.
const std::string & name() const
Return port name (for DPRINTF).
void writeback(Addr aMask)
Addr descBase() const override
void unserialize(CheckpointIn &cp) override
Unserialize an object.
EventFunctionWrapper wbDelayEvent
Addr pciToDma(Addr a)
Shortcut for DMA address translation.
void drainResume() override
Resume execution after a successful drain.
long descTail() const override
DrainState drain() override
Draining is the process of clearing out the states of SimObjects.These are the SimObjects that are pa...
void chkInterrupt()
Check and see if changes to the mask register have caused an interrupt to need to be sent or perhaps ...
const PortID InvalidPortID
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
long descHead() const override
EthPacketPtr pktPtr
The packet that is currently being dmad to memory if any.
IGbE(const Params ¶ms)
bool packetAvailable()
Ask if the packet has been transfered so the state machine can give it to the fifo.
int splitCount
Variable to head with header/data completion events.
DescCache(IGbE *i, const std::string n, int s)
void serialize(CheckpointOut &cp) const override
Serialize an object.
void pktComplete()
Called by event when dma to write packet is completed.
EventFunctionWrapper fetchDelayEvent
void pktComplete()
Called by event when dma to write packet is completed.
virtual bool recvPacket(EthPacketPtr pkt)
unsigned descUnused() const
bool hasOutstandingEvents() override
void restartClock()
This function is used to restart the clock so it can handle things like draining and resume in one pl...
Basic support for object serialization.
DrainState
Object drain/handover states.
EventFunctionWrapper wbEvent
EventFunctionWrapper tadvEvent
Addr descBase() const override
EventFunctionWrapper pktEvent
std::shared_ptr< EthPacketData > EthPacketPtr
void fetchAfterWb() override
const Params & params() const
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
TxDescCache(IGbE *i, std::string n, int s)
uint64_t Tick
Tick count type.
void actionAfterWb() override
EventFunctionWrapper pktEvent
void serialize(CheckpointOut &cp) const override
Serialize an object.
long descLen() const override
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
void updateHead(long h) override
unsigned int cacheBlockSize() const
std::string annUnusedCacheQ
bool hasOutstandingEvents() override
void fetchComplete()
Called by event when dma to read descriptors is completed.
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
const uint8_t EEPROM_SIZE
unsigned descUsed() const
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
long descLen() const override
IGbEInt(const std::string &name, IGbE *d)
EventFunctionWrapper fetchEvent
EventFunctionWrapper interEvent
bool packetMultiDesc()
Ask if this packet is composed of multiple descriptors so even if we've got data, we need to wait for...
EventFunctionWrapper tidvEvent
void serialize(CheckpointOut &cp) const override
Serialize an object.
virtual void updateHead(long h)=0
void checkDrain()
Check if all the draining things that need to occur have occured and handle the drain event if so.
EventFunctionWrapper radvEvent
std::deque< T * > CacheType
Ports are used to interface objects to each other.
void processContextDesc()
unsigned descLeft() const
virtual long descHead() const =0
void updateHead(long h) override
void delayIntEvent()
Send an interrupt to the cpu.
unsigned getPacketSize(EthPacketPtr p)
Tell the cache to DMA a packet from main memory into its buffer and return the size the of the packet...
std::string annSmFetch
Annotate sm.
std::string annUnusedDescQ
std::ostream CheckpointOut
void fetchAfterWb() override
uint16_t flash[igbreg::EEPROM_SIZE]
bool packetDone()
Check if the dma on the packet has completed and RX state machine can continue.
@ Running
Running normally.
Addr pciToDma(Addr pci_addr) const
bool ethRxPkt(EthPacketPtr packet)
void unserialize(CheckpointIn &cp) override
Unserialize an object.
EventFunctionWrapper tickEvent
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
virtual void enableSm()=0
void serialize(CheckpointOut &cp) const override
Serialize an object.
EventFunctionWrapper pktDataEvent
long descTail() const override
RxDescCache(IGbE *i, std::string n, int s)
EventFunctionWrapper rdtrEvent
virtual long descTail() const =0
bool scheduled() const
Determine if the current event is scheduled.
int writePacket(EthPacketPtr packet, int pkt_offset)
Write the given packet into the buffer(s) pointed to by the descriptor and update the book keeping.
virtual void actionAfterWb()
void fetchDescriptors()
Fetch a chunk of descriptors into the descriptor cache.
bool packetWaiting()
Ask if we are still waiting for the packet to be transfered.
Generated on Wed May 4 2022 12:13:57 for gem5 by doxygen 1.8.17