41 #ifndef __DEV_IO_DEVICE_HH__ 42 #define __DEV_IO_DEVICE_HH__ 45 #include "params/BasicPioDevice.hh" 46 #include "params/PioDevice.hh" 59 template <
class Device>
75 pkt->
isRead() ? device->read(pkt) : device->write(pkt);
77 return delay + receive_delay;
83 return device->getAddrRanges();
138 return dynamic_cast<const Params *
>(_params);
141 void init()
override;
143 Port &getPort(
const std::string &if_name,
169 return dynamic_cast<const Params *
>(_params);
180 #endif // __DEV_IO_DEVICE_HH__ Ports are used to interface objects to each other.
const PortID InvalidPortID
Device * device
The device that this port serves.
PioPort< PioDevice > pioPort
The pioPort that handles the requests for us and provides us requests that it sees.
The simple timing port uses a queued port to implement recvFunctional and recvTimingReq through recvA...
BasicPioDeviceParams Params
Declaration of SimpleTimingPort.
Addr pioSize
Size that the device's address range.
uint32_t headerDelay
The extra delay from seeing the packet until the header is transmitted.
AddrRangeList getAddrRanges() const override
Get a list of the non-overlapping address ranges the owner is responsible for.
uint64_t Tick
Tick count type.
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
ClockedObject declaration and implementation.
const Params * params() const
This device is the base class which all devices senstive to an address range inherit from...
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
uint32_t payloadDelay
The extra pipelining delay from seeing the packet until the end of payload is transmitted by the comp...
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
const Params * params() const
const std::string name() const
Return port name (for DPRINTF).
Tick pioDelay
Delay that the device experinces on an access.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
The PioPort class is a programmed i/o port that all devices that are sensitive to an address range us...
Addr pioAddr
Address that the device listens to.
Tick recvAtomic(PacketPtr pkt) override
Receive an atomic request packet from the peer.
const FlagsType init
This Stat is Initialized.