34 #ifndef __DEV_NET_NS_GIGE_HH__ 35 #define __DEV_NET_NS_GIGE_HH__ 44 #include "params/NSGigE.hh" 103 uint8_t perfectMatch[ETH_ADDR_LEN];
251 void rxDmaReadDone();
254 void rxDmaWriteDone();
257 void txDmaReadDone();
260 void txDmaWriteDone();
291 if (txState == txFifoBlock)
314 void devIntrPost(uint32_t interrupts);
315 void devIntrClear(uint32_t interrupts);
316 void devIntrChangeMask();
321 void cpuIntrPost(
Tick when);
331 return dynamic_cast<const Params *
>(_params);
337 Port &getPort(
const std::string &if_name,
345 bool cpuIntrPending()
const;
354 void drainResume()
override;
374 #endif // __DEV_NET_NS_GIGE_HH__
Ports are used to interface objects to each other.
EventFunctionWrapper txDmaReadEvent
const uint8_t EEPROM_READ
const std::string & name()
Addr rxFragPtr
ptr to the next byte in current fragment
const PortID InvalidPortID
Dummy class to keep the Python class hierarchy in sync with the C++ object hierarchy.
dp_regs regs
device register file
EEPROMState
EEPROM State Machine States.
EventFunctionWrapper rxDmaWriteEvent
const uint8_t EEPROM_PMATCH2_ADDR
const Params * params() const
EventFunctionWrapper txDmaWriteEvent
TxState
Transmit State Machine states.
EEPROMState eepromState
EEPROM State Machine.
const uint16_t FHASH_SIZE
bool txHalt
halt the tx state machine after next packet
uint32_t rxDescCnt
count of bytes remaining in the current descriptor
EventFunctionWrapper rxDmaReadEvent
NSGigEInt(const std::string &name, NSGigE *d)
Addr txFragPtr
ptr to the next byte in the current fragment
ns_desc32 txDesc32
DescCaches.
const uint8_t EEPROM_PMATCH0_ADDR
uint64_t Tick
Tick count type.
const uint8_t EEPROM_SIZE
const uint8_t EEPROM_PMATCH1_ADDR
void serialize(const ThreadContext &tc, CheckpointOut &cp)
Thread context serialization helpers.
bool CTDD
Current Transmit Descriptor Done.
std::shared_ptr< EthPacketData > EthPacketPtr
Ethernet device registers.
bool ioEnable
pci settings
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
const uint16_t FHASH_ADDR
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
Base Ethernet Device declaration.
RxState
Receive State Machine States.
Ethernet device register definitions for the National Semiconductor DP83820 Ethernet controller...
EventFunctionWrapper * intrEvent
bool rxHalt
halt the rx state machine after current packet
EventFunctionWrapper rxKickEvent
EthPacketPtr txPacket
various helper vars
EventFunctionWrapper txKickEvent
std::ostream CheckpointOut
EventFunctionWrapper txEvent
uint32_t txDescCnt
count of bytes remaining in the current descriptor
void unserialize(ThreadContext &tc, CheckpointIn &cp)
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
bool rxFilterEnable
receive address filter
RxState rxState
rx State Machine
NS DP83820 Ethernet device model.
bool CRDD
Current Receive Descriptor Done.
virtual bool recvPacket(EthPacketPtr pkt)
uint32_t rxPktBytes
num of bytes in the current packet being drained from rxDataFifo
bool recvPacket(EthPacketPtr packet)