Go to the documentation of this file.
29 #ifndef __DEV_NET_SINIC_HH__
30 #define __DEV_NET_SINIC_HH__
41 #include "params/Sinic.hh"
253 void devIntrClear(uint32_t interrupts = Regs::Intr_All);
320 #endif // __DEV_NET_SINIC_HH__
PacketFifo::iterator rxIndex
Interface(const std::string &name, Device *d)
Stats::Formula avgVnicDistance
Stats::Scalar maxVnicDistance
EventFunctionWrapper rxDmaEvent
const PortID InvalidPortID
void cpuIntrPost(Tick when)
DeviceStats(Stats::Group *parent)
std::list< unsigned > VirtualList
virtual void drainResume() override
Resume execution after a successful drain.
int ContextID
Globally unique thread context ID.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
Tick read(PacketPtr pkt) override
Memory Interface.
Tick write(PacketPtr pkt) override
IPR read of device register.
uint64_t Tick
Tick count type.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
EventFunctionWrapper txEvent
void changeConfig(uint32_t newconfig)
device configuration
EtherDevBaseParams Params
void devIntrChangeMask(uint32_t newmask)
Stats::Scalar numVnicDistance
This is a simple scalar statistic, like a counter.
int64_t Counter
Statistics counter type.
void prepareIO(ContextID cpu, int index)
void devIntrClear(uint32_t interrupts=Regs::Intr_All)
void resetStats() override
Callback to reset stats.
void serialize(CheckpointOut &cp) const override
Serialization stuff.
Ports are used to interface objects to each other.
RxState
Receive State Machine States.
bool cpuIntrPending() const
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
Stats::Scalar totalVnicDistance
void devIntrPost(uint32_t interrupts)
Interrupt management.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
TxState
Transmit State Machine states.
void prepareWrite(ContextID cpu, int index)
fifo_list::iterator iterator
void rxDmaDone()
DMA parameters.
void prepareRead(ContextID cpu, int index)
PARAMS(Sinic)
Construction/Destruction/Parameters.
void transmit()
Retransmit event.
Sinic::Device::DeviceStats sinicDeviceStats
EventFunctionWrapper * intrEvent
bool rxFilter(const EthPacketPtr &packet)
receive address filter
uint64_t & regData64(Addr daddr)
std::shared_ptr< EthPacketData > EthPacketPtr
const std::string & name() const
Return port name (for DPRINTF).
bool recvPacket(EthPacketPtr packet)
device ethernet interface
std::vector< VirtualReg > VirtualRegs
EventFunctionWrapper txDmaEvent
uint32_t & regData32(Addr daddr)
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
void unserialize(CheckpointIn &cp) override
Unserialize an object.
void command(uint32_t command)
std::ostream CheckpointOut
Dummy class to keep the Python class hierarchy in sync with the C++ object hierarchy.
struct Sinic::Device::@90 regs
device register file
void serialize(CheckpointOut &cp) const override
Serialization stuff.
uint8_t & regData8(Addr daddr)
PacketFifo::iterator rxFifoPtr
virtual bool recvPacket(EthPacketPtr pkt)
Generated on Tue Jun 22 2021 15:28:28 for gem5 by doxygen 1.8.17