Go to the documentation of this file.
34 #ifndef __DEV_NET_NS_GIGE_HH__
35 #define __DEV_NET_NS_GIGE_HH__
44 #include "params/NSGigE.hh"
378 #endif // __DEV_NET_NS_GIGE_HH__
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
Dummy class to keep the Python class hierarchy in sync with the C++ object hierarchy.
bool rxFilter(const EthPacketPtr &packet)
const uint8_t EEPROM_PMATCH0_ADDR
const uint16_t FHASH_ADDR
uint8_t filterHash[FHASH_SIZE]
for hash table memory.
Tick writeConfig(PacketPtr pkt) override
This is to write to the PCI general configuration registers.
Addr txFragPtr
ptr to the next byte in the current fragment
NS DP83820 Ethernet device model.
const uint8_t EEPROM_SIZE
Addr rxFragPtr
ptr to the next byte in current fragment
RxState
Receive State Machine States.
bool rxFilterEnable
receive address filter
NSGigEInt(const std::string &name, NSGigE *d)
Ethernet device registers.
TxState
Transmit State Machine states.
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
const std::string & name() const
Return port name (for DPRINTF).
bool rxHalt
halt the rx state machine after current packet
dp_regs regs
device register file
void drainResume() override
Resume execution after a successful drain.
bool txHalt
halt the tx state machine after next packet
const PortID InvalidPortID
EventFunctionWrapper txKickEvent
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
uint32_t txDescCnt
count of bytes remaining in the current descriptor
EthPacketPtr txPacket
various helper vars
const uint16_t FHASH_SIZE
EventFunctionWrapper rxKickEvent
std::shared_ptr< EthPacketData > EthPacketPtr
RxState rxState
rx State Machine
const Params & params() const
uint8_t perfectMatch[ETH_ADDR_LEN]
for perfect match memory.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
bool recvPacket(EthPacketPtr packet)
uint64_t Tick
Tick count type.
bool CTDD
Current Transmit Descriptor Done.
ns_desc32 txDesc32
DescCaches.
const uint8_t EEPROM_PMATCH1_ADDR
EventFunctionWrapper rxDmaWriteEvent
EEPROMState eepromState
EEPROM State Machine.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
EventFunctionWrapper txDmaReadEvent
virtual bool recvPacket(EthPacketPtr pkt)
bool CRDD
Current Receive Descriptor Done.
EventFunctionWrapper * intrEvent
void transmit()
Retransmit event.
const uint8_t EEPROM_PMATCH2_ADDR
Ports are used to interface objects to each other.
bool ioEnable
pci settings
void devIntrPost(uint32_t interrupts)
Interrupt management.
EventFunctionWrapper txEvent
void eepromKick()
Advance the EEPROM state machine Called on rising edge of EEPROM clock bit in MEAR.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
void serialize(CheckpointOut &cp) const override
Serialize an object.
EEPROMState
EEPROM State Machine States.
Tick read(PacketPtr pkt) override
This reads the device registers, which are detailed in the NS83820 spec sheet.
EventFunctionWrapper txDmaWriteEvent
bool cpuIntrPending() const
std::ostream CheckpointOut
void cpuIntrPost(Tick when)
uint32_t rxPktBytes
num of bytes in the current packet being drained from rxDataFifo
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
NSGigE(const Params ¶ms)
const uint8_t EEPROM_READ
EventFunctionWrapper rxDmaReadEvent
void devIntrClear(uint32_t interrupts)
uint32_t rxDescCnt
count of bytes remaining in the current descriptor
Generated on Thu Jun 16 2022 10:41:52 for gem5 by doxygen 1.8.17