gem5 v23.0.0.1
Loading...
Searching...
No Matches
q_policy.hh
Go to the documentation of this file.
1/*
2 * Copyright (c) 2018 ARM Limited
3 * All rights reserved
4 *
5 * The license below extends only to copyright in the software and shall
6 * not be construed as granting a license to any other intellectual
7 * property including but not limited to intellectual property relating
8 * to a hardware implementation of the functionality of the software
9 * licensed hereunder. You may use the software subject to the license
10 * terms below provided that you ensure that this notice is replicated
11 * unmodified and in its entirety in all distributions of the software,
12 * modified or unmodified, in source code or in binary form.
13 *
14 * Redistribution and use in source and binary forms, with or without
15 * modification, are permitted provided that the following conditions are
16 * met: redistributions of source code must retain the above copyright
17 * notice, this list of conditions and the following disclaimer;
18 * redistributions in binary form must reproduce the above copyright
19 * notice, this list of conditions and the following disclaimer in the
20 * documentation and/or other materials provided with the distribution;
21 * neither the name of the copyright holders nor the names of its
22 * contributors may be used to endorse or promote products derived from
23 * this software without specific prior written permission.
24 *
25 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
26 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
27 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
28 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
29 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
30 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
31 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
32 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
33 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
34 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
35 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36 */
37
38#ifndef __MEM_QOS_Q_POLICY_HH__
39#define __MEM_QOS_Q_POLICY_HH__
40
41#include <deque>
42#include <list>
43#include <unordered_set>
44
45#include "base/compiler.hh"
46#include "mem/packet.hh"
47#include "mem/qos/mem_ctrl.hh"
48#include "params/QoSMemCtrl.hh"
49
50namespace gem5
51{
52
53namespace memory
54{
55
56namespace qos
57{
58
66{
67 public:
69
79 static QueuePolicy* create(const QoSMemCtrlParams &p);
80
89 virtual void enqueuePacket(PacketPtr pkt) {};
90
100 virtual PacketQueue::iterator selectPacket(PacketQueue* queue) = 0;
101
107
108 virtual ~QueuePolicy() {};
109
110 protected:
111 QueuePolicy(const QoSMemCtrlParams &p)
112 : memCtrl(nullptr)
113 {}
114
117};
118
121{
122 public:
123 LifoQueuePolicy(const QoSMemCtrlParams &p)
124 : QueuePolicy(p)
125 {}
126
133 PacketQueue::iterator
134 selectPacket(PacketQueue* queue) override
135 {
136 return queue->end();
137 }
138};
139
142{
143 public:
144 FifoQueuePolicy(const QoSMemCtrlParams &p)
145 : QueuePolicy(p)
146 {}
147
154 PacketQueue::iterator
155 selectPacket(PacketQueue* queue) override
156 {
157 return queue->begin();
158 }
159};
160
168{
169 public:
170 LrgQueuePolicy(const QoSMemCtrlParams &p)
171 : QueuePolicy(p)
172 {}
173
174 void enqueuePacket(PacketPtr pkt) override;
175
182 PacketQueue::iterator
183 selectPacket(PacketQueue* queue) override;
184
185 protected:
192};
193
194} // namespace qos
195} // namespace memory
196} // namespace gem5
197
198#endif /* __MEM_QOS_Q_POLICY_HH__ */
A packet queue is a class that holds deferred packets and later sends them using the associated CPU-s...
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
Definition packet.hh:295
First In First Out Queue Policy.
Definition q_policy.hh:142
PacketQueue::iterator selectPacket(PacketQueue *queue) override
Implements FCFS packet select policy.
Definition q_policy.hh:155
FifoQueuePolicy(const QoSMemCtrlParams &p)
Definition q_policy.hh:144
Last In First Out Queue Policy.
Definition q_policy.hh:121
PacketQueue::iterator selectPacket(PacketQueue *queue) override
Implements LIFO packet select policy.
Definition q_policy.hh:134
LifoQueuePolicy(const QoSMemCtrlParams &p)
Definition q_policy.hh:123
Least Recently Granted Queue Policy It selects packets from the queue with a round robin-like policy:...
Definition q_policy.hh:168
void enqueuePacket(PacketPtr pkt) override
This method is called by the memory controller after it enqueues a packet.
Definition q_policy.cc:146
LrgQueuePolicy(const QoSMemCtrlParams &p)
Definition q_policy.hh:170
PacketQueue::iterator selectPacket(PacketQueue *queue) override
Implements LRG packet select policy.
Definition q_policy.cc:73
std::list< RequestorID > toServe
Support structure for lrg algorithms: keeps track of serviced requestors, always serve the front elem...
Definition q_policy.hh:191
The qos::MemCtrl is a base class for Memory objects which support QoS - it provides access to a set o...
Definition mem_ctrl.hh:80
static QueuePolicy * create(const QoSMemCtrlParams &p)
This factory method is used for generating the queue policy.
Definition q_policy.cc:59
MemCtrl * memCtrl
Pointer to parent memory controller implementing the policy.
Definition q_policy.hh:116
void setMemCtrl(MemCtrl *mem)
Setting a pointer to the Memory Controller implementing the policy.
Definition q_policy.hh:106
QueuePolicy(const QoSMemCtrlParams &p)
Definition q_policy.hh:111
std::deque< PacketPtr > PacketQueue
Definition q_policy.hh:68
virtual void enqueuePacket(PacketPtr pkt)
This method is called by the memory controller after it enqueues a packet.
Definition q_policy.hh:89
virtual PacketQueue::iterator selectPacket(PacketQueue *queue)=0
Policy selector.
STL deque class.
Definition stl.hh:44
STL list class.
Definition stl.hh:51
Bitfield< 0 > p
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Declaration of the Packet class.
Definition mem.h:38
bool_vector8 mem[]
Definition reset_stim.h:43

Generated on Mon Jul 10 2023 15:32:04 for gem5 by doxygen 1.9.7