gem5 v23.0.0.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
queued.hh
Go to the documentation of this file.
1/*
2 * Copyright (c) 2014-2015 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_CACHE_PREFETCH_QUEUED_HH__
39#define __MEM_CACHE_PREFETCH_QUEUED_HH__
40
41#include <cstdint>
42#include <list>
43#include <utility>
44
45#include "arch/generic/mmu.hh"
46#include "base/statistics.hh"
47#include "base/types.hh"
49#include "mem/packet.hh"
50
51namespace gem5
52{
53
54struct QueuedPrefetcherParams;
55
56namespace prefetch
57{
58
59class Queued : public Base
60{
61 protected:
63 {
73 int32_t priority;
78
88 int32_t prio) : owner(o), pfInfo(pfi), tick(t), pkt(nullptr),
89 priority(prio), translationRequest(), tc(nullptr),
90 ongoingTranslation(false) {
91 }
92
93 bool operator>(const DeferredPacket& that) const
94 {
95 return priority > that.priority;
96 }
97 bool operator<(const DeferredPacket& that) const
98 {
99 return priority < that.priority;
100 }
101 bool operator<=(const DeferredPacket& that) const
102 {
103 return !(*this > that);
104 }
105
116 void createPkt(Addr paddr, unsigned blk_size, RequestorID requestor_id,
117 bool tag_prefetch, Tick t);
118
125 {
126 translationRequest = req;
127 }
128
129 void markDelayed() override
130 {}
131
132 void finish(const Fault &fault, const RequestPtr &req,
134
140 };
141
144
147
148 // PARAMETERS
149
151 const unsigned queueSize;
152
158
161
163 const bool queueSquash;
164
166 const bool queueFilter;
167
169 const bool cacheSnoop;
170
172 const bool tagPrefetch;
173
175 const unsigned int throttleControlPct;
176
178 {
180 // STATS
189 public:
191
192 Queued(const QueuedPrefetcherParams &p);
193 virtual ~Queued();
194
195 void notify(const PacketPtr &pkt, const PrefetchInfo &pfi) override;
196
197 void insert(const PacketPtr &pkt, PrefetchInfo &new_pfi, int32_t priority);
198
199 virtual void calculatePrefetch(const PrefetchInfo &pfi,
200 std::vector<AddrPriority> &addresses) = 0;
201 PacketPtr getPacket() override;
202
204 {
205 return pfq.empty() ? MaxTick : pfq.front().tick;
206 }
207
208 void printQueue(const std::list<DeferredPacket> &queue) const;
209
210 private:
211
217 void addToQueue(std::list<DeferredPacket> &queue, DeferredPacket &dpp);
218
226 void processMissingTranslations(unsigned max);
227
235 void translationComplete(DeferredPacket *dp, bool failed);
236
246 const PrefetchInfo &pfi, int32_t priority);
247
256 size_t getMaxPermittedPrefetches(size_t total) const;
257
258 RequestPtr createPrefetchRequest(Addr addr, PrefetchInfo const &pfi,
259 PacketPtr pkt);
260};
261
262} // namespace prefetch
263} // namespace gem5
264
265#endif //__MEM_CACHE_PREFETCH_QUEUED_HH__
Defines global host-dependent types: Counter, Tick, and (indirectly) {int,uint}{8,...
Cycles is a wrapper class for representing cycle counts, i.e.
Definition types.hh:79
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
Definition packet.hh:295
ThreadContext is the external interface to all thread state for anything outside of the CPU.
Class containing the information needed by the prefetch to train and generate new prefetch requests.
Definition base.hh:97
BaseMMU * mmu
Registered mmu for address translations.
Definition base.hh:367
const bool queueSquash
Squash queued prefetch if demand access observed.
Definition queued.hh:163
void translationComplete(DeferredPacket *dp, bool failed)
Indicates that the translation of the address of the provided deferred packet has been successfully c...
Definition queued.cc:301
gem5::prefetch::Queued::QueuedStats statsQueued
std::list< DeferredPacket >::iterator iterator
Definition queued.hh:146
void printQueue(const std::list< DeferredPacket > &queue) const
Definition queued.cc:120
const unsigned queueSize
Maximum size of the prefetch queue.
Definition queued.hh:151
std::list< DeferredPacket > pfqMissingTranslation
Definition queued.hh:143
void processMissingTranslations(unsigned max)
Starts the translations of the queued prefetches with a missing translation.
Definition queued.cc:286
RequestPtr createPrefetchRequest(Addr addr, PrefetchInfo const &pfi, PacketPtr pkt)
Definition queued.cc:373
void notify(const PacketPtr &pkt, const PrefetchInfo &pfi) override
Notify prefetcher of cache access (may be any access or just misses, depending on cache parameters....
Definition queued.cc:172
const bool queueFilter
Filter prefetches if already queued.
Definition queued.hh:166
std::list< DeferredPacket >::const_iterator const_iterator
Definition queued.hh:145
const bool tagPrefetch
Tag prefetch with PC of generating access?
Definition queued.hh:172
const Cycles latency
Cycles after generation when a prefetch can first be issued.
Definition queued.hh:160
const bool cacheSnoop
Snoop the cache before generating prefetch (cheating basically)
Definition queued.hh:169
const unsigned int throttleControlPct
Percentage of requests that can be throttled.
Definition queued.hh:175
void insert(const PacketPtr &pkt, PrefetchInfo &new_pfi, int32_t priority)
Definition queued.cc:384
PacketPtr getPacket() override
Definition queued.cc:237
void addToQueue(std::list< DeferredPacket > &queue, DeferredPacket &dpp)
Adds a DeferredPacket to the specified queue.
Definition queued.cc:483
bool alreadyInQueue(std::list< DeferredPacket > &queue, const PrefetchInfo &pfi, int32_t priority)
Checks whether the specified prefetch request is already in the specified queue.
Definition queued.cc:338
Tick nextPrefetchReadyTime() const override
Definition queued.hh:203
size_t getMaxPermittedPrefetches(size_t total) const
Returns the maxmimum number of prefetch requests that are allowed to be created from the number of pr...
Definition queued.cc:142
virtual void calculatePrefetch(const PrefetchInfo &pfi, std::vector< AddrPriority > &addresses)=0
const unsigned missingTranslationQueueSize
Maximum size of the queue holding prefetch requests with missing address translations.
Definition queued.hh:157
std::list< DeferredPacket > pfq
Definition queued.hh:142
Statistics container.
Definition group.hh:93
This is a simple scalar statistic, like a counter.
STL list class.
Definition stl.hh:51
STL pair class.
Definition stl.hh:58
STL vector class.
Definition stl.hh:37
Miss and writeback queue declarations.
Bitfield< 4, 0 > mode
Definition misc_types.hh:74
Bitfield< 5 > t
Definition misc_types.hh:71
Bitfield< 7, 4 > dp
Definition misc_types.hh:95
Bitfield< 3, 0 > priority
Bitfield< 0 > p
Bitfield< 3 > addr
Definition types.hh:84
const FlagsType total
Print the total.
Definition info.hh:59
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
std::shared_ptr< FaultBase > Fault
Definition types.hh:249
std::shared_ptr< Request > RequestPtr
Definition request.hh:94
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Definition types.hh:147
uint64_t Tick
Tick count type.
Definition types.hh:58
const Tick MaxTick
Definition types.hh:60
uint16_t RequestorID
Definition request.hh:95
Declaration of the Packet class.
Declaration of Statistics objects.
bool operator>(const DeferredPacket &that) const
Definition queued.hh:93
int32_t priority
The priority of this prefetch.
Definition queued.hh:73
Tick tick
Time when this prefetch becomes ready.
Definition queued.hh:69
DeferredPacket(Queued *o, PrefetchInfo const &pfi, Tick t, int32_t prio)
Constructor.
Definition queued.hh:87
bool operator<=(const DeferredPacket &that) const
Definition queued.hh:101
void startTranslation(BaseMMU *mmu)
Issues the translation request to the provided MMU.
Definition queued.cc:80
void setTranslationRequest(const RequestPtr &req)
Sets the translation request needed to obtain the physical address of this request.
Definition queued.hh:124
void createPkt(Addr paddr, unsigned blk_size, RequestorID requestor_id, bool tag_prefetch, Tick t)
Create the associated memory packet.
Definition queued.cc:58
Queued * owner
Owner of the packet.
Definition queued.hh:65
void finish(const Fault &fault, const RequestPtr &req, ThreadContext *tc, BaseMMU::Mode mode) override
Definition queued.cc:91
RequestPtr translationRequest
Request used when a translation is needed.
Definition queued.hh:75
PacketPtr pkt
The memory packet generated by this prefetch.
Definition queued.hh:71
bool operator<(const DeferredPacket &that) const
Definition queued.hh:97
void markDelayed() override
Signal that the translation has been delayed due to a hw page table walk.
Definition queued.hh:129
PrefetchInfo pfInfo
Prefetch info corresponding to this packet.
Definition queued.hh:67
statistics::Scalar pfUsefulSpanPage
Definition queued.hh:187
statistics::Scalar pfBufferHit
Definition queued.hh:182
statistics::Scalar pfIdentified
Definition queued.hh:181
statistics::Scalar pfRemovedDemand
Definition queued.hh:184
statistics::Scalar pfRemovedFull
Definition queued.hh:185
statistics::Scalar pfSpanPage
Definition queued.hh:186

Generated on Mon Jul 10 2023 14:24:32 for gem5 by doxygen 1.9.7