|
gem5 v23.0.0.1
|
#include <packet_queue.hh>
Public Member Functions | |
| SnoopRespPacketQueue (EventManager &_em, RequestPort &_mem_side_port, bool force_order=false, const std::string _label="SnoopRespPacketQueue") | |
| Create a snoop response packet queue, linked to an event manager, a memory-side port, and a label that will be used for functional print request packets. | |
| virtual | ~SnoopRespPacketQueue () |
| 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. | |
Static Protected Member Functions | |
| static const std::string | name (const RequestPort &memSidePort, const std::string &label) |
Protected Attributes | |
| 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. | |
Definition at line 262 of file packet_queue.hh.
| gem5::SnoopRespPacketQueue::SnoopRespPacketQueue | ( | EventManager & | _em, |
| RequestPort & | _mem_side_port, | ||
| bool | force_order = false, |
||
| const std::string | _label = "SnoopRespPacketQueue" |
||
| ) |
Create a snoop response packet queue, linked to an event manager, a memory-side port, and a label that will be used for functional print request packets.
| _em | Event manager used for scheduling this queue |
| _mem_side_port | memory-side port used to send the packets |
| force_order | Force insertion order for packets with same address |
| _label | Label to push on the label stack for print request packets |
Definition at line 251 of file packet_queue.cc.
|
inlinevirtual |
Definition at line 291 of file packet_queue.hh.
|
inlinevirtual |
Provide a name to simplify debugging.
Implements gem5::PacketQueue.
Definition at line 293 of file packet_queue.hh.
References gem5::PacketQueue::label, memSidePort, and name().
Referenced by name().
|
inlinestaticprotected |
Definition at line 271 of file packet_queue.hh.
References gem5::PacketQueue::label, memSidePort, and gem5::Port::name().
|
virtual |
Send a packet using the appropriate method for the specific subclass (request, response or snoop response).
Implements gem5::PacketQueue.
Definition at line 261 of file packet_queue.cc.
References memSidePort, and gem5::RequestPort::sendTimingSnoopResp().
|
protected |
Definition at line 267 of file packet_queue.hh.
Referenced by name(), name(), and sendTiming().