Go to the documentation of this file.
38 #ifndef __MEM_MEM_DELAY_HH__
39 #define __MEM_MEM_DELAY_HH__
47 struct MemDelayParams;
48 struct SimpleMemDelayParams;
185 #endif //__MEM_MEM_DELAY_HH__
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
bool recvTimingSnoopResp(PacketPtr pkt) override
Receive a timing snoop response from the peer.
void recvRangeChange() override
Called to receive an address range change from the peer response port.
void recvFunctionalSnoop(PacketPtr pkt) override
Receive a functional snoop request packet from the peer.
The QueuedRequestPort combines two queues, a request queue and a snoop response queue,...
ResponsePort responsePort
ResponsePort(const std::string &_name, MemDelay &_parent)
RespPacketQueue respQueue
bool tryTiming(PacketPtr pkt) override
Availability request from the peer.
const PortID InvalidPortID
bool isSnooping() const override
Determine if this request port is snooping or not.
This abstract component provides a mechanism to delay packets.
Tick recvAtomicSnoop(PacketPtr pkt) override
Receive an atomic snoop request packet from our peer.
bool recvTimingResp(PacketPtr pkt) override
Receive a timing response from the peer.
const Params & params() const
A queued port is a port that has an infinite queue for outgoing packets and thus decouples the module...
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
bool isSnooping() const
Find out if the peer request port is snooping or not.
SimpleMemDelay(const SimpleMemDelayParams ¶ms)
AddrRangeList getAddrRanges() const
Get the address ranges of the connected responder port.
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
void sendRangeChange() const
Called by the owner to send a range change.
bool trySatisfyFunctional(PacketPtr pkt)
virtual Tick delayResp(PacketPtr pkt)
Delay a response by some number of ticks.
SnoopRespPacketQueue snoopRespQueue
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
const Tick writeRespDelay
Tick delayResp(PacketPtr pkt) override
Delay a response by some number of ticks.
bool recvTimingReq(PacketPtr pkt) override
Receive a timing request from the peer.
Ports are used to interface objects to each other.
virtual Tick delaySnoopResp(PacketPtr pkt)
Delay a snoop response by some number of ticks.
Delay packets by a constant time.
void recvFunctional(PacketPtr pkt) override
Receive a functional request packet from the peer.
AddrRangeList getAddrRanges() const override
Get a list of the non-overlapping address ranges the owner is responsible for.
Tick delayReq(PacketPtr pkt) override
Delay a request by some number of ticks.
RequestPort(const std::string &_name, MemDelay &_parent)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
void recvTimingSnoopReq(PacketPtr pkt) override
Receive a timing snoop request from the peer.
MemDelay(const MemDelayParams ¶ms)
virtual Tick delayReq(PacketPtr pkt)
Delay a request by some number of ticks.
Tick recvAtomic(PacketPtr pkt) override
Receive an atomic request packet from the peer.
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
Generated on Tue Sep 7 2021 14:53:48 for gem5 by doxygen 1.8.17