Go to the documentation of this file.
46 #ifndef __MEM_XBAR_HH__
47 #define __MEM_XBAR_HH__
50 #include <unordered_map>
55 #include "params/BaseXBar.hh"
90 template <
typename SrcType,
typename DstType>
175 virtual void sendRetry(SrcType* retry_port) = 0;
248 const std::string&
_name) :
271 const std::string&
_name) :
294 const std::string&
_name) :
327 std::unordered_map<RequestPtr, PortID>
routeTo;
419 #endif //__MEM_XBAR_HH__
This is a simple scalar statistic, like a counter.
void sendRetry(RequestPort *retry_port) override
Sending the actual retry, in a manner specific to the individual layers.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
void failedTiming(SrcType *src_port, Tick busy_time)
Deal with a destination port not accepting a packet by potentially adding the source port to the retr...
void succeededTiming(Tick busy_time)
Deal with a destination port accepting a packet by potentially removing the source port from the retr...
The base crossbar contains the common elements of the non-coherent and coherent crossbar.
const bool useDefaultRange
If true, use address range provided by default device.
SnoopRespLayer(RequestPort &_port, BaseXBar &_xbar, const std::string &_name)
Create a snoop response layer and give it a name.
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
A function used to return the port associated with this object.
const uint32_t width
the width of the xbar in bytes
void sendRetryReq()
Send a retry to the request port that previously attempted a sendTimingReq to this response port and ...
std::vector< QueuedResponsePort * > cpuSidePorts
The memory-side ports and CPU-side ports of the crossbar.
const std::string name() const
virtual void sendRetry(SrcType *retry_port)=0
Sending the actual retry, in a manner specific to the individual layers.
const Cycles frontendLatency
Cycles of front-end pipeline including the delay to accept the request and to decode the address.
void sendRetry(ResponsePort *retry_port) override
Sending the actual retry, in a manner specific to the individual layers.
void sendRetrySnoopResp()
Send a retry to the request port that previously attempted a sendTimingSnoopResp to this response por...
void retryWaiting()
Send a retry to the port at the head of waitingForLayer.
void releaseLayer()
Release the layer after being occupied and return to an idle state where we proceed to send a retry t...
std::unordered_map< RequestPtr, PortID > routeTo
Remember where request packets came from so that we can route responses to the appropriate port.
bool tryTiming(SrcType *src_port)
Determine if the layer accepts a packet from a specific port.
State
We declare an enum to track the state of the layer.
statistics::Vector2d pktCount
A 2-Dimensional vecto of scalar stats.
A vector of scalar stats.
statistics::Formula utilization
const Cycles responseLatency
const PortID InvalidPortID
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.
AddrRangeList xbarRanges
all contigous ranges seen by this crossbar
DrainState
Object drain/handover states.
BaseXBar & xbar
The crossbar this layer is a part of.
const Cycles forwardLatency
statistics::Vector transDist
Stats for transaction distribution and data passing through the crossbar.
RespLayer(ResponsePort &_port, BaseXBar &_xbar, const std::string &_name)
Create a response layer and give it a name.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
virtual void sendRetryResp()
Send a retry to the response port that previously attempted a sendTimingResp to this request port and...
virtual void recvRangeChange(PortID mem_side_port_id)
Function called by the port when the crossbar is recieving a range change.
AddrRangeList getAddrRanges() const
Return the address ranges the crossbar is responsible for.
BaseXBar(const BaseXBarParams &p)
Layer(DstType &_port, BaseXBar &_xbar, const std::string &_name)
Create a layer and give it a name.
PortID defaultPortID
Port that handles requests that don't match any of the interfaces.
std::deque< SrcType * > waitingForLayer
A deque of ports that retry should be called on because the original send was delayed due to a busy l...
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
DrainState drain() override
Drain according to the normal semantics, so that the crossbar can tell the layer to drain,...
A ResponsePort is a specialization of a port.
ReqLayer(RequestPort &_port, BaseXBar &_xbar, const std::string &_name)
Create a request layer and give it a name.
Ports are used to interface objects to each other.
statistics::Vector2d pktSize
Interface for objects that might require draining before checkpointing.
DstType & port
The destination port this layer converges at.
void calcPacketTiming(PacketPtr pkt, Tick header_delay)
Calculate the timing parameters for the packet.
void recvRetry()
Handle a retry from a neighbouring module.
A layer is an internal crossbar arbitration point with its own flow control.
PortID findPort(AddrRange addr_range)
Find which port connected to this crossbar (if any) should be given a packet with this address range.
The AddrRange class encapsulates an address range, and supports a number of tests to check if two ran...
statistics::Scalar occupancy
Stats for occupancy and utilization.
void sendRetry(ResponsePort *retry_port) override
Sending the actual retry, in a manner specific to the individual layers.
const Cycles headerLatency
Cycles the layer is occupied processing the packet header.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
void regStats() override
Callback to set stat parameters.
SrcType * waitingForPeer
Track who is waiting for the retry when receiving it from a peer.
std::vector< bool > gotAddrRanges
Remember for each of the memory-side ports of the crossbar if we got an address range from the connec...
void occupyLayer(Tick until)
AddrRangeMap< PortID, 3 > portMap
std::vector< RequestPort * > memSidePorts
EventFunctionWrapper releaseEvent
Generated on Tue Sep 7 2021 14:53:49 for gem5 by doxygen 1.8.17