38 #ifndef __MEM_MEM_DELAY_HH__ 39 #define __MEM_MEM_DELAY_HH__ 44 struct MemDelayParams;
45 struct SimpleMemDelayParams;
107 bool recvTimingReq(
PacketPtr pkt)
override;
108 void recvFunctional(
PacketPtr pkt)
override;
109 bool recvTimingSnoopResp(
PacketPtr pkt)
override;
180 #endif //__MEM_MEM_DELAY_HH__ Ports are used to interface objects to each other.
void sendRangeChange() const
Called by the owner to send a range change.
const PortID InvalidPortID
bool tryTiming(PacketPtr pkt) override
Availability request from the peer.
This abstract component provides a mechanism to delay packets.
The QueuedMasterPort combines two queues, a request queue and a snoop response queue, that both share the same port.
RespPacketQueue respQueue
A queued port is a port that has an infinite queue for outgoing packets and thus decouples the module...
const Tick writeRespDelay
SnoopRespPacketQueue snoopRespQueue
const Params * params() const
Tick recvAtomicSnoop(PacketPtr pkt) override
Receive an atomic snoop request packet from our peer.
Declaration of the queued port.
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
void recvRangeChange() override
Called to receive an address range change from the peer slave port.
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
uint64_t Tick
Tick count type.
MasterPort(const std::string &_name, MemDelay &_parent)
virtual Tick delayReq(PacketPtr pkt)
Delay a request by some number of ticks.
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
ClockedObject declaration and implementation.
void recvTimingSnoopReq(PacketPtr pkt) override
Receive a timing snoop request from the peer.
virtual Tick delaySnoopResp(PacketPtr pkt)
Delay a snoop response by some number of ticks.
AddrRangeList getAddrRanges() const override
Get a list of the non-overlapping address ranges the owner is responsible for.
bool isSnooping() const override
Determine if this master port is snooping or not.
bool trySatisfyFunctional(PacketPtr pkt)
Check the list of buffered packets against the supplied functional request.
Delay packets by a constant time.
bool isSnooping() const
Find out if the peer master port is snooping or not.
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
void recvFunctionalSnoop(PacketPtr pkt) override
Receive a functional snoop request packet from the peer.
bool recvTimingResp(PacketPtr pkt) override
Receive a timing response from the peer.
AddrRangeList getAddrRanges() const
Get the address ranges of the connected slave port.
MemDelay(const MemDelayParams *params)
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
virtual Tick delayResp(PacketPtr pkt)
Delay a response by some number of ticks.