Go to the documentation of this file.
28 #ifndef __MEM_SYS_BRIDGE_HH__
29 #define __MEM_SYS_BRIDGE_HH__
33 #include "debug/SysBridge.hh"
35 #include "params/SysBridge.hh"
353 #endif //__MEM_SYS_BRIDGE_HH__
Tick recvAtomic(PacketPtr pkt) override
Receive an atomic request packet from the peer.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
bool tryTiming(PacketPtr pkt) const
Check if the responder can handle a timing request.
bool sendTimingReq(PacketPtr pkt)
Attempt to send a timing request to the responder port by calling its corresponding receive function.
void sendFunctionalSnoop(PacketPtr pkt) const
Send a functional snoop request packet, where the data is instantly updated everywhere in the memory ...
void sendRetryReq()
Send a retry to the request port that previously attempted a sendTimingReq to this response port and ...
SysBridgeTargetPort * targetPort
AddrRangeList getAddrRanges() const override
Get a list of the non-overlapping address ranges the owner is responsible for.
void sendRetrySnoopResp()
Send a retry to the request port that previously attempted a sendTimingSnoopResp to this response por...
void recvTimingSnoopReq(PacketPtr pkt) override
Receive a timing snoop request from the peer.
void pushSenderState(SenderState *sender_state)
Push a new sender state to the packet and make the current sender state the predecessor of the new on...
RequestPtr req
A pointer to the original request.
Tick sendAtomic(PacketPtr pkt)
Send an atomic request packet, where the data is moved and the state is updated in zero time,...
bool recvTimingResp(PacketPtr pkt) override
Receive a timing response from the peer.
SysBridgeSourcePort sourcePort
static void restoreReqID(PacketPtr pkt, const PacketData &data)
void recvFunctional(PacketPtr pkt) override
Receive a functional request packet from the peer.
bool tryTiming(PacketPtr pkt) override
Availability request from the peer.
const PortID InvalidPortID
SysBridgeSenderState(const PacketData &data)
A RequestPort is a specialisation of a Port, which implements the default protocol for the three diff...
SysBridgeTargetPort targetPort
void recvRangeChange() override
Called to receive an address range change from the peer response port.
Tick sendAtomicBackdoor(PacketPtr pkt, MemBackdoorPtr &backdoor)
Send an atomic request packet like above, but also request a backdoor to the data being accessed.
void sendFunctional(PacketPtr pkt) const
Send a functional request packet, where the data is instantly updated everywhere in the memory system...
SysBridgeSourcePort * sourcePort
PacketData replaceReqID(PacketPtr pkt)
RequestorID requestorId() const
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
SysBridge(const SysBridgeParams &p)
virtual void sendRetryResp()
Send a retry to the response port that previously attempted a sendTimingResp to this request port and...
std::shared_ptr< Request > RequestPtr
void recvReqRetry() override
Called by the peer if sendTimingReq was called on this peer (causing recvTimingReq to be called on th...
SysBridgeTargetPort(const std::string &_name, SimObject *owner, SysBridgeSourcePort *source_port, RequestorID _id)
bool sendTimingResp(PacketPtr pkt)
Attempt to send a timing response to the request port by calling its corresponding receive function.
void sendTimingSnoopReq(PacketPtr pkt)
Attempt to send a timing snoop request packet to the request port by calling its corresponding receiv...
bool recvTimingReq(PacketPtr pkt) override
Receive a timing request from the peer.
AddrRangeList getAddrRanges() const
Get the address ranges of the connected responder port.
Abstract superclass for simulation objects.
SysBridgeSourcePort(const std::string &_name, SimObject *owner, SysBridgeTargetPort *target_port, RequestorID _id)
A virtual base opaque structure used to hold state associated with the packet (e.g....
void recvRespRetry() override
Called by the peer if sendTimingResp was called on this protocol (causing recvTimingResp to be called...
void recvFunctionalSnoop(PacketPtr pkt) override
Receive a functional snoop request packet from the peer.
void sendRangeChange() const
Called by the owner to send a range change.
SenderState * popSenderState()
Pop the top of the state stack and return a pointer to it.
Tick recvAtomicBackdoor(PacketPtr pkt, MemBackdoorPtr &backdoor) override
Default implementations.
A ResponsePort is a specialization of a port.
Ports are used to interface objects to each other.
BridgingPort(RequestorID _id)
void recvRetrySnoopResp() override
Called by the peer if sendTimingSnoopResp was called on this protocol (causing recvTimingSnoopResp to...
Tick recvAtomicSnoop(PacketPtr pkt) override
Default implementations.
Tick sendAtomicSnoop(PacketPtr pkt)
Send an atomic snoop request packet, where the data is moved and the state is updated in zero time,...
Each System object in gem5 is responsible for a set of RequestorIDs which identify different sources ...
static void restoreReqID(PacketPtr pkt, const PacketData &data, PacketData &backup)
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
bool sendTimingSnoopResp(PacketPtr pkt)
Attempt to send a timing snoop response packet to the response port by calling its corresponding rece...
bool recvTimingSnoopResp(PacketPtr pkt) override
Receive a timing snoop response from the peer.
const PacketData & data() const
Generated on Wed Jul 13 2022 10:39:26 for gem5 by doxygen 1.8.17