Go to the documentation of this file.
38 #ifndef __MEM_QOS_Q_POLICY_HH__
39 #define __MEM_QOS_Q_POLICY_HH__
43 #include <unordered_set>
48 #include "params/QoSMemCtrl.hh"
134 PacketQueue::iterator
155 PacketQueue::iterator
158 return queue->begin();
183 PacketQueue::iterator
LrgQueuePolicy(const QoSMemCtrlParams &p)
FifoQueuePolicy(const QoSMemCtrlParams &p)
PacketQueue::iterator selectPacket(PacketQueue *queue) override
Implements LRG packet select policy.
PacketQueue::iterator selectPacket(PacketQueue *queue) override
Implements FCFS packet select policy.
static QueuePolicy * create(const QoSMemCtrlParams &p)
This factory method is used for generating the queue policy.
GEM5_DEPRECATED_NAMESPACE(QoS, qos)
Last In First Out Queue Policy.
First In First Out Queue Policy.
std::deque< PacketPtr > PacketQueue
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
MemCtrl * memCtrl
Pointer to parent memory controller implementing the policy.
Least Recently Granted Queue Policy It selects packets from the queue with a round robin-like policy:...
A packet queue is a class that holds deferred packets and later sends them using the associated CPU-s...
void enqueuePacket(PacketPtr pkt) override
This method is called by the memory controller after it enqueues a packet.
virtual PacketQueue::iterator selectPacket(PacketQueue *queue)=0
Policy selector.
QueuePolicy(const QoSMemCtrlParams &p)
LifoQueuePolicy(const QoSMemCtrlParams &p)
virtual void enqueuePacket(PacketPtr pkt)
This method is called by the memory controller after it enqueues a packet.
The qos::MemCtrl is a base class for Memory objects which support QoS - it provides access to a set o...
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
std::list< RequestorID > toServe
Support structure for lrg algorithms: keeps track of serviced requestors, always serve the front elem...
PacketQueue::iterator selectPacket(PacketQueue *queue) override
Implements LIFO packet select policy.
void setMemCtrl(MemCtrl *mem)
Setting a pointer to the Memory Controller implementing the policy.
Generated on Tue Sep 7 2021 14:53:48 for gem5 by doxygen 1.8.17