gem5 [DEVELOP-FOR-25.0]
Loading...
Searching...
No Matches
iew.hh
Go to the documentation of this file.
1/*
2 * Copyright (c) 2010-2012, 2014, 2019 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 * Copyright (c) 2004-2006 The Regents of The University of Michigan
15 * All rights reserved.
16 *
17 * Redistribution and use in source and binary forms, with or without
18 * modification, are permitted provided that the following conditions are
19 * met: redistributions of source code must retain the above copyright
20 * notice, this list of conditions and the following disclaimer;
21 * redistributions in binary form must reproduce the above copyright
22 * notice, this list of conditions and the following disclaimer in the
23 * documentation and/or other materials provided with the distribution;
24 * neither the name of the copyright holders nor the names of its
25 * contributors may be used to endorse or promote products derived from
26 * this software without specific prior written permission.
27 *
28 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
29 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
30 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
31 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
32 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
33 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
34 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
35 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
36 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
37 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
38 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
39 */
40
41#ifndef __CPU_O3_IEW_HH__
42#define __CPU_O3_IEW_HH__
43
44#include <queue>
45#include <set>
46
47#include "base/statistics.hh"
48#include "cpu/o3/comm.hh"
50#include "cpu/o3/inst_queue.hh"
51#include "cpu/o3/limits.hh"
52#include "cpu/o3/lsq.hh"
53#include "cpu/o3/scoreboard.hh"
54#include "cpu/timebuf.hh"
55#include "debug/IEW.hh"
56#include "sim/probe/probe.hh"
57
58namespace gem5
59{
60
61struct BaseO3CPUParams;
62
63namespace o3
64{
65
66class FUPool;
67
87class IEW
88{
89 public:
93 enum Status
94 {
97 };
98
109
110 private:
119
127
128 public:
130 IEW(CPU *_cpu, const BaseO3CPUParams &params);
131
133 std::string name() const;
134
136 void regProbePoints();
137
139 void startupStage();
140
142 void clearStates(ThreadID tid);
143
146
149
152
155
157 void setScoreboard(Scoreboard *sb_ptr);
158
160 void drainSanityCheck() const;
161
163 bool isDrained() const;
164
166 void takeOverFrom();
167
169 void squash(ThreadID tid);
170
172 void wakeDependents(const DynInstPtr &inst);
173
177 void rescheduleMemInst(const DynInstPtr &inst);
178
180 void replayMemInst(const DynInstPtr &inst);
181
183 void blockMemInst(const DynInstPtr &inst);
184
186 void retryMemInst(const DynInstPtr &inst);
187
189 void cacheUnblocked();
190
192 void instToCommit(const DynInstPtr &inst);
193
195 void skidInsert(ThreadID tid);
196
198 int skidCount();
199
201 bool skidsEmpty();
202
204 void updateStatus();
205
208
212 void wakeCPU();
213
215 void activityThisCycle();
216
218 void activateStage();
219
221 void deactivateStage();
222
224 bool hasStoresToWB() { return ldstQueue.hasStoresToWB(); }
225
227 bool hasStoresToWB(ThreadID tid) { return ldstQueue.hasStoresToWB(tid); }
228
230 void checkMisprediction(const DynInstPtr &inst);
231
232 // hardware transactional memory
233 // For debugging purposes, it is useful to keep track of the most recent
234 // htmUid that has been committed (architecturally, not transactionally)
235 // to ensure that the core and the memory subsystem are observing
236 // correct ordering constraints.
237 void setLastRetiredHtmUid(ThreadID tid, uint64_t htmUid)
238 {
239 ldstQueue.setLastRetiredHtmUid(tid, htmUid);
240 }
241
242 private:
246 void squashDueToBranch(const DynInstPtr &inst, ThreadID tid);
247
251 void squashDueToMemOrder(const DynInstPtr &inst, ThreadID tid);
252
254 void block(ThreadID tid);
255
259 void unblock(ThreadID tid);
260
262 void dispatch(ThreadID tid);
263
265 void dispatchInsts(ThreadID tid);
266
271 void executeInsts();
272
278 void writebackInsts();
279
281 bool checkStall(ThreadID tid);
282
285
287 void emptyRenameInsts(ThreadID tid);
288
290 void sortInsts();
291
292 public:
296 void tick();
297
298 private:
300 void updateExeInstStats(const DynInstPtr &inst);
301
304
307
310
313
316
319
322
325
331
334
336 std::queue<DynInstPtr> insts[MaxThreads];
337
339 std::queue<DynInstPtr> skidBuffer[MaxThreads];
340
343
344 private:
347
352
354 void printAvailableInsts();
355
356 public:
359
362
369
370 private:
373
378
381
384
391
394
396 unsigned issueWidth;
397
399 unsigned wbNumInst;
400
406 unsigned wbCycle;
407
409 unsigned wbWidth;
410
413
416
419
420
481};
482
483} // namespace o3
484} // namespace gem5
485
486#endif // __CPU_O3_IEW_HH__
Cycles is a wrapper class for representing cycle counts, i.e.
Definition types.hh:79
ProbePointArg generates a point for the class of Arg.
Definition probe.hh:273
O3CPU class, has each of the stages (fetch through commit) within it, as well as all of the time buff...
Definition cpu.hh:94
Pool of FU's, specific to the new CPU model.
Definition fu_pool.hh:76
void printAvailableInsts()
Debug function to print instructions that are issued this cycle.
Definition iew.cc:1097
Status
Overall IEW stage status.
Definition iew.hh:94
void updateStatus()
Updates overall IEW status based on all of the stages' statuses.
Definition iew.cc:639
void deactivateStage()
Tells CPU that the IEW stage is inactive and idle.
Definition iew.cc:807
TimeBuffer< IEWStruct > * iewQueue
IEW stage time buffer.
Definition iew.hh:330
void resetEntries()
Resets entries of the IQ and the LSQ.
TimeBuffer< TimeStruct >::wire fromCommit
Wire to get commit's output from backwards time buffer.
Definition iew.hh:309
StageStatus dispatchStatus[MaxThreads]
Dispatch status.
Definition iew.hh:114
std::list< ThreadID > * activeThreads
Pointer to list of active threads.
Definition iew.hh:415
void takeOverFrom()
Takes over from another CPU's thread.
Definition iew.cc:383
void setTimeBuffer(TimeBuffer< TimeStruct > *tb_ptr)
Sets main time buffer used for backwards communication.
Definition iew.cc:296
int skidCount()
Returns the max of the number of entries in all of the skid buffers.
Definition iew.cc:614
void instToCommit(const DynInstPtr &inst)
Sends an instruction to commit through the time buffer.
Definition iew.cc:565
FUPool * fuPool
Pointer to the functional unit pool.
Definition iew.hh:364
void squashDueToBranch(const DynInstPtr &inst, ThreadID tid)
Sends commit proper information for a squash due to a branch mispredict.
Definition iew.cc:445
void squashDueToMemOrder(const DynInstPtr &inst, ThreadID tid)
Sends commit proper information for a squash due to a memory order violation.
Definition iew.cc:469
unsigned wbWidth
Writeback width.
Definition iew.hh:409
std::queue< DynInstPtr > insts[MaxThreads]
Queue of all instructions coming from rename this cycle.
Definition iew.hh:336
void block(ThreadID tid)
Sets Dispatch to blocked, and signals back to other stages to block.
Definition iew.cc:495
StageStatus exeStatus
Execute status.
Definition iew.hh:116
void clearStates(ThreadID tid)
Clear all thread-specific states.
Definition iew.cc:254
void dispatch(ThreadID tid)
Determines proper actions to take given Dispatch's status.
Definition iew.cc:814
void startupStage()
Initializes stage; sends back the number of free IQ and LSQ entries.
Definition iew.cc:231
void blockMemInst(const DynInstPtr &inst)
Moves memory instruction onto the list of cache blocked instructions.
Definition iew.cc:547
void unblock(ThreadID tid)
Unblocks Dispatch if the skid buffer is empty, and signals back to other stages to unblock.
Definition iew.cc:513
void sortInsts()
Sorts instructions coming from rename into lists separated by thread.
Definition iew.cc:753
void wakeDependents(const DynInstPtr &inst)
Wakes all dependents of a completed instruction.
Definition iew.cc:529
unsigned issueWidth
Width of issue, in instructions.
Definition iew.hh:396
void updateExeInstStats(const DynInstPtr &inst)
Updates execution stats based on the instruction.
Definition iew.cc:1531
void dispatchInsts(ThreadID tid)
Dispatches instructions to IQ and LSQ.
Definition iew.cc:861
void drainSanityCheck() const
Perform sanity checks after a drain.
Definition iew.cc:374
TimeBuffer< IssueStruct > issueToExecQueue
Issue stage queue.
Definition iew.hh:321
void checkSignalsAndUpdate(ThreadID tid)
Processes inputs and changes state accordingly.
Definition iew.cc:690
void activateStage()
Tells CPU that the IEW stage is active and running.
Definition iew.cc:800
TimeBuffer< TimeStruct >::wire toRename
Wire to write information heading to previous stages.
Definition iew.hh:312
bool wroteToTimeBuffer
Records if IEW has written to the time buffer this cycle, so that the CPU can deschedule itself if th...
Definition iew.hh:351
CPU * cpu
CPU pointer.
Definition iew.hh:346
void activityThisCycle()
Reports to the CPU that there is activity this cycle.
Definition iew.cc:793
void setScoreboard(Scoreboard *sb_ptr)
Sets pointer to the scoreboard.
Definition iew.cc:340
Scoreboard * scoreboard
Scoreboard pointer.
Definition iew.hh:342
std::queue< DynInstPtr > skidBuffer[MaxThreads]
Skid buffer between rename and IEW.
Definition iew.hh:339
TimeBuffer< IssueStruct >::wire fromIssue
Wire to read information from the issue stage time queue.
Definition iew.hh:324
Cycles renameToIEWDelay
Rename to IEW delay.
Definition iew.hh:383
TimeBuffer< TimeStruct > * timeBuffer
Pointer to main time buffer used for backwards communication.
Definition iew.hh:303
void writebackInsts()
Writebacks instructions.
Definition iew.cc:1361
void wakeCPU()
Tells the CPU to wakeup if it has descheduled itself due to no activity.
Definition iew.cc:787
void squash(ThreadID tid)
Squashes instructions in IEW for a specific thread.
Definition iew.cc:410
void setIEWQueue(TimeBuffer< IEWStruct > *iq_ptr)
Sets time buffer to pass on instructions to commit.
Definition iew.cc:322
ProbePointArg< DynInstPtr > * ppExecute
To probe when instruction execution begins.
Definition iew.hh:124
void rescheduleMemInst(const DynInstPtr &inst)
Tells memory dependence unit that a memory instruction needs to be rescheduled.
Definition iew.cc:535
ThreadID numThreads
Number of active threads.
Definition iew.hh:412
unsigned skidBufferMax
Maximum size of the skid buffer.
Definition iew.hh:418
Status _status
Overall stage status.
Definition iew.hh:112
TimeBuffer< RenameStruct >::wire fromRename
Wire to get rename's output from rename queue.
Definition iew.hh:318
ProbePointArg< DynInstPtr > * ppMispredict
Probe points.
Definition iew.hh:121
TimeBuffer< TimeStruct >::wire toFetch
Wire to write information heading to previous stages.
Definition iew.hh:306
gem5::o3::IEW::IEWStats iewStats
void setLastRetiredHtmUid(ThreadID tid, uint64_t htmUid)
Definition iew.hh:237
bool isDrained() const
Has the stage drained?
Definition iew.cc:346
InstructionQueue instQueue
Instruction queue.
Definition iew.hh:358
bool fetchRedirect[MaxThreads]
Records if there is a fetch redirect on this cycle for each thread.
Definition iew.hh:372
TimeBuffer< RenameStruct > * renameQueue
Rename instruction queue interface.
Definition iew.hh:315
IEW(CPU *_cpu, const BaseO3CPUParams &params)
Constructs a IEW with the given parameters.
Definition iew.cc:67
unsigned dispatchWidth
Width of dispatch, in instructions.
Definition iew.hh:393
ProbePointArg< DynInstPtr > * ppDispatch
Definition iew.hh:122
void retryMemInst(const DynInstPtr &inst)
Moves memory instruction onto the list of retry memory instructions.
Definition iew.cc:553
std::string name() const
Returns the name of the IEW stage.
Definition iew.cc:118
void tick()
Ticks IEW stage, causing Dispatch, the IQ, the LSQ, Execute, and Writeback to run for one cycle.
Definition iew.cc:1411
bool hasStoresToWB(ThreadID tid)
Returns if the LSQ has any stores to writeback.
Definition iew.hh:227
ProbePointArg< DynInstPtr > * ppToCommit
To probe when instruction execution is complete.
Definition iew.hh:126
bool updatedQueues
Records if the queues have been changed (inserted or issued insts), so that IEW knows to broadcast th...
Definition iew.hh:377
bool hasStoresToWB()
Returns if the LSQ has any stores to writeback.
Definition iew.hh:224
void checkMisprediction(const DynInstPtr &inst)
Check misprediction.
Definition iew.cc:1563
LSQ ldstQueue
Load / store queue.
Definition iew.hh:361
Cycles issueToExecuteDelay
Issue to execute delay.
Definition iew.hh:390
void setActiveThreads(std::list< ThreadID > *at_ptr)
Sets pointer to list of active threads.
Definition iew.cc:331
bool skidsEmpty()
Returns if all of the skid buffers are empty.
Definition iew.cc:628
bool updateLSQNextCycle
Records if the LSQ needs to be updated on the next cycle, so that IEW knows if there will be activity...
Definition iew.hh:368
void emptyRenameInsts(ThreadID tid)
Removes instructions from rename from a thread's instruction list.
Definition iew.cc:766
void replayMemInst(const DynInstPtr &inst)
Re-executes all rescheduled memory instructions.
Definition iew.cc:541
Cycles commitToIEWDelay
Commit to IEW delay.
Definition iew.hh:380
unsigned wbCycle
Cycle number within the queue of instructions being written back.
Definition iew.hh:406
void skidInsert(ThreadID tid)
Inserts unused instructions of a thread into the skid buffer.
Definition iew.cc:593
void cacheUnblocked()
Notifies that the cache has become unblocked.
Definition iew.cc:559
TimeBuffer< IEWStruct >::wire toCommit
Wire to write infromation heading to commit.
Definition iew.hh:333
void regProbePoints()
Registers probes.
Definition iew.cc:124
bool checkStall(ThreadID tid)
Checks if any of the stall conditions are currently true.
Definition iew.cc:674
void executeInsts()
Executes instructions.
Definition iew.cc:1119
unsigned wbNumInst
Index into queue of instructions being written back.
Definition iew.hh:399
void setRenameQueue(TimeBuffer< RenameStruct > *rq_ptr)
Sets time buffer for getting instructions coming from rename.
Definition iew.cc:313
StageStatus wbStatus
Writeback status.
Definition iew.hh:118
StageStatus
Status for Issue, Execute, and Writeback stages.
Definition iew.hh:101
@ StartSquash
Definition iew.hh:105
A standard instruction queue class.
Definition inst_queue.hh:99
Implements a simple scoreboard to track which registers are ready.
Definition scoreboard.hh:55
A formula for statistics that is calculated when printed.
Statistics container.
Definition group.hh:93
This is a simple scalar statistic, like a counter.
A vector of scalar stats.
STL list class.
Definition stl.hh:51
static constexpr int MaxThreads
Definition limits.hh:38
RefCountingPtr< DynInst > DynInstPtr
Copyright (c) 2024 Arm Limited All rights reserved.
Definition binary32.hh:36
int16_t ThreadID
Thread index/ID type.
Definition types.hh:235
Declaration of Statistics objects.
statistics::Vector numSwp
Number of executed software prefetches.
Definition iew.hh:465
statistics::Scalar numSquashedInsts
Stat for total number of squashed instructions skipped at execute.
Definition iew.hh:463
statistics::Scalar dispatchedInsts
Stat for total number of instructions dispatched.
Definition iew.hh:434
statistics::Formula wbFanout
Average number of woken instructions per writeback.
Definition iew.hh:479
statistics::Scalar squashCycles
Stat for total number of squashing cycles.
Definition iew.hh:428
statistics::Vector consumerInst
Number of instructions that wake up from producers.
Definition iew.hh:475
statistics::Scalar predictedNotTakenIncorrect
Stat for total number of incorrect predicted not taken branches.
Definition iew.hh:452
statistics::Scalar dispLoadInsts
Stat for total number of dispatched load instructions.
Definition iew.hh:438
statistics::Scalar dispNonSpecInsts
Stat for total number of dispatched non speculative insts.
Definition iew.hh:442
statistics::Scalar idleCycles
Stat for total number of idle cycles.
Definition iew.hh:426
statistics::Vector instsToCommit
Number of instructions sent to commit.
Definition iew.hh:469
gem5::o3::IEW::IEWStats::ExecutedInstStats executedInstStats
statistics::Formula wbRate
Number of instructions per cycle written back.
Definition iew.hh:477
statistics::Scalar dispSquashedInsts
Stat for total number of squashed instructions dispatch skips.
Definition iew.hh:436
statistics::Scalar predictedTakenIncorrect
Stat for total number of incorrect predicted taken branches.
Definition iew.hh:450
statistics::Scalar blockCycles
Stat for total number of blocking cycles.
Definition iew.hh:430
statistics::Vector writebackCount
Number of instructions that writeback.
Definition iew.hh:471
statistics::Scalar memOrderViolationEvents
Stat for total number of memory ordering violation events.
Definition iew.hh:448
statistics::Vector producerInst
Number of instructions that wake consumers.
Definition iew.hh:473
IEWStats(CPU *cpu)
Definition iew.cc:144
statistics::Scalar iqFullEvents
Stat for number of times the IQ becomes full.
Definition iew.hh:444
statistics::Scalar unblockCycles
Stat for total number of unblocking cycles.
Definition iew.hh:432
statistics::Scalar lsqFullEvents
Stat for number of times the LSQ becomes full.
Definition iew.hh:446
statistics::Formula branchMispredicts
Stat for total number of mispredicted branches detected at execute.
Definition iew.hh:455
statistics::Scalar dispStoreInsts
Stat for total number of dispatched store instructions.
Definition iew.hh:440

Generated on Mon May 26 2025 09:19:08 for gem5 by doxygen 1.13.2