| gem5 v23.0.0.1
    | 
Override the default behaviour of sendDeferredPacket to enable the memory-side cache port to also send requests based on the current MSHR status. More...
#include <base.hh>
 
  
| Public Member Functions | |
| CacheReqPacketQueue (BaseCache &cache, RequestPort &port, SnoopRespPacketQueue &snoop_resp_queue, const std::string &label) | |
| virtual void | sendDeferredPacket () | 
| Override the normal sendDeferredPacket and do not only consider the transmit list (used for responses), but also requests. | |
| bool | checkConflictingSnoop (const PacketPtr pkt) | 
| Check if there is a conflicting snoop response about to be send out, and if so simply stall any requests, and schedule a send event at the same time as the next snoop response is being sent out. | |
|  Public Member Functions inherited from gem5::ReqPacketQueue | |
| ReqPacketQueue (EventManager &_em, RequestPort &_mem_side_port, const std::string _label="ReqPacketQueue") | |
| Create a request packet queue, linked to an event manager, a memory-side port, and a label that will be used for functional print request packets. | |
| virtual | ~ReqPacketQueue () | 
| const std::string | name () const | 
| Provide a name to simplify debugging. | |
| bool | sendTiming (PacketPtr pkt) | 
| Send a packet using the appropriate method for the specific subclass (request, response or snoop response). | |
|  Public Member Functions inherited from gem5::PacketQueue | |
| virtual const std::string | name () const =0 | 
| Provide a name to simplify debugging. | |
| size_t | size () const | 
| Get the size of the queue. | |
| Tick | deferredPacketReadyTime () const | 
| Get the next packet ready time. | |
| bool | checkConflict (const PacketPtr pkt, const int blk_size) const | 
| Check if a packet corresponding to the same address exists in the queue. | |
| bool | trySatisfyFunctional (PacketPtr pkt) | 
| Check the list of buffered packets against the supplied functional request. | |
| void | schedSendEvent (Tick when) | 
| Schedule a send event if we are not already waiting for a retry. | |
| void | schedSendTiming (PacketPtr pkt, Tick when) | 
| Add a packet to the transmit list, and schedule a send event. | |
| void | retry () | 
| Retry sending a packet from the queue. | |
| void | disableSanityCheck () | 
| This allows a user to explicitly disable the sanity check on the size of the transmitList, which is enabled by default. | |
| DrainState | drain () override | 
| Draining is the process of clearing out the states of SimObjects.These are the SimObjects that are partially executed or are partially in flight. | |
|  Public Member Functions inherited from gem5::Drainable | |
| DrainState | drainState () const | 
| Return the current drain state of an object. | |
| virtual void | notifyFork () | 
| Notify a child process of a fork. | |
| Protected Attributes | |
| BaseCache & | cache | 
| SnoopRespPacketQueue & | snoopRespQueue | 
|  Protected Attributes inherited from gem5::ReqPacketQueue | |
| RequestPort & | memSidePort | 
|  Protected Attributes inherited from gem5::PacketQueue | |
| const std::string | label | 
| Label to use for print request packets label stack. | |
| bool | waitingOnRetry | 
| Remember whether we're awaiting a retry. | |
| Additional Inherited Members | |
|  Protected Member Functions inherited from gem5::PacketQueue | |
| bool | deferredPacketReady () const | 
| Check whether we have a packet ready to go on the transmit list. | |
| virtual void | sendDeferredPacket () | 
| Attempt to send a packet. | |
| virtual bool | sendTiming (PacketPtr pkt)=0 | 
| Send a packet using the appropriate method for the specific subclass (request, response or snoop response). | |
| PacketQueue (EventManager &_em, const std::string &_label, const std::string &_sendEventName, bool force_order=false, bool disable_sanity_check=false) | |
| Create a packet queue, linked to an event manager, and a label that will be used for functional print request packets. | |
| virtual | ~PacketQueue () | 
| Virtual desctructor since the class may be used as a base class. | |
|  Protected Member Functions inherited from gem5::Drainable | |
| Drainable () | |
| virtual | ~Drainable () | 
| virtual DrainState | drain ()=0 | 
| Draining is the process of clearing out the states of SimObjects.These are the SimObjects that are partially executed or are partially in flight. | |
| virtual void | drainResume () | 
| Resume execution after a successful drain. | |
| void | signalDrainDone () const | 
| Signal that an object is drained. | |
|  Static Protected Member Functions inherited from gem5::ReqPacketQueue | |
| static const std::string | name (const RequestPort &memSidePort, const std::string &label) | 
Override the default behaviour of sendDeferredPacket to enable the memory-side cache port to also send requests based on the current MSHR status.
This queue has a pointer to our specific cache implementation and is used by the MemSidePort.
| 
 | inline | 
| 
 | inline | 
Check if there is a conflicting snoop response about to be send out, and if so simply stall any requests, and schedule a send event at the same time as the next snoop response is being sent out.
| pkt | The packet to check for conflicts against. | 
Definition at line 219 of file base.hh.
References gem5::BaseCache::blkSize, cache, gem5::PacketQueue::checkConflict(), gem5::PacketQueue::deferredPacketReadyTime(), DPRINTF, gem5::PacketQueue::schedSendEvent(), and snoopRespQueue.
| 
 | virtual | 
Override the normal sendDeferredPacket and do not only consider the transmit list (used for responses), but also requests.
Reimplemented from gem5::PacketQueue.
Definition at line 2653 of file base.cc.
References gem5::QueueEntry::getTarget(), gem5::MaxTick, gem5::QueueEntry::Target::pkt, and gem5::QueueEntry::sendPacket().
| 
 | protected | 
Definition at line 193 of file base.hh.
Referenced by checkConflictingSnoop().
| 
 | protected | 
Definition at line 194 of file base.hh.
Referenced by checkConflictingSnoop().