Go to the documentation of this file.
46 #ifndef __MEM_PORT_HH__
47 #define __MEM_PORT_HH__
228 panic(
"%s was not expecting an atomic snoop request\n",
name());
235 panic(
"%s was not expecting a functional snoop request\n",
name());
241 panic(
"%s was not expecting a timing snoop request.\n",
name());
247 panic(
"%s was not expecting a snoop retry.\n",
name());
445 panic(
"%s was not expecting a %s\n",
name(), __func__);
451 panic(
"%s was not expecting a timing snoop response\n",
name());
536 #endif //__MEM_PORT_HH__
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.
void send(FunctionalResponseProtocol *peer, PacketPtr pkt) const
Send a functional request packet, where the data is instantly updated everywhere in the memory system...
bool sendTimingReq(PacketPtr pkt)
Attempt to send a timing request to the responder port by calling its corresponding receive function.
void recvFunctionalSnoop(PacketPtr pkt) override
Receive a functional snoop request packet from the peer.
void unbind() override
Unbind this request port and the associated response port.
const std::string name() const
Return port name (for DPRINTF).
void bind(Port &peer) override
Bind this request port to a response port.
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 ...
void sendRetrySnoopResp()
Send a retry to the request port that previously attempted a sendTimingSnoopResp to this response por...
bool sendResp(TimingRequestProtocol *peer, PacketPtr pkt)
Attempt to send a timing response to the peer by calling its corresponding receive function.
RequestPort * _requestPort
void reportUnbound() const
Tick sendSnoop(AtomicRequestProtocol *peer, PacketPtr pkt)
Send an atomic snoop request packet, where the data is moved and the state is updated in zero time,...
Tick sendAtomic(PacketPtr pkt)
Send an atomic request packet, where the data is moved and the state is updated in zero time,...
void unbind() override
We let the request port do the work, so these don't do anything.
RequestPort(const std::string &name, SimObject *_owner, PortID id=InvalidPortID)
Request port.
void sendRetryReq(TimingRequestProtocol *peer)
Send a retry to the peer that previously attempted a sendTimingReq to this protocol and failed.
void responderUnbind()
Called by the request port to unbind.
bool sendReq(TimingResponseProtocol *peer, PacketPtr pkt)
Attempt to send a timing request to the peer by calling its corresponding receive function.
void recvRetrySnoopResp() override
Called by the peer if sendTimingSnoopResp was called on this protocol (causing recvTimingSnoopResp to...
virtual void recvRangeChange()
Called to receive an address range change from the peer response port.
void sendRetrySnoopResp(TimingRequestProtocol *peer)
Send a retry to the peer that previously attempted a sendTimingSnoopResp to this peer and failed.
const PortID InvalidPortID
A RequestPort is a specialisation of a Port, which implements the default protocol for the three diff...
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...
void responderBind(RequestPort &request_port)
Called by the request port to bind.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
Tick send(AtomicResponseProtocol *peer, PacketPtr pkt)
Send an atomic request packet, where the data is moved and the state is updated in zero time,...
bool isSnooping() const
Find out if the peer request port is snooping or not.
void recvTimingSnoopReq(PacketPtr pkt) override
Receive a timing snoop request from the peer.
virtual void sendRetryResp()
Send a retry to the response port that previously attempted a sendTimingResp to this request port and...
MasterPort(const std::string &name, SimObject *_owner, PortID id=InvalidPortID)
SlavePort(const std::string &name, SimObject *_owner, PortID id=InvalidPortID)
virtual bool isSnooping() const
Determine if this request port is snooping or not.
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...
AddrRangeList getAddrRanges() const
Get the address ranges of the connected responder port.
Abstract superclass for simulation objects.
bool sendSnoopResp(TimingResponseProtocol *peer, PacketPtr pkt)
Attempt to send a timing snoop response packet to it's peer by calling its corresponding receive func...
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
const std::string & name()
bool trySend(TimingResponseProtocol *peer, PacketPtr pkt) const
Check if the peer can handle a timing request.
ResponsePort(const std::string &name, SimObject *_owner, PortID id=InvalidPortID)
Response port.
void sendRangeChange() const
Called by the owner to send a range change.
void bind(Port &peer) override
Attach to a peer port.
virtual AddrRangeList getAddrRanges() const =0
Get a list of the non-overlapping address ranges the owner is responsible for.
A ResponsePort is a specialization of a port.
bool tryTiming(PacketPtr pkt) override
Availability request from the peer.
Ports are used to interface objects to each other.
Tick sendBackdoor(AtomicResponseProtocol *peer, PacketPtr pkt, MemBackdoorPtr &backdoor)
Send an atomic request packet like above, but also request a backdoor to the data being accessed.
void sendSnoop(FunctionalRequestProtocol *peer, PacketPtr pkt) const
Send a functional snoop request packet, where the data is instantly updated everywhere in the memory ...
ResponsePort * _responsePort
bool defaultBackdoorWarned
void sendRetryResp(TimingResponseProtocol *peer)
Send a retry to the peer that previously attempted a sendTimingResp to this protocol and failed.
Tick sendAtomicSnoop(PacketPtr pkt)
Send an atomic snoop request packet, where the data is moved and the state is updated in zero time,...
Tick recvAtomicBackdoor(PacketPtr pkt, MemBackdoorPtr &backdoor) override
Default implementations.
bool recvTimingSnoopResp(PacketPtr pkt) override
Receive a timing snoop response from the peer.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Tick recvAtomicSnoop(PacketPtr pkt) override
Default implementations.
void printAddr(Addr a)
Inject a PrintReq for the given address to print the state of that address throughout the memory syst...
bool sendTimingSnoopResp(PacketPtr pkt)
Attempt to send a timing snoop response packet to the response port by calling its corresponding rece...
void sendSnoopReq(TimingRequestProtocol *peer, PacketPtr pkt)
Attempt to send a timing snoop request packet to the peer by calling its corresponding receive functi...
#define panic(...)
This implements a cprintf based panic() function.
Generated on Thu Jun 16 2022 10:41:56 for gem5 by doxygen 1.8.17