Go to the documentation of this file.
47 #ifndef __MEM_BRIDGE_HH__
48 #define __MEM_BRIDGE_HH__
54 #include "params/Bridge.hh"
94 class BridgeRequestPort;
324 void init()
override;
333 #endif //__MEM_BRIDGE_HH__
BridgeResponsePort cpuSidePort
Response port of the bridge.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
std::deque< DeferredPacket > transmitList
Request packet queue.
std::unique_ptr< Packet > pendingDelete
Upstream caches need this packet until true is returned, so hold it for deletion until a subsequent c...
void retryStalledReq()
Retry any stalled request that we have failed to accept at an earlier point in time.
const Cycles delay
Minimum request delay though this bridge.
void schedTimingResp(PacketPtr pkt, Tick when)
Queue a response packet to be sent out later and also schedule a send if necessary.
BridgeRequestPort(const std::string &_name, Bridge &_bridge, BridgeResponsePort &_cpuSidePort, Cycles _delay, int _req_limit)
Constructor for the BridgeRequestPort.
DeferredPacket(PacketPtr _pkt, Tick _tick)
Tick recvAtomic(PacketPtr pkt)
When receiving a Atomic requestfrom the peer port, pass it to the bridge.
const PortID InvalidPortID
Port on the side that forwards requests and receives responses.
BridgeResponsePort(const std::string &_name, Bridge &_bridge, BridgeRequestPort &_memSidePort, Cycles _delay, int _resp_limit, std::vector< AddrRange > _ranges)
Constructor for the BridgeResponsePort.
AddrRangeList getAddrRanges() const
When receiving a address range request the peer port, pass it to the bridge.
A RequestPort is a specialisation of a Port, which implements the default protocol for the three diff...
Cycles is a wrapper class for representing cycle counts, i.e.
bool recvTimingReq(PacketPtr pkt)
When receiving a timing request from the peer port, pass it to the bridge.
bool trySatisfyFunctional(PacketPtr pkt)
Check a functional request against the packets in our request queue.
void trySendTiming()
Handle send event, scheduled when the packet at the head of the response queue is ready to transmit (...
A bridge is used to interface two different crossbars (or in general a memory-mapped requestor and re...
void recvFunctional(PacketPtr pkt)
When receiving a Functional request from the peer port, pass it to the bridge.
bool retryReq
If we should send a retry when space becomes available.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
bool recvTimingResp(PacketPtr pkt)
When receiving a timing request from the peer port, pass it to the bridge.
BridgeResponsePort & cpuSidePort
The response port on the other side of the bridge.
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
The port on the side that receives requests and sends responses.
unsigned int outstandingResponses
Counter to track the outstanding responses.
unsigned int respQueueLimit
Max queue size for reserved responses.
std::deque< DeferredPacket > transmitList
Response packet queue.
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
Bridge & bridge
The bridge to which this port belongs.
A ResponsePort is a specialization of a port.
EventFunctionWrapper sendEvent
Send event for the request queue.
BridgeRequestPort memSidePort
Request port of the bridge.
const Cycles delay
Minimum delay though this bridge.
const unsigned int reqQueueLimit
Max queue size for request packets.
void recvRespRetry()
When receiving a retry request from the peer port, pass it to the bridge.
Ports are used to interface objects to each other.
EventFunctionWrapper sendEvent
Send event for the response queue.
void schedTimingReq(PacketPtr pkt, Tick when)
Queue a request packet to be sent out later and also schedule a send if necessary.
const AddrRangeList ranges
Address ranges to pass through the bridge.
A deferred packet stores a packet along with its scheduled transmission time.
void trySendTiming()
Handle send event, scheduled when the packet at the head of the outbound queue is ready to transmit (...
Bridge & bridge
The bridge to which this port belongs.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
bool respQueueFull() const
Is this side blocked from accepting new response packets.
BridgeRequestPort & memSidePort
Request port on the other side of the bridge.
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
void recvReqRetry()
When receiving a retry request from the peer port, pass it to the bridge.
bool reqQueueFull() const
Is this side blocked from accepting new request packets.
Generated on Tue Sep 7 2021 14:53:47 for gem5 by doxygen 1.8.17