gem5  v21.0.1.0
iew_impl.hh
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2010-2013, 2018-2019 ARM Limited
3  * Copyright (c) 2013 Advanced Micro Devices, Inc.
4  * All rights reserved.
5  *
6  * The license below extends only to copyright in the software and shall
7  * not be construed as granting a license to any other intellectual
8  * property including but not limited to intellectual property relating
9  * to a hardware implementation of the functionality of the software
10  * licensed hereunder. You may use the software subject to the license
11  * terms below provided that you ensure that this notice is replicated
12  * unmodified and in its entirety in all distributions of the software,
13  * modified or unmodified, in source code or in binary form.
14  *
15  * Copyright (c) 2004-2006 The Regents of The University of Michigan
16  * All rights reserved.
17  *
18  * Redistribution and use in source and binary forms, with or without
19  * modification, are permitted provided that the following conditions are
20  * met: redistributions of source code must retain the above copyright
21  * notice, this list of conditions and the following disclaimer;
22  * redistributions in binary form must reproduce the above copyright
23  * notice, this list of conditions and the following disclaimer in the
24  * documentation and/or other materials provided with the distribution;
25  * neither the name of the copyright holders nor the names of its
26  * contributors may be used to endorse or promote products derived from
27  * this software without specific prior written permission.
28  *
29  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
30  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
31  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
32  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
33  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
34  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
35  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
36  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
37  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
38  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
39  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
40  */
41 
42 #ifndef __CPU_O3_IEW_IMPL_IMPL_HH__
43 #define __CPU_O3_IEW_IMPL_IMPL_HH__
44 
45 // @todo: Fix the instantaneous communication among all the stages within
46 // iew. There's a clear delay between issue and execute, yet backwards
47 // communication happens simultaneously.
48 
49 #include <queue>
50 
51 #include "arch/utility.hh"
52 #include "config/the_isa.hh"
53 #include "cpu/checker/cpu.hh"
54 #include "cpu/o3/fu_pool.hh"
55 #include "cpu/o3/iew.hh"
56 #include "cpu/timebuf.hh"
57 #include "debug/Activity.hh"
58 #include "debug/Drain.hh"
59 #include "debug/IEW.hh"
60 #include "debug/O3PipeView.hh"
61 #include "params/DerivO3CPU.hh"
62 
63 template<class Impl>
64 DefaultIEW<Impl>::DefaultIEW(O3CPU *_cpu, const DerivO3CPUParams &params)
65  : issueToExecQueue(params.backComSize, params.forwardComSize),
66  cpu(_cpu),
67  instQueue(_cpu, this, params),
68  ldstQueue(_cpu, this, params),
69  fuPool(params.fuPool),
70  commitToIEWDelay(params.commitToIEWDelay),
71  renameToIEWDelay(params.renameToIEWDelay),
72  issueToExecuteDelay(params.issueToExecuteDelay),
73  dispatchWidth(params.dispatchWidth),
74  issueWidth(params.issueWidth),
75  wbNumInst(0),
76  wbCycle(0),
77  wbWidth(params.wbWidth),
78  numThreads(params.numThreads),
79  iewStats(cpu)
80 {
81  if (dispatchWidth > Impl::MaxWidth)
82  fatal("dispatchWidth (%d) is larger than compiled limit (%d),\n"
83  "\tincrease MaxWidth in src/cpu/o3/impl.hh\n",
84  dispatchWidth, static_cast<int>(Impl::MaxWidth));
85  if (issueWidth > Impl::MaxWidth)
86  fatal("issueWidth (%d) is larger than compiled limit (%d),\n"
87  "\tincrease MaxWidth in src/cpu/o3/impl.hh\n",
88  issueWidth, static_cast<int>(Impl::MaxWidth));
89  if (wbWidth > Impl::MaxWidth)
90  fatal("wbWidth (%d) is larger than compiled limit (%d),\n"
91  "\tincrease MaxWidth in src/cpu/o3/impl.hh\n",
92  wbWidth, static_cast<int>(Impl::MaxWidth));
93 
94  _status = Active;
96  wbStatus = Idle;
97 
98  // Setup wire to read instructions coming from issue.
100 
101  // Instruction queue needs the queue between issue and execute.
102  instQueue.setIssueToExecuteQueue(&issueToExecQueue);
103 
104  for (ThreadID tid = 0; tid < Impl::MaxThreads; tid++) {
105  dispatchStatus[tid] = Running;
106  fetchRedirect[tid] = false;
107  }
108 
109  updateLSQNextCycle = false;
110 
111  skidBufferMax = (renameToIEWDelay + 1) * params.renameWidth;
112 }
113 
114 template <class Impl>
115 std::string
117 {
118  return cpu->name() + ".iew";
119 }
120 
121 template <class Impl>
122 void
124 {
125  ppDispatch = new ProbePointArg<DynInstPtr>(cpu->getProbeManager(), "Dispatch");
126  ppMispredict = new ProbePointArg<DynInstPtr>(cpu->getProbeManager(), "Mispredict");
131  ppExecute = new ProbePointArg<DynInstPtr>(cpu->getProbeManager(),
132  "Execute");
137  ppToCommit = new ProbePointArg<DynInstPtr>(cpu->getProbeManager(),
138  "ToCommit");
139 }
140 
141 template <class Impl>
144  : Stats::Group(cpu),
145  ADD_STAT(idleCycles, UNIT_CYCLE, "Number of cycles IEW is idle"),
146  ADD_STAT(squashCycles, UNIT_CYCLE, "Number of cycles IEW is squashing"),
147  ADD_STAT(blockCycles, UNIT_CYCLE, "Number of cycles IEW is blocking"),
148  ADD_STAT(unblockCycles, UNIT_CYCLE, "Number of cycles IEW is unblocking"),
149  ADD_STAT(dispatchedInsts, UNIT_COUNT,
150  "Number of instructions dispatched to IQ"),
151  ADD_STAT(dispSquashedInsts, UNIT_COUNT,
152  "Number of squashed instructions skipped by dispatch"),
153  ADD_STAT(dispLoadInsts, UNIT_COUNT,
154  "Number of dispatched load instructions"),
155  ADD_STAT(dispStoreInsts, UNIT_COUNT,
156  "Number of dispatched store instructions"),
157  ADD_STAT(dispNonSpecInsts, UNIT_COUNT,
158  "Number of dispatched non-speculative instructions"),
159  ADD_STAT(iqFullEvents, UNIT_COUNT,
160  "Number of times the IQ has become full, causing a stall"),
161  ADD_STAT(lsqFullEvents, UNIT_COUNT,
162  "Number of times the LSQ has become full, causing a stall"),
163  ADD_STAT(memOrderViolationEvents, UNIT_COUNT,
164  "Number of memory order violations"),
165  ADD_STAT(predictedTakenIncorrect, UNIT_COUNT,
166  "Number of branches that were predicted taken incorrectly"),
167  ADD_STAT(predictedNotTakenIncorrect, UNIT_COUNT,
168  "Number of branches that were predicted not taken incorrectly"),
169  ADD_STAT(branchMispredicts, UNIT_COUNT,
170  "Number of branch mispredicts detected at execute",
171  predictedTakenIncorrect + predictedNotTakenIncorrect),
172  executedInstStats(cpu),
173  ADD_STAT(instsToCommit, UNIT_COUNT,
174  "Cumulative count of insts sent to commit"),
175  ADD_STAT(writebackCount, UNIT_COUNT,
176  "Cumulative count of insts written-back"),
177  ADD_STAT(producerInst, UNIT_COUNT,
178  "Number of instructions producing a value"),
179  ADD_STAT(consumerInst, UNIT_COUNT,
180  "Number of instructions consuming a value"),
181  ADD_STAT(wbRate, UNIT_RATE(Stats::Units::Count, Stats::Units::Cycle),
182  "Insts written-back per cycle"),
183  ADD_STAT(wbFanout, UNIT_RATE(Stats::Units::Count, Stats::Units::Count),
184  "Average fanout of values written-back")
185 {
187  .init(cpu->numThreads)
189 
191  .init(cpu->numThreads)
193 
195  .init(cpu->numThreads)
197 
199  .init(cpu->numThreads)
201 
202  wbRate
204  wbRate = writebackCount / cpu->baseStats.numCycles;
205 
206  wbFanout
209 }
210 
211 template <class Impl>
214  : Stats::Group(cpu),
215  ADD_STAT(numInsts, UNIT_COUNT, "Number of executed instructions"),
216  ADD_STAT(numLoadInsts, UNIT_COUNT, "Number of load instructions executed"),
217  ADD_STAT(numSquashedInsts, UNIT_COUNT,
218  "Number of squashed instructions skipped in execute"),
219  ADD_STAT(numSwp, UNIT_COUNT, "Number of swp insts executed"),
220  ADD_STAT(numNop, UNIT_COUNT, "Number of nop insts executed"),
221  ADD_STAT(numRefs, UNIT_COUNT, "Number of memory reference insts executed"),
222  ADD_STAT(numBranches, UNIT_COUNT, "Number of branches executed"),
223  ADD_STAT(numStoreInsts, UNIT_COUNT, "Number of stores executed"),
224  ADD_STAT(numRate, UNIT_RATE(Stats::Units::Count, Stats::Units::Cycle),
225  "Inst execution rate", numInsts / cpu->baseStats.numCycles)
226 {
228  .init(cpu->numThreads)
230 
231  numSwp
232  .init(cpu->numThreads)
234 
235  numNop
236  .init(cpu->numThreads)
238 
239  numRefs
240  .init(cpu->numThreads)
242 
244  .init(cpu->numThreads)
246 
250 
251  numRate
253 }
254 
255 template<class Impl>
256 void
258 {
259  for (ThreadID tid = 0; tid < numThreads; tid++) {
260  toRename->iewInfo[tid].usedIQ = true;
261  toRename->iewInfo[tid].freeIQEntries =
262  instQueue.numFreeEntries(tid);
263 
264  toRename->iewInfo[tid].usedLSQ = true;
265  toRename->iewInfo[tid].freeLQEntries = ldstQueue.numFreeLoadEntries(tid);
266  toRename->iewInfo[tid].freeSQEntries = ldstQueue.numFreeStoreEntries(tid);
267  }
268 
269  // Initialize the checker's dcache port here
270  if (cpu->checker) {
271  cpu->checker->setDcachePort(&ldstQueue.getDataPort());
272  }
273 
274  cpu->activateStage(O3CPU::IEWIdx);
275 }
276 
277 template<class Impl>
278 void
280 {
281  toRename->iewInfo[tid].usedIQ = true;
282  toRename->iewInfo[tid].freeIQEntries =
283  instQueue.numFreeEntries(tid);
284 
285  toRename->iewInfo[tid].usedLSQ = true;
286  toRename->iewInfo[tid].freeLQEntries = ldstQueue.numFreeLoadEntries(tid);
287  toRename->iewInfo[tid].freeSQEntries = ldstQueue.numFreeStoreEntries(tid);
288 }
289 
290 template<class Impl>
291 void
293 {
294  timeBuffer = tb_ptr;
295 
296  // Setup wire to read information from time buffer, from commit.
298 
299  // Setup wire to write information back to previous stages.
301 
302  toFetch = timeBuffer->getWire(0);
303 
304  // Instruction queue also needs main time buffer.
305  instQueue.setTimeBuffer(tb_ptr);
306 }
307 
308 template<class Impl>
309 void
311 {
312  renameQueue = rq_ptr;
313 
314  // Setup wire to read information from rename queue.
316 }
317 
318 template<class Impl>
319 void
321 {
322  iewQueue = iq_ptr;
323 
324  // Setup wire to write instructions to commit.
325  toCommit = iewQueue->getWire(0);
326 }
327 
328 template<class Impl>
329 void
331 {
332  activeThreads = at_ptr;
333 
334  ldstQueue.setActiveThreads(at_ptr);
335  instQueue.setActiveThreads(at_ptr);
336 }
337 
338 template<class Impl>
339 void
341 {
342  scoreboard = sb_ptr;
343 }
344 
345 template <class Impl>
346 bool
348 {
349  bool drained = ldstQueue.isDrained() && instQueue.isDrained();
350 
351  for (ThreadID tid = 0; tid < numThreads; tid++) {
352  if (!insts[tid].empty()) {
353  DPRINTF(Drain, "%i: Insts not empty.\n", tid);
354  drained = false;
355  }
356  if (!skidBuffer[tid].empty()) {
357  DPRINTF(Drain, "%i: Skid buffer not empty.\n", tid);
358  drained = false;
359  }
360  drained = drained && dispatchStatus[tid] == Running;
361  }
362 
363  // Also check the FU pool as instructions are "stored" in FU
364  // completion events until they are done and not accounted for
365  // above
366  if (drained && !fuPool->isDrained()) {
367  DPRINTF(Drain, "FU pool still busy.\n");
368  drained = false;
369  }
370 
371  return drained;
372 }
373 
374 template <class Impl>
375 void
377 {
378  assert(isDrained());
379 
380  instQueue.drainSanityCheck();
382 }
383 
384 template <class Impl>
385 void
387 {
388  // Reset all state.
389  _status = Active;
390  exeStatus = Running;
391  wbStatus = Idle;
392 
393  instQueue.takeOverFrom();
395  fuPool->takeOverFrom();
396 
397  startupStage();
398  cpu->activityThisCycle();
399 
400  for (ThreadID tid = 0; tid < numThreads; tid++) {
401  dispatchStatus[tid] = Running;
402  fetchRedirect[tid] = false;
403  }
404 
405  updateLSQNextCycle = false;
406 
407  for (int i = 0; i < issueToExecQueue.getSize(); ++i) {
409  }
410 }
411 
412 template<class Impl>
413 void
415 {
416  DPRINTF(IEW, "[tid:%i] Squashing all instructions.\n", tid);
417 
418  // Tell the IQ to start squashing.
419  instQueue.squash(tid);
420 
421  // Tell the LDSTQ to start squashing.
422  ldstQueue.squash(fromCommit->commitInfo[tid].doneSeqNum, tid);
423  updatedQueues = true;
424 
425  // Clear the skid buffer in case it has any data in it.
426  DPRINTF(IEW,
427  "Removing skidbuffer instructions until "
428  "[sn:%llu] [tid:%i]\n",
429  fromCommit->commitInfo[tid].doneSeqNum, tid);
430 
431  while (!skidBuffer[tid].empty()) {
432  if (skidBuffer[tid].front()->isLoad()) {
433  toRename->iewInfo[tid].dispatchedToLQ++;
434  }
435  if (skidBuffer[tid].front()->isStore() ||
436  skidBuffer[tid].front()->isAtomic()) {
437  toRename->iewInfo[tid].dispatchedToSQ++;
438  }
439 
440  toRename->iewInfo[tid].dispatched++;
441 
442  skidBuffer[tid].pop();
443  }
444 
445  emptyRenameInsts(tid);
446 }
447 
448 template<class Impl>
449 void
451 {
452  DPRINTF(IEW, "[tid:%i] [sn:%llu] Squashing from a specific instruction,"
453  " PC: %s "
454  "\n", tid, inst->seqNum, inst->pcState() );
455 
456  if (!toCommit->squash[tid] ||
457  inst->seqNum < toCommit->squashedSeqNum[tid]) {
458  toCommit->squash[tid] = true;
459  toCommit->squashedSeqNum[tid] = inst->seqNum;
460  toCommit->branchTaken[tid] = inst->pcState().branching();
461 
462  TheISA::PCState pc = inst->pcState();
463  TheISA::advancePC(pc, inst->staticInst);
464 
465  toCommit->pc[tid] = pc;
466  toCommit->mispredictInst[tid] = inst;
467  toCommit->includeSquashInst[tid] = false;
468 
469  wroteToTimeBuffer = true;
470  }
471 
472 }
473 
474 template<class Impl>
475 void
477 {
478  DPRINTF(IEW, "[tid:%i] Memory violation, squashing violator and younger "
479  "insts, PC: %s [sn:%llu].\n", tid, inst->pcState(), inst->seqNum);
480  // Need to include inst->seqNum in the following comparison to cover the
481  // corner case when a branch misprediction and a memory violation for the
482  // same instruction (e.g. load PC) are detected in the same cycle. In this
483  // case the memory violator should take precedence over the branch
484  // misprediction because it requires the violator itself to be included in
485  // the squash.
486  if (!toCommit->squash[tid] ||
487  inst->seqNum <= toCommit->squashedSeqNum[tid]) {
488  toCommit->squash[tid] = true;
489 
490  toCommit->squashedSeqNum[tid] = inst->seqNum;
491  toCommit->pc[tid] = inst->pcState();
492  toCommit->mispredictInst[tid] = NULL;
493 
494  // Must include the memory violator in the squash.
495  toCommit->includeSquashInst[tid] = true;
496 
497  wroteToTimeBuffer = true;
498  }
499 }
500 
501 template<class Impl>
502 void
504 {
505  DPRINTF(IEW, "[tid:%i] Blocking.\n", tid);
506 
507  if (dispatchStatus[tid] != Blocked &&
508  dispatchStatus[tid] != Unblocking) {
509  toRename->iewBlock[tid] = true;
510  wroteToTimeBuffer = true;
511  }
512 
513  // Add the current inputs to the skid buffer so they can be
514  // reprocessed when this stage unblocks.
515  skidInsert(tid);
516 
517  dispatchStatus[tid] = Blocked;
518 }
519 
520 template<class Impl>
521 void
523 {
524  DPRINTF(IEW, "[tid:%i] Reading instructions out of the skid "
525  "buffer %u.\n",tid, tid);
526 
527  // If the skid bufffer is empty, signal back to previous stages to unblock.
528  // Also switch status to running.
529  if (skidBuffer[tid].empty()) {
530  toRename->iewUnblock[tid] = true;
531  wroteToTimeBuffer = true;
532  DPRINTF(IEW, "[tid:%i] Done unblocking.\n",tid);
533  dispatchStatus[tid] = Running;
534  }
535 }
536 
537 template<class Impl>
538 void
540 {
541  instQueue.wakeDependents(inst);
542 }
543 
544 template<class Impl>
545 void
547 {
548  instQueue.rescheduleMemInst(inst);
549 }
550 
551 template<class Impl>
552 void
554 {
555  instQueue.replayMemInst(inst);
556 }
557 
558 template<class Impl>
559 void
561 {
562  instQueue.blockMemInst(inst);
563 }
564 
565 template<class Impl>
566 void
568 {
569  instQueue.cacheUnblocked();
570 }
571 
572 template<class Impl>
573 void
575 {
576  // This function should not be called after writebackInsts in a
577  // single cycle. That will cause problems with an instruction
578  // being added to the queue to commit without being processed by
579  // writebackInsts prior to being sent to commit.
580 
581  // First check the time slot that this instruction will write
582  // to. If there are free write ports at the time, then go ahead
583  // and write the instruction to that time. If there are not,
584  // keep looking back to see where's the first time there's a
585  // free slot.
586  while ((*iewQueue)[wbCycle].insts[wbNumInst]) {
587  ++wbNumInst;
588  if (wbNumInst == wbWidth) {
589  ++wbCycle;
590  wbNumInst = 0;
591  }
592  }
593 
594  DPRINTF(IEW, "Current wb cycle: %i, width: %i, numInst: %i\nwbActual:%i\n",
596  // Add finished instruction to queue to commit.
597  (*iewQueue)[wbCycle].insts[wbNumInst] = inst;
598  (*iewQueue)[wbCycle].size++;
599 }
600 
601 template <class Impl>
602 unsigned
604 {
605  unsigned inst_count = 0;
606 
607  for (int i=0; i<fromRename->size; i++) {
608  if (!fromRename->insts[i]->isSquashed())
609  inst_count++;
610  }
611 
612  return inst_count;
613 }
614 
615 template<class Impl>
616 void
618 {
619  DynInstPtr inst = NULL;
620 
621  while (!insts[tid].empty()) {
622  inst = insts[tid].front();
623 
624  insts[tid].pop();
625 
626  DPRINTF(IEW,"[tid:%i] Inserting [sn:%lli] PC:%s into "
627  "dispatch skidBuffer %i\n",tid, inst->seqNum,
628  inst->pcState(),tid);
629 
630  skidBuffer[tid].push(inst);
631  }
632 
633  assert(skidBuffer[tid].size() <= skidBufferMax &&
634  "Skidbuffer Exceeded Max Size");
635 }
636 
637 template<class Impl>
638 int
640 {
641  int max=0;
642 
643  std::list<ThreadID>::iterator threads = activeThreads->begin();
645 
646  while (threads != end) {
647  ThreadID tid = *threads++;
648  unsigned thread_count = skidBuffer[tid].size();
649  if (max < thread_count)
650  max = thread_count;
651  }
652 
653  return max;
654 }
655 
656 template<class Impl>
657 bool
659 {
660  std::list<ThreadID>::iterator threads = activeThreads->begin();
662 
663  while (threads != end) {
664  ThreadID tid = *threads++;
665 
666  if (!skidBuffer[tid].empty())
667  return false;
668  }
669 
670  return true;
671 }
672 
673 template <class Impl>
674 void
676 {
677  bool any_unblocking = false;
678 
679  std::list<ThreadID>::iterator threads = activeThreads->begin();
681 
682  while (threads != end) {
683  ThreadID tid = *threads++;
684 
685  if (dispatchStatus[tid] == Unblocking) {
686  any_unblocking = true;
687  break;
688  }
689  }
690 
691  // If there are no ready instructions waiting to be scheduled by the IQ,
692  // and there's no stores waiting to write back, and dispatch is not
693  // unblocking, then there is no internal activity for the IEW stage.
694  instQueue.iqIOStats.intInstQueueReads++;
695  if (_status == Active && !instQueue.hasReadyInsts() &&
696  !ldstQueue.willWB() && !any_unblocking) {
697  DPRINTF(IEW, "IEW switching to idle\n");
698 
699  deactivateStage();
700 
701  _status = Inactive;
702  } else if (_status == Inactive && (instQueue.hasReadyInsts() ||
703  ldstQueue.willWB() ||
704  any_unblocking)) {
705  // Otherwise there is internal activity. Set to active.
706  DPRINTF(IEW, "IEW switching to active\n");
707 
708  activateStage();
709 
710  _status = Active;
711  }
712 }
713 
714 template <class Impl>
715 bool
717 {
718  bool ret_val(false);
719 
720  if (fromCommit->commitInfo[tid].robSquashing) {
721  DPRINTF(IEW,"[tid:%i] Stall from Commit stage detected.\n",tid);
722  ret_val = true;
723  } else if (instQueue.isFull(tid)) {
724  DPRINTF(IEW,"[tid:%i] Stall: IQ is full.\n",tid);
725  ret_val = true;
726  }
727 
728  return ret_val;
729 }
730 
731 template <class Impl>
732 void
734 {
735  // Check if there's a squash signal, squash if there is
736  // Check stall signals, block if there is.
737  // If status was Blocked
738  // if so then go to unblocking
739  // If status was Squashing
740  // check if squashing is not high. Switch to running this cycle.
741 
742  if (fromCommit->commitInfo[tid].squash) {
743  squash(tid);
744 
745  if (dispatchStatus[tid] == Blocked ||
746  dispatchStatus[tid] == Unblocking) {
747  toRename->iewUnblock[tid] = true;
748  wroteToTimeBuffer = true;
749  }
750 
751  dispatchStatus[tid] = Squashing;
752  fetchRedirect[tid] = false;
753  return;
754  }
755 
756  if (fromCommit->commitInfo[tid].robSquashing) {
757  DPRINTF(IEW, "[tid:%i] ROB is still squashing.\n", tid);
758 
759  dispatchStatus[tid] = Squashing;
760  emptyRenameInsts(tid);
761  wroteToTimeBuffer = true;
762  }
763 
764  if (checkStall(tid)) {
765  block(tid);
766  dispatchStatus[tid] = Blocked;
767  return;
768  }
769 
770  if (dispatchStatus[tid] == Blocked) {
771  // Status from previous cycle was blocked, but there are no more stall
772  // conditions. Switch over to unblocking.
773  DPRINTF(IEW, "[tid:%i] Done blocking, switching to unblocking.\n",
774  tid);
775 
776  dispatchStatus[tid] = Unblocking;
777 
778  unblock(tid);
779 
780  return;
781  }
782 
783  if (dispatchStatus[tid] == Squashing) {
784  // Switch status to running if rename isn't being told to block or
785  // squash this cycle.
786  DPRINTF(IEW, "[tid:%i] Done squashing, switching to running.\n",
787  tid);
788 
789  dispatchStatus[tid] = Running;
790 
791  return;
792  }
793 }
794 
795 template <class Impl>
796 void
798 {
799  int insts_from_rename = fromRename->size;
800 #ifdef DEBUG
801  for (ThreadID tid = 0; tid < numThreads; tid++)
802  assert(insts[tid].empty());
803 #endif
804  for (int i = 0; i < insts_from_rename; ++i) {
805  insts[fromRename->insts[i]->threadNumber].push(fromRename->insts[i]);
806  }
807 }
808 
809 template <class Impl>
810 void
812 {
813  DPRINTF(IEW, "[tid:%i] Removing incoming rename instructions\n", tid);
814 
815  while (!insts[tid].empty()) {
816 
817  if (insts[tid].front()->isLoad()) {
818  toRename->iewInfo[tid].dispatchedToLQ++;
819  }
820  if (insts[tid].front()->isStore() ||
821  insts[tid].front()->isAtomic()) {
822  toRename->iewInfo[tid].dispatchedToSQ++;
823  }
824 
825  toRename->iewInfo[tid].dispatched++;
826 
827  insts[tid].pop();
828  }
829 }
830 
831 template <class Impl>
832 void
834 {
835  cpu->wakeCPU();
836 }
837 
838 template <class Impl>
839 void
841 {
842  DPRINTF(Activity, "Activity this cycle.\n");
843  cpu->activityThisCycle();
844 }
845 
846 template <class Impl>
847 inline void
849 {
850  DPRINTF(Activity, "Activating stage.\n");
851  cpu->activateStage(O3CPU::IEWIdx);
852 }
853 
854 template <class Impl>
855 inline void
857 {
858  DPRINTF(Activity, "Deactivating stage.\n");
859  cpu->deactivateStage(O3CPU::IEWIdx);
860 }
861 
862 template<class Impl>
863 void
865 {
866  // If status is Running or idle,
867  // call dispatchInsts()
868  // If status is Unblocking,
869  // buffer any instructions coming from rename
870  // continue trying to empty skid buffer
871  // check if stall conditions have passed
872 
873  if (dispatchStatus[tid] == Blocked) {
875 
876  } else if (dispatchStatus[tid] == Squashing) {
878  }
879 
880  // Dispatch should try to dispatch as many instructions as its bandwidth
881  // will allow, as long as it is not currently blocked.
882  if (dispatchStatus[tid] == Running ||
883  dispatchStatus[tid] == Idle) {
884  DPRINTF(IEW, "[tid:%i] Not blocked, so attempting to run "
885  "dispatch.\n", tid);
886 
887  dispatchInsts(tid);
888  } else if (dispatchStatus[tid] == Unblocking) {
889  // Make sure that the skid buffer has something in it if the
890  // status is unblocking.
891  assert(!skidsEmpty());
892 
893  // If the status was unblocking, then instructions from the skid
894  // buffer were used. Remove those instructions and handle
895  // the rest of unblocking.
896  dispatchInsts(tid);
897 
899 
900  if (validInstsFromRename()) {
901  // Add the current inputs to the skid buffer so they can be
902  // reprocessed when this stage unblocks.
903  skidInsert(tid);
904  }
905 
906  unblock(tid);
907  }
908 }
909 
910 template <class Impl>
911 void
913 {
914  // Obtain instructions from skid buffer if unblocking, or queue from rename
915  // otherwise.
916  std::queue<DynInstPtr> &insts_to_dispatch =
917  dispatchStatus[tid] == Unblocking ?
918  skidBuffer[tid] : insts[tid];
919 
920  int insts_to_add = insts_to_dispatch.size();
921 
922  DynInstPtr inst;
923  bool add_to_iq = false;
924  int dis_num_inst = 0;
925 
926  // Loop through the instructions, putting them in the instruction
927  // queue.
928  for ( ; dis_num_inst < insts_to_add &&
929  dis_num_inst < dispatchWidth;
930  ++dis_num_inst)
931  {
932  inst = insts_to_dispatch.front();
933 
934  if (dispatchStatus[tid] == Unblocking) {
935  DPRINTF(IEW, "[tid:%i] Issue: Examining instruction from skid "
936  "buffer\n", tid);
937  }
938 
939  // Make sure there's a valid instruction there.
940  assert(inst);
941 
942  DPRINTF(IEW, "[tid:%i] Issue: Adding PC %s [sn:%lli] [tid:%i] to "
943  "IQ.\n",
944  tid, inst->pcState(), inst->seqNum, inst->threadNumber);
945 
946  // Be sure to mark these instructions as ready so that the
947  // commit stage can go ahead and execute them, and mark
948  // them as issued so the IQ doesn't reprocess them.
949 
950  // Check for squashed instructions.
951  if (inst->isSquashed()) {
952  DPRINTF(IEW, "[tid:%i] Issue: Squashed instruction encountered, "
953  "not adding to IQ.\n", tid);
954 
956 
957  insts_to_dispatch.pop();
958 
959  //Tell Rename That An Instruction has been processed
960  if (inst->isLoad()) {
961  toRename->iewInfo[tid].dispatchedToLQ++;
962  }
963  if (inst->isStore() || inst->isAtomic()) {
964  toRename->iewInfo[tid].dispatchedToSQ++;
965  }
966 
967  toRename->iewInfo[tid].dispatched++;
968 
969  continue;
970  }
971 
972  // Check for full conditions.
973  if (instQueue.isFull(tid)) {
974  DPRINTF(IEW, "[tid:%i] Issue: IQ has become full.\n", tid);
975 
976  // Call function to start blocking.
977  block(tid);
978 
979  // Set unblock to false. Special case where we are using
980  // skidbuffer (unblocking) instructions but then we still
981  // get full in the IQ.
982  toRename->iewUnblock[tid] = false;
983 
985  break;
986  }
987 
988  // Check LSQ if inst is LD/ST
989  if ((inst->isAtomic() && ldstQueue.sqFull(tid)) ||
990  (inst->isLoad() && ldstQueue.lqFull(tid)) ||
991  (inst->isStore() && ldstQueue.sqFull(tid))) {
992  DPRINTF(IEW, "[tid:%i] Issue: %s has become full.\n",tid,
993  inst->isLoad() ? "LQ" : "SQ");
994 
995  // Call function to start blocking.
996  block(tid);
997 
998  // Set unblock to false. Special case where we are using
999  // skidbuffer (unblocking) instructions but then we still
1000  // get full in the IQ.
1001  toRename->iewUnblock[tid] = false;
1002 
1004  break;
1005  }
1006 
1007  // hardware transactional memory
1008  // CPU needs to track transactional state in program order.
1009  const int numHtmStarts = ldstQueue.numHtmStarts(tid);
1010  const int numHtmStops = ldstQueue.numHtmStops(tid);
1011  const int htmDepth = numHtmStarts - numHtmStops;
1012 
1013  if (htmDepth > 0) {
1014  inst->setHtmTransactionalState(ldstQueue.getLatestHtmUid(tid),
1015  htmDepth);
1016  } else {
1017  inst->clearHtmTransactionalState();
1018  }
1019 
1020 
1021  // Otherwise issue the instruction just fine.
1022  if (inst->isAtomic()) {
1023  DPRINTF(IEW, "[tid:%i] Issue: Memory instruction "
1024  "encountered, adding to LSQ.\n", tid);
1025 
1026  ldstQueue.insertStore(inst);
1027 
1029 
1030  // AMOs need to be set as "canCommit()"
1031  // so that commit can process them when they reach the
1032  // head of commit.
1033  inst->setCanCommit();
1034  instQueue.insertNonSpec(inst);
1035  add_to_iq = false;
1036 
1038 
1039  toRename->iewInfo[tid].dispatchedToSQ++;
1040  } else if (inst->isLoad()) {
1041  DPRINTF(IEW, "[tid:%i] Issue: Memory instruction "
1042  "encountered, adding to LSQ.\n", tid);
1043 
1044  // Reserve a spot in the load store queue for this
1045  // memory access.
1046  ldstQueue.insertLoad(inst);
1047 
1049 
1050  add_to_iq = true;
1051 
1052  toRename->iewInfo[tid].dispatchedToLQ++;
1053  } else if (inst->isStore()) {
1054  DPRINTF(IEW, "[tid:%i] Issue: Memory instruction "
1055  "encountered, adding to LSQ.\n", tid);
1056 
1057  ldstQueue.insertStore(inst);
1058 
1060 
1061  if (inst->isStoreConditional()) {
1062  // Store conditionals need to be set as "canCommit()"
1063  // so that commit can process them when they reach the
1064  // head of commit.
1065  // @todo: This is somewhat specific to Alpha.
1066  inst->setCanCommit();
1067  instQueue.insertNonSpec(inst);
1068  add_to_iq = false;
1069 
1071  } else {
1072  add_to_iq = true;
1073  }
1074 
1075  toRename->iewInfo[tid].dispatchedToSQ++;
1076  } else if (inst->isReadBarrier() || inst->isWriteBarrier()) {
1077  // Same as non-speculative stores.
1078  inst->setCanCommit();
1079  instQueue.insertBarrier(inst);
1080  add_to_iq = false;
1081  } else if (inst->isNop()) {
1082  DPRINTF(IEW, "[tid:%i] Issue: Nop instruction encountered, "
1083  "skipping.\n", tid);
1084 
1085  inst->setIssued();
1086  inst->setExecuted();
1087  inst->setCanCommit();
1088 
1089  instQueue.recordProducer(inst);
1090 
1092 
1093  add_to_iq = false;
1094  } else {
1095  assert(!inst->isExecuted());
1096  add_to_iq = true;
1097  }
1098 
1099  if (add_to_iq && inst->isNonSpeculative()) {
1100  DPRINTF(IEW, "[tid:%i] Issue: Nonspeculative instruction "
1101  "encountered, skipping.\n", tid);
1102 
1103  // Same as non-speculative stores.
1104  inst->setCanCommit();
1105 
1106  // Specifically insert it as nonspeculative.
1107  instQueue.insertNonSpec(inst);
1108 
1110 
1111  add_to_iq = false;
1112  }
1113 
1114  // If the instruction queue is not full, then add the
1115  // instruction.
1116  if (add_to_iq) {
1117  instQueue.insert(inst);
1118  }
1119 
1120  insts_to_dispatch.pop();
1121 
1122  toRename->iewInfo[tid].dispatched++;
1123 
1125 
1126 #if TRACING_ON
1127  inst->dispatchTick = curTick() - inst->fetchTick;
1128 #endif
1129  ppDispatch->notify(inst);
1130  }
1131 
1132  if (!insts_to_dispatch.empty()) {
1133  DPRINTF(IEW,"[tid:%i] Issue: Bandwidth Full. Blocking.\n", tid);
1134  block(tid);
1135  toRename->iewUnblock[tid] = false;
1136  }
1137 
1138  if (dispatchStatus[tid] == Idle && dis_num_inst) {
1139  dispatchStatus[tid] = Running;
1140 
1141  updatedQueues = true;
1142  }
1143 
1144  dis_num_inst = 0;
1145 }
1146 
1147 template <class Impl>
1148 void
1150 {
1151  int inst = 0;
1152 
1153  std::cout << "Available Instructions: ";
1154 
1155  while (fromIssue->insts[inst]) {
1156 
1157  if (inst%3==0) std::cout << "\n\t";
1158 
1159  std::cout << "PC: " << fromIssue->insts[inst]->pcState()
1160  << " TN: " << fromIssue->insts[inst]->threadNumber
1161  << " SN: " << fromIssue->insts[inst]->seqNum << " | ";
1162 
1163  inst++;
1164 
1165  }
1166 
1167  std::cout << "\n";
1168 }
1169 
1170 template <class Impl>
1171 void
1173 {
1174  wbNumInst = 0;
1175  wbCycle = 0;
1176 
1177  std::list<ThreadID>::iterator threads = activeThreads->begin();
1179 
1180  while (threads != end) {
1181  ThreadID tid = *threads++;
1182  fetchRedirect[tid] = false;
1183  }
1184 
1185  // Uncomment this if you want to see all available instructions.
1186  // @todo This doesn't actually work anymore, we should fix it.
1187 // printAvailableInsts();
1188 
1189  // Execute/writeback any instructions that are available.
1190  int insts_to_execute = fromIssue->size;
1191  int inst_num = 0;
1192  for (; inst_num < insts_to_execute;
1193  ++inst_num) {
1194 
1195  DPRINTF(IEW, "Execute: Executing instructions from IQ.\n");
1196 
1197  DynInstPtr inst = instQueue.getInstToExecute();
1198 
1199  DPRINTF(IEW, "Execute: Processing PC %s, [tid:%i] [sn:%llu].\n",
1200  inst->pcState(), inst->threadNumber,inst->seqNum);
1201 
1202  // Notify potential listeners that this instruction has started
1203  // executing
1204  ppExecute->notify(inst);
1205 
1206  // Check if the instruction is squashed; if so then skip it
1207  if (inst->isSquashed()) {
1208  DPRINTF(IEW, "Execute: Instruction was squashed. PC: %s, [tid:%i]"
1209  " [sn:%llu]\n", inst->pcState(), inst->threadNumber,
1210  inst->seqNum);
1211 
1212  // Consider this instruction executed so that commit can go
1213  // ahead and retire the instruction.
1214  inst->setExecuted();
1215 
1216  // Not sure if I should set this here or just let commit try to
1217  // commit any squashed instructions. I like the latter a bit more.
1218  inst->setCanCommit();
1219 
1221 
1222  continue;
1223  }
1224 
1225  Fault fault = NoFault;
1226 
1227  // Execute instruction.
1228  // Note that if the instruction faults, it will be handled
1229  // at the commit stage.
1230  if (inst->isMemRef()) {
1231  DPRINTF(IEW, "Execute: Calculating address for memory "
1232  "reference.\n");
1233 
1234  // Tell the LDSTQ to execute this instruction (if it is a load).
1235  if (inst->isAtomic()) {
1236  // AMOs are treated like store requests
1237  fault = ldstQueue.executeStore(inst);
1238 
1239  if (inst->isTranslationDelayed() &&
1240  fault == NoFault) {
1241  // A hw page table walk is currently going on; the
1242  // instruction must be deferred.
1243  DPRINTF(IEW, "Execute: Delayed translation, deferring "
1244  "store.\n");
1245  instQueue.deferMemInst(inst);
1246  continue;
1247  }
1248  } else if (inst->isLoad()) {
1249  // Loads will mark themselves as executed, and their writeback
1250  // event adds the instruction to the queue to commit
1251  fault = ldstQueue.executeLoad(inst);
1252 
1253  if (inst->isTranslationDelayed() &&
1254  fault == NoFault) {
1255  // A hw page table walk is currently going on; the
1256  // instruction must be deferred.
1257  DPRINTF(IEW, "Execute: Delayed translation, deferring "
1258  "load.\n");
1259  instQueue.deferMemInst(inst);
1260  continue;
1261  }
1262 
1263  if (inst->isDataPrefetch() || inst->isInstPrefetch()) {
1264  inst->fault = NoFault;
1265  }
1266  } else if (inst->isStore()) {
1267  fault = ldstQueue.executeStore(inst);
1268 
1269  if (inst->isTranslationDelayed() &&
1270  fault == NoFault) {
1271  // A hw page table walk is currently going on; the
1272  // instruction must be deferred.
1273  DPRINTF(IEW, "Execute: Delayed translation, deferring "
1274  "store.\n");
1275  instQueue.deferMemInst(inst);
1276  continue;
1277  }
1278 
1279  // If the store had a fault then it may not have a mem req
1280  if (fault != NoFault || !inst->readPredicate() ||
1281  !inst->isStoreConditional()) {
1282  // If the instruction faulted, then we need to send it along
1283  // to commit without the instruction completing.
1284  // Send this instruction to commit, also make sure iew stage
1285  // realizes there is activity.
1286  inst->setExecuted();
1287  instToCommit(inst);
1289  }
1290 
1291  // Store conditionals will mark themselves as
1292  // executed, and their writeback event will add the
1293  // instruction to the queue to commit.
1294  } else {
1295  panic("Unexpected memory type!\n");
1296  }
1297 
1298  } else {
1299  // If the instruction has already faulted, then skip executing it.
1300  // Such case can happen when it faulted during ITLB translation.
1301  // If we execute the instruction (even if it's a nop) the fault
1302  // will be replaced and we will lose it.
1303  if (inst->getFault() == NoFault) {
1304  inst->execute();
1305  if (!inst->readPredicate())
1306  inst->forwardOldRegs();
1307  }
1308 
1309  inst->setExecuted();
1310 
1311  instToCommit(inst);
1312  }
1313 
1314  updateExeInstStats(inst);
1315 
1316  // Check if branch prediction was correct, if not then we need
1317  // to tell commit to squash in flight instructions. Only
1318  // handle this if there hasn't already been something that
1319  // redirects fetch in this group of instructions.
1320 
1321  // This probably needs to prioritize the redirects if a different
1322  // scheduler is used. Currently the scheduler schedules the oldest
1323  // instruction first, so the branch resolution order will be correct.
1324  ThreadID tid = inst->threadNumber;
1325 
1326  if (!fetchRedirect[tid] ||
1327  !toCommit->squash[tid] ||
1328  toCommit->squashedSeqNum[tid] > inst->seqNum) {
1329 
1330  // Prevent testing for misprediction on load instructions,
1331  // that have not been executed.
1332  bool loadNotExecuted = !inst->isExecuted() && inst->isLoad();
1333 
1334  if (inst->mispredicted() && !loadNotExecuted) {
1335  fetchRedirect[tid] = true;
1336 
1337  DPRINTF(IEW, "[tid:%i] [sn:%llu] Execute: "
1338  "Branch mispredict detected.\n",
1339  tid,inst->seqNum);
1340  DPRINTF(IEW, "[tid:%i] [sn:%llu] "
1341  "Predicted target was PC: %s\n",
1342  tid,inst->seqNum,inst->readPredTarg());
1343  DPRINTF(IEW, "[tid:%i] [sn:%llu] Execute: "
1344  "Redirecting fetch to PC: %s\n",
1345  tid,inst->seqNum,inst->pcState());
1346  // If incorrect, then signal the ROB that it must be squashed.
1347  squashDueToBranch(inst, tid);
1348 
1349  ppMispredict->notify(inst);
1350 
1351  if (inst->readPredTaken()) {
1353  } else {
1355  }
1356  } else if (ldstQueue.violation(tid)) {
1357  assert(inst->isMemRef());
1358  // If there was an ordering violation, then get the
1359  // DynInst that caused the violation. Note that this
1360  // clears the violation signal.
1361  DynInstPtr violator;
1362  violator = ldstQueue.getMemDepViolator(tid);
1363 
1364  DPRINTF(IEW, "LDSTQ detected a violation. Violator PC: %s "
1365  "[sn:%lli], inst PC: %s [sn:%lli]. Addr is: %#x.\n",
1366  violator->pcState(), violator->seqNum,
1367  inst->pcState(), inst->seqNum, inst->physEffAddr);
1368 
1369  fetchRedirect[tid] = true;
1370 
1371  // Tell the instruction queue that a violation has occured.
1372  instQueue.violation(inst, violator);
1373 
1374  // Squash.
1375  squashDueToMemOrder(violator, tid);
1376 
1378  }
1379  } else {
1380  // Reset any state associated with redirects that will not
1381  // be used.
1382  if (ldstQueue.violation(tid)) {
1383  assert(inst->isMemRef());
1384 
1385  DynInstPtr violator = ldstQueue.getMemDepViolator(tid);
1386 
1387  DPRINTF(IEW, "LDSTQ detected a violation. Violator PC: "
1388  "%s, inst PC: %s. Addr is: %#x.\n",
1389  violator->pcState(), inst->pcState(),
1390  inst->physEffAddr);
1391  DPRINTF(IEW, "Violation will not be handled because "
1392  "already squashing\n");
1393 
1395  }
1396  }
1397  }
1398 
1399  // Update and record activity if we processed any instructions.
1400  if (inst_num) {
1401  if (exeStatus == Idle) {
1402  exeStatus = Running;
1403  }
1404 
1405  updatedQueues = true;
1406 
1407  cpu->activityThisCycle();
1408  }
1409 
1410  // Need to reset this in case a writeback event needs to write into the
1411  // iew queue. That way the writeback event will write into the correct
1412  // spot in the queue.
1413  wbNumInst = 0;
1414 
1415 }
1416 
1417 template <class Impl>
1418 void
1420 {
1421  // Loop through the head of the time buffer and wake any
1422  // dependents. These instructions are about to write back. Also
1423  // mark scoreboard that this instruction is finally complete.
1424  // Either have IEW have direct access to scoreboard, or have this
1425  // as part of backwards communication.
1426  for (int inst_num = 0; inst_num < wbWidth &&
1427  toCommit->insts[inst_num]; inst_num++) {
1428  DynInstPtr inst = toCommit->insts[inst_num];
1429  ThreadID tid = inst->threadNumber;
1430 
1431  DPRINTF(IEW, "Sending instructions to commit, [sn:%lli] PC %s.\n",
1432  inst->seqNum, inst->pcState());
1433 
1434  iewStats.instsToCommit[tid]++;
1435  // Notify potential listeners that execution is complete for this
1436  // instruction.
1437  ppToCommit->notify(inst);
1438 
1439  // Some instructions will be sent to commit without having
1440  // executed because they need commit to handle them.
1441  // E.g. Strictly ordered loads have not actually executed when they
1442  // are first sent to commit. Instead commit must tell the LSQ
1443  // when it's ready to execute the strictly ordered load.
1444  if (!inst->isSquashed() && inst->isExecuted() && inst->getFault() == NoFault) {
1445  int dependents = instQueue.wakeDependents(inst);
1446 
1447  for (int i = 0; i < inst->numDestRegs(); i++) {
1448  // Mark register as ready if not pinned
1449  if (inst->regs.renamedDestIdx(i)->
1450  getNumPinnedWritesToComplete() == 0) {
1451  DPRINTF(IEW,"Setting Destination Register %i (%s)\n",
1452  inst->regs.renamedDestIdx(i)->index(),
1453  inst->regs.renamedDestIdx(i)->className());
1454  scoreboard->setReg(inst->regs.renamedDestIdx(i));
1455  }
1456  }
1457 
1458  if (dependents) {
1459  iewStats.producerInst[tid]++;
1460  iewStats.consumerInst[tid]+= dependents;
1461  }
1462  iewStats.writebackCount[tid]++;
1463  }
1464  }
1465 }
1466 
1467 template<class Impl>
1468 void
1470 {
1471  wbNumInst = 0;
1472  wbCycle = 0;
1473 
1474  wroteToTimeBuffer = false;
1475  updatedQueues = false;
1476 
1477  ldstQueue.tick();
1478 
1479  sortInsts();
1480 
1481  // Free function units marked as being freed this cycle.
1483 
1484  std::list<ThreadID>::iterator threads = activeThreads->begin();
1486 
1487  // Check stall and squash signals, dispatch any instructions.
1488  while (threads != end) {
1489  ThreadID tid = *threads++;
1490 
1491  DPRINTF(IEW,"Issue: Processing [tid:%i]\n",tid);
1492 
1493  checkSignalsAndUpdate(tid);
1494  dispatch(tid);
1495  }
1496 
1497  if (exeStatus != Squashing) {
1498  executeInsts();
1499 
1500  writebackInsts();
1501 
1502  // Have the instruction queue try to schedule any ready instructions.
1503  // (In actuality, this scheduling is for instructions that will
1504  // be executed next cycle.)
1505  instQueue.scheduleReadyInsts();
1506 
1507  // Also should advance its own time buffers if the stage ran.
1508  // Not the best place for it, but this works (hopefully).
1510  }
1511 
1512  bool broadcast_free_entries = false;
1513 
1515  exeStatus = Idle;
1516  updateLSQNextCycle = false;
1517 
1518  broadcast_free_entries = true;
1519  }
1520 
1521  // Writeback any stores using any leftover bandwidth.
1523 
1524  // Check the committed load/store signals to see if there's a load
1525  // or store to commit. Also check if it's being told to execute a
1526  // nonspeculative instruction.
1527  // This is pretty inefficient...
1528 
1529  threads = activeThreads->begin();
1530  while (threads != end) {
1531  ThreadID tid = (*threads++);
1532 
1533  DPRINTF(IEW,"Processing [tid:%i]\n",tid);
1534 
1535  // Update structures based on instructions committed.
1536  if (fromCommit->commitInfo[tid].doneSeqNum != 0 &&
1537  !fromCommit->commitInfo[tid].squash &&
1538  !fromCommit->commitInfo[tid].robSquashing) {
1539 
1540  ldstQueue.commitStores(fromCommit->commitInfo[tid].doneSeqNum,tid);
1541 
1542  ldstQueue.commitLoads(fromCommit->commitInfo[tid].doneSeqNum,tid);
1543 
1544  updateLSQNextCycle = true;
1545  instQueue.commit(fromCommit->commitInfo[tid].doneSeqNum,tid);
1546  }
1547 
1548  if (fromCommit->commitInfo[tid].nonSpecSeqNum != 0) {
1549 
1550  //DPRINTF(IEW,"NonspecInst from thread %i",tid);
1551  if (fromCommit->commitInfo[tid].strictlyOrdered) {
1552  instQueue.replayMemInst(
1553  fromCommit->commitInfo[tid].strictlyOrderedLoad);
1554  fromCommit->commitInfo[tid].strictlyOrderedLoad->setAtCommit();
1555  } else {
1556  instQueue.scheduleNonSpec(
1557  fromCommit->commitInfo[tid].nonSpecSeqNum);
1558  }
1559  }
1560 
1561  if (broadcast_free_entries) {
1562  toFetch->iewInfo[tid].iqCount =
1563  instQueue.getCount(tid);
1564  toFetch->iewInfo[tid].ldstqCount =
1565  ldstQueue.getCount(tid);
1566 
1567  toRename->iewInfo[tid].usedIQ = true;
1568  toRename->iewInfo[tid].freeIQEntries =
1569  instQueue.numFreeEntries(tid);
1570  toRename->iewInfo[tid].usedLSQ = true;
1571 
1572  toRename->iewInfo[tid].freeLQEntries =
1574  toRename->iewInfo[tid].freeSQEntries =
1576 
1577  wroteToTimeBuffer = true;
1578  }
1579 
1580  DPRINTF(IEW, "[tid:%i], Dispatch dispatched %i instructions.\n",
1581  tid, toRename->iewInfo[tid].dispatched);
1582  }
1583 
1584  DPRINTF(IEW, "IQ has %i free entries (Can schedule: %i). "
1585  "LQ has %i free entries. SQ has %i free entries.\n",
1586  instQueue.numFreeEntries(), instQueue.hasReadyInsts(),
1588 
1589  updateStatus();
1590 
1591  if (wroteToTimeBuffer) {
1592  DPRINTF(Activity, "Activity this cycle.\n");
1593  cpu->activityThisCycle();
1594  }
1595 }
1596 
1597 template <class Impl>
1598 void
1600 {
1601  ThreadID tid = inst->threadNumber;
1602 
1604 
1605 #if TRACING_ON
1606  if (DTRACE(O3PipeView)) {
1607  inst->completeTick = curTick() - inst->fetchTick;
1608  }
1609 #endif
1610 
1611  //
1612  // Control operations
1613  //
1614  if (inst->isControl())
1616 
1617  //
1618  // Memory operations
1619  //
1620  if (inst->isMemRef()) {
1622 
1623  if (inst->isLoad()) {
1625  }
1626  }
1627 }
1628 
1629 template <class Impl>
1630 void
1632 {
1633  ThreadID tid = inst->threadNumber;
1634 
1635  if (!fetchRedirect[tid] ||
1636  !toCommit->squash[tid] ||
1637  toCommit->squashedSeqNum[tid] > inst->seqNum) {
1638 
1639  if (inst->mispredicted()) {
1640  fetchRedirect[tid] = true;
1641 
1642  DPRINTF(IEW, "[tid:%i] [sn:%llu] Execute: "
1643  "Branch mispredict detected.\n",
1644  tid,inst->seqNum);
1645  DPRINTF(IEW, "[tid:%i] [sn:%llu] Predicted target "
1646  "was PC:%#x, NPC:%#x\n",
1647  tid,inst->seqNum,
1648  inst->predInstAddr(), inst->predNextInstAddr());
1649  DPRINTF(IEW, "[tid:%i] [sn:%llu] Execute: "
1650  "Redirecting fetch to PC: %#x, "
1651  "NPC: %#x.\n",
1652  tid,inst->seqNum,
1653  inst->nextInstAddr(),
1654  inst->nextInstAddr());
1655  // If incorrect, then signal the ROB that it must be squashed.
1656  squashDueToBranch(inst, tid);
1657 
1658  if (inst->readPredTaken()) {
1660  } else {
1662  }
1663  }
1664  }
1665 }
1666 
1667 #endif//__CPU_O3_IEW_IMPL_IMPL_HH__
LSQ::insertStore
void insertStore(const DynInstPtr &store_inst)
Inserts a store into the LSQ.
Definition: lsq_impl.hh:228
fatal
#define fatal(...)
This implements a cprintf based fatal() function.
Definition: logging.hh:183
DefaultIEW::wakeCPU
void wakeCPU()
Tells the CPU to wakeup if it has descheduled itself due to no activity.
Definition: iew_impl.hh:833
DefaultIEW::issueToExecQueue
TimeBuffer< IssueStruct > issueToExecQueue
Issue stage queue.
Definition: iew.hh:327
DefaultIEW::IEWStats::ExecutedInstStats::numNop
Stats::Vector numNop
Number of executed nops.
Definition: iew.hh:477
LSQ::willWB
bool willWB()
Returns if the LSQ will write back to memory this cycle.
Definition: lsq_impl.hh:644
DefaultIEW::wbCycle
unsigned wbCycle
Cycle number within the queue of instructions being written back.
Definition: iew.hh:412
Scoreboard::setReg
void setReg(PhysRegIdPtr phys_reg)
Sets the register as ready.
Definition: scoreboard.hh:93
LSQ::executeStore
Fault executeStore(const DynInstPtr &inst)
Executes a store.
Definition: lsq_impl.hh:246
DefaultIEW::takeOverFrom
void takeOverFrom()
Takes over from another CPU's thread.
Definition: iew_impl.hh:386
DefaultIEW::IEWStats::squashCycles
Stats::Scalar squashCycles
Stat for total number of squashing cycles.
Definition: iew.hh:434
DefaultIEW::IEWStats::blockCycles
Stats::Scalar blockCycles
Stat for total number of blocking cycles.
Definition: iew.hh:436
DefaultIEW::emptyRenameInsts
void emptyRenameInsts(ThreadID tid)
Removes instructions from rename from a thread's instruction list.
Definition: iew_impl.hh:811
LSQ::commitStores
void commitStores(InstSeqNum &youngest_inst, ThreadID tid)
Commits stores up until the given sequence number for a specific thread.
Definition: lsq.hh:898
DefaultIEW::IEWStats::ExecutedInstStats::numStoreInsts
Stats::Formula numStoreInsts
Number of executed store instructions.
Definition: iew.hh:483
DefaultIEW::checkSignalsAndUpdate
void checkSignalsAndUpdate(ThreadID tid)
Processes inputs and changes state accordingly.
Definition: iew_impl.hh:733
DefaultIEW::wbWidth
unsigned wbWidth
Writeback width.
Definition: iew.hh:415
DefaultIEW::IEWStats::ExecutedInstStats::numLoadInsts
Stats::Vector numLoadInsts
Stat for total number of executed load instructions.
Definition: iew.hh:470
LSQ::numHtmStops
int numHtmStops(ThreadID tid) const
Definition: lsq.hh:978
DefaultIEW::replayMemInst
void replayMemInst(const DynInstPtr &inst)
Re-executes all rescheduled memory instructions.
Definition: iew_impl.hh:553
DefaultIEW::updateLSQNextCycle
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:374
LSQ::insertLoad
void insertLoad(const DynInstPtr &load_inst)
Inserts a load into the LSQ.
Definition: lsq_impl.hh:219
ArmISA::i
Bitfield< 7 > i
Definition: miscregs_types.hh:63
DefaultIEW::activityThisCycle
void activityThisCycle()
Reports to the CPU that there is activity this cycle.
Definition: iew_impl.hh:840
ThreadID
int16_t ThreadID
Thread index/ID type.
Definition: types.hh:233
DefaultIEW::IEWStats::dispLoadInsts
Stats::Scalar dispLoadInsts
Stat for total number of dispatched load instructions.
Definition: iew.hh:444
DefaultIEW::setActiveThreads
void setActiveThreads(std::list< ThreadID > *at_ptr)
Sets pointer to list of active threads.
Definition: iew_impl.hh:330
DefaultIEW::updateExeInstStats
void updateExeInstStats(const DynInstPtr &inst)
Updates execution stats based on the instruction.
Definition: iew_impl.hh:1599
DefaultIEW::setScoreboard
void setScoreboard(Scoreboard *sb_ptr)
Sets pointer to the scoreboard.
Definition: iew_impl.hh:340
DefaultIEW::wroteToTimeBuffer
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:357
DefaultIEW::commitToIEWDelay
Cycles commitToIEWDelay
Commit to IEW delay.
Definition: iew.hh:386
DefaultIEW::IEWStats::ExecutedInstStats::numRefs
Stats::Vector numRefs
Number of executed meomory references.
Definition: iew.hh:479
ProbePointArg< DynInstPtr >
DefaultIEW::renameQueue
TimeBuffer< RenameStruct > * renameQueue
Rename instruction queue interface.
Definition: iew.hh:321
DefaultIEW::isDrained
bool isDrained() const
Has the stage drained?
Definition: iew_impl.hh:347
DefaultIEW::writebackInsts
void writebackInsts()
Writebacks instructions.
Definition: iew_impl.hh:1419
DefaultIEW::name
std::string name() const
Returns the name of the DefaultIEW stage.
Definition: iew_impl.hh:116
DefaultIEW::wakeDependents
void wakeDependents(const DynInstPtr &inst)
Wakes all dependents of a completed instruction.
Definition: iew_impl.hh:539
DTRACE
#define DTRACE(x)
Definition: debug.hh:156
DefaultIEW::skidCount
int skidCount()
Returns the max of the number of entries in all of the skid buffers.
Definition: iew_impl.hh:639
DefaultIEW::toCommit
TimeBuffer< IEWStruct >::wire toCommit
Wire to write infromation heading to commit.
Definition: iew.hh:339
LSQ::violation
bool violation()
Returns whether or not there was a memory ordering violation.
Definition: lsq_impl.hh:274
ProbePointArg::notify
void notify(const Arg &arg)
called at the ProbePoint call site, passes arg to each listener.
Definition: probe.hh:299
TimeBuffer::size
unsigned size
Definition: timebuf.hh:42
FUPool::takeOverFrom
void takeOverFrom()
Takes over from another CPU's thread.
Definition: fu_pool.hh:175
iew.hh
DefaultIEW::squashDueToBranch
void squashDueToBranch(const DynInstPtr &inst, ThreadID tid)
Sends commit proper information for a squash due to a branch mispredict.
Definition: iew_impl.hh:450
DefaultIEW::executeInsts
void executeInsts()
Executes instructions.
Definition: iew_impl.hh:1172
ArmISA::advancePC
void advancePC(PCState &pc, const StaticInstPtr &inst)
Definition: utility.hh:392
DefaultIEW::IEWStats::instsToCommit
Stats::Vector instsToCommit
Number of instructions sent to commit.
Definition: iew.hh:489
DefaultIEW::Inactive
@ Inactive
Definition: iew.hh:101
TimeBuffer< TimeStruct >
LSQ::tick
void tick()
Ticks the LSQ.
Definition: lsq_impl.hh:168
DefaultIEW::blockMemInst
void blockMemInst(const DynInstPtr &inst)
Moves memory instruction onto the list of cache blocked instructions.
Definition: iew_impl.hh:560
DefaultIEW::DynInstPtr
Impl::DynInstPtr DynInstPtr
Definition: iew.hh:83
LSQ::lqFull
bool lqFull()
Returns if any of the LQs are full.
Definition: lsq_impl.hh:542
DefaultIEW::sortInsts
void sortInsts()
Sorts instructions coming from rename into lists separated by thread.
Definition: iew_impl.hh:797
DefaultIEW::IEWStats::wbFanout
Stats::Formula wbFanout
Average number of woken instructions per writeback.
Definition: iew.hh:499
DefaultIEW::toRename
TimeBuffer< TimeStruct >::wire toRename
Wire to write information heading to previous stages.
Definition: iew.hh:318
DefaultIEW::checkMisprediction
void checkMisprediction(const DynInstPtr &inst)
Check misprediction
Definition: iew_impl.hh:1631
DefaultIEW::iewStats
DefaultIEW::IEWStats iewStats
Stats::DataWrap::flags
Derived & flags(Flags _flags)
Set the flags and marks this stat to print at the end of simulation.
Definition: statistics.hh:339
DefaultIEW::clearStates
void clearStates(ThreadID tid)
Clear all thread-specific states.
Definition: iew_impl.hh:279
LSQ::isDrained
bool isDrained() const
Has the LSQ drained?
Definition: lsq_impl.hh:137
DefaultIEW::IEWStats::ExecutedInstStats::numRate
Stats::Formula numRate
Number of instructions executed per cycle.
Definition: iew.hh:485
DefaultIEW::ppMispredict
ProbePointArg< DynInstPtr > * ppMispredict
Probe points.
Definition: iew.hh:125
DefaultIEW::Active
@ Active
Definition: iew.hh:100
timebuf.hh
DefaultIEW::dispatch
void dispatch(ThreadID tid)
Determines proper actions to take given Dispatch's status.
Definition: iew_impl.hh:864
DefaultIEW::block
void block(ThreadID tid)
Sets Dispatch to blocked, and signals back to other stages to block.
Definition: iew_impl.hh:503
DefaultIEW::skidInsert
void skidInsert(ThreadID tid)
Inserts unused instructions of a thread into the skid buffer.
Definition: iew_impl.hh:617
DefaultIEW::fromRename
TimeBuffer< RenameStruct >::wire fromRename
Wire to get rename's output from rename queue.
Definition: iew.hh:324
DefaultIEW::ldstQueue
LSQ ldstQueue
Load / store queue.
Definition: iew.hh:367
LSQ::takeOverFrom
void takeOverFrom()
Takes over execution from another CPU's thread.
Definition: lsq_impl.hh:156
DefaultIEW::IEWStats::dispSquashedInsts
Stats::Scalar dispSquashedInsts
Stat for total number of squashed instructions dispatch skips.
Definition: iew.hh:442
DefaultIEW::deactivateStage
void deactivateStage()
Tells CPU that the IEW stage is inactive and idle.
Definition: iew_impl.hh:856
DefaultIEW::skidsEmpty
bool skidsEmpty()
Returns if all of the skid buffers are empty.
Definition: iew_impl.hh:658
DefaultIEW::skidBufferMax
unsigned skidBufferMax
Maximum size of the skid buffer.
Definition: iew.hh:424
DefaultIEW::IEWStats::executedInstStats
DefaultIEW::IEWStats::ExecutedInstStats executedInstStats
LSQ::drainSanityCheck
void drainSanityCheck() const
Perform sanity checks after a drain.
Definition: lsq_impl.hh:127
DefaultIEW::squashDueToMemOrder
void squashDueToMemOrder(const DynInstPtr &inst, ThreadID tid)
Sends commit proper information for a squash due to a memory order violation.
Definition: iew_impl.hh:476
DefaultIEW::ppExecute
ProbePointArg< DynInstPtr > * ppExecute
To probe when instruction execution begins.
Definition: iew.hh:128
DefaultIEW::IEWStats::predictedTakenIncorrect
Stats::Scalar predictedTakenIncorrect
Stat for total number of incorrect predicted taken branches.
Definition: iew.hh:456
DefaultIEW::Running
@ Running
Definition: iew.hh:106
DefaultIEW::IEWStats::writebackCount
Stats::Vector writebackCount
Number of instructions that writeback.
Definition: iew.hh:491
DefaultIEW::IEWStats::unblockCycles
Stats::Scalar unblockCycles
Stat for total number of unblocking cycles.
Definition: iew.hh:438
FUPool::isDrained
bool isDrained() const
Have all the FUs drained?
Definition: fu_pool.cc:238
DefaultIEW::dispatchStatus
StageStatus dispatchStatus[Impl::MaxThreads]
Dispatch status.
Definition: iew.hh:118
DefaultIEW::drainSanityCheck
void drainSanityCheck() const
Perform sanity checks after a drain.
Definition: iew_impl.hh:376
DPRINTF
#define DPRINTF(x,...)
Definition: trace.hh:237
ADD_STAT
#define ADD_STAT(n,...)
Convenience macro to add a stat to a statistics group.
Definition: group.hh:71
DefaultIEW::issueWidth
unsigned issueWidth
Width of issue, in instructions.
Definition: iew.hh:402
DefaultIEW::fetchRedirect
bool fetchRedirect[Impl::MaxThreads]
Records if there is a fetch redirect on this cycle for each thread.
Definition: iew.hh:378
DefaultIEW::exeStatus
StageStatus exeStatus
Execute status.
Definition: iew.hh:120
Fault
std::shared_ptr< FaultBase > Fault
Definition: types.hh:246
DefaultIEW::O3CPU
Impl::O3CPU O3CPU
Definition: iew.hh:84
MipsISA::pc
Bitfield< 4 > pc
Definition: pra_constants.hh:240
DefaultIEW::regProbePoints
void regProbePoints()
Registers probes.
Definition: iew_impl.hh:123
cpu.hh
LSQ::numFreeStoreEntries
unsigned numFreeStoreEntries()
Returns the number of free store entries.
Definition: lsq_impl.hh:440
LSQ::executeLoad
Fault executeLoad(const DynInstPtr &inst)
Executes a load.
Definition: lsq_impl.hh:237
DefaultIEW::updateStatus
void updateStatus()
Updates overall IEW status based on all of the stages' statuses.
Definition: iew_impl.hh:675
DefaultIEW::setIEWQueue
void setIEWQueue(TimeBuffer< IEWStruct > *iq_ptr)
Sets time buffer to pass on instructions to commit.
Definition: iew_impl.hh:320
DefaultIEW::fuPool
FUPool * fuPool
Pointer to the functional unit pool.
Definition: iew.hh:370
LSQ::getDataPort
RequestPort & getDataPort()
Definition: lsq.hh:1126
DefaultIEW::setRenameQueue
void setRenameQueue(TimeBuffer< RenameStruct > *rq_ptr)
Sets time buffer for getting instructions coming from rename.
Definition: iew_impl.hh:310
DefaultIEW::renameToIEWDelay
Cycles renameToIEWDelay
Rename to IEW delay.
Definition: iew.hh:389
DefaultIEW::IEWStats::dispStoreInsts
Stats::Scalar dispStoreInsts
Stat for total number of dispatched store instructions.
Definition: iew.hh:446
DefaultIEW::setTimeBuffer
void setTimeBuffer(TimeBuffer< TimeStruct > *tb_ptr)
Sets main time buffer used for backwards communication.
Definition: iew_impl.hh:292
DefaultIEW::IEWStats::dispatchedInsts
Stats::Scalar dispatchedInsts
Stat for total number of instructions dispatched.
Definition: iew.hh:440
DefaultIEW::startupStage
void startupStage()
Initializes stage; sends back the number of free IQ and LSQ entries.
Definition: iew_impl.hh:257
DefaultIEW::scoreboard
Scoreboard * scoreboard
Scoreboard pointer.
Definition: iew.hh:348
fu_pool.hh
LSQ::getLatestHtmUid
uint64_t getLatestHtmUid(ThreadID tid) const
Definition: lsq.hh:992
LSQ::getCount
int getCount()
Returns the number of instructions in all of the queues.
Definition: lsq_impl.hh:368
UNIT_COUNT
#define UNIT_COUNT
Definition: units.hh:49
NoFault
constexpr decltype(nullptr) NoFault
Definition: types.hh:251
LSQ::writebackStores
void writebackStores()
Attempts to write back stores until all cache ports are used or the interface becomes blocked.
Definition: lsq_impl.hh:255
DefaultIEW::rescheduleMemInst
void rescheduleMemInst(const DynInstPtr &inst)
Tells memory dependence unit that a memory instruction needs to be rescheduled.
Definition: iew_impl.hh:546
DefaultIEW::printAvailableInsts
void printAvailableInsts()
Debug function to print instructions that are issued this cycle.
Definition: iew_impl.hh:1149
Stats::VectorBase::init
Derived & init(size_type size)
Set this vector to have the given size.
Definition: statistics.hh:1028
DefaultIEW::cpu
O3CPU * cpu
CPU pointer.
Definition: iew.hh:352
DefaultIEW::updatedQueues
bool updatedQueues
Records if the queues have been changed (inserted or issued insts), so that IEW knows to broadcast th...
Definition: iew.hh:383
DefaultIEW::IEWStats::memOrderViolationEvents
Stats::Scalar memOrderViolationEvents
Stat for total number of memory ordering violation events.
Definition: iew.hh:454
LSQ::numFreeLoadEntries
unsigned numFreeLoadEntries()
Returns the number of free load entries.
Definition: lsq_impl.hh:422
DefaultIEW::DefaultIEW
DefaultIEW(O3CPU *_cpu, const DerivO3CPUParams &params)
Constructs a DefaultIEW with the given parameters.
Definition: iew_impl.hh:64
DefaultIEW::unblock
void unblock(ThreadID tid)
Unblocks Dispatch if the skid buffer is empty, and signals back to other stages to unblock.
Definition: iew_impl.hh:522
DefaultIEW::squash
void squash(ThreadID tid)
Squashes instructions in IEW for a specific thread.
Definition: iew_impl.hh:414
DefaultIEW::insts
std::queue< DynInstPtr > insts[Impl::MaxThreads]
Queue of all instructions coming from rename this cycle.
Definition: iew.hh:342
UNIT_RATE
#define UNIT_RATE(T1, T2)
Definition: units.hh:47
DefaultIEW::Squashing
@ Squashing
Definition: iew.hh:110
DefaultIEW::checkStall
bool checkStall(ThreadID tid)
Checks if any of the stall conditions are currently true.
Definition: iew_impl.hh:716
LSQ::setActiveThreads
void setActiveThreads(std::list< ThreadID > *at_ptr)
Sets the pointer to the list of active threads.
Definition: lsq_impl.hh:119
DefaultIEW::IEWStats::lsqFullEvents
Stats::Scalar lsqFullEvents
Stat for number of times the LSQ becomes full.
Definition: iew.hh:452
DefaultIEW::IEWStats::IEWStats
IEWStats(O3CPU *cpu)
Definition: iew_impl.hh:143
DefaultIEW::wbNumInst
unsigned wbNumInst
Index into queue of instructions being written back.
Definition: iew.hh:405
DefaultIEW::IEWStats::predictedNotTakenIncorrect
Stats::Scalar predictedNotTakenIncorrect
Stat for total number of incorrect predicted not taken branches.
Definition: iew.hh:458
DefaultIEW::activeThreads
std::list< ThreadID > * activeThreads
Pointer to list of active threads.
Definition: iew.hh:421
DefaultIEW::numThreads
ThreadID numThreads
Number of active threads.
Definition: iew.hh:418
DefaultIEW::dispatchWidth
unsigned dispatchWidth
Width of dispatch, in instructions.
Definition: iew.hh:399
DefaultIEW::IEWStats::wbRate
Stats::Formula wbRate
Number of instructions per cycle written back.
Definition: iew.hh:497
DefaultIEW::toFetch
TimeBuffer< TimeStruct >::wire toFetch
Wire to write information heading to previous stages.
Definition: iew.hh:312
DefaultIEW::IEWStats::consumerInst
Stats::Vector consumerInst
Number of instructions that wake up from producers.
Definition: iew.hh:495
DefaultIEW::issueToExecuteDelay
Cycles issueToExecuteDelay
Issue to execute delay.
Definition: iew.hh:396
FUPool::processFreeUnits
void processFreeUnits()
Frees all FUs on the list.
Definition: fu_pool.cc:191
MipsISA::PCState
GenericISA::DelaySlotPCState< MachInst > PCState
Definition: types.hh:41
DefaultIEW::timeBuffer
TimeBuffer< TimeStruct > * timeBuffer
Pointer to main time buffer used for backwards communication.
Definition: iew.hh:309
DefaultIEW::validInstsFromRename
unsigned validInstsFromRename()
Returns the number of valid, non-squashed instructions coming from rename to dispatch.
Definition: iew_impl.hh:603
DefaultIEW::IEWStats::producerInst
Stats::Vector producerInst
Number of instructions that wake consumers.
Definition: iew.hh:493
DefaultIEW::iewQueue
TimeBuffer< IEWStruct > * iewQueue
IEW stage time buffer.
Definition: iew.hh:336
DefaultIEW::Idle
@ Idle
Definition: iew.hh:108
DefaultIEW::IEWStats::ExecutedInstStats::numInsts
Stats::Scalar numInsts
Stat for total number of executed instructions.
Definition: iew.hh:468
LSQ::squash
void squash(const InstSeqNum &squashed_num, ThreadID tid)
Squash instructions from a thread until the specified sequence number.
Definition: lsq.hh:913
DefaultIEW::ppToCommit
ProbePointArg< DynInstPtr > * ppToCommit
To probe when instruction execution is complete.
Definition: iew.hh:130
UNIT_CYCLE
#define UNIT_CYCLE
Convenience macros to declare the unit of a stat.
Definition: units.hh:39
DefaultIEW::IEWStats::iqFullEvents
Stats::Scalar iqFullEvents
Stat for number of times the IQ becomes full.
Definition: iew.hh:450
LSQ::sqFull
bool sqFull()
Returns if any of the SQs are full.
Definition: lsq_impl.hh:571
DefaultIEW::IEWStats::ExecutedInstStats::numSquashedInsts
Stats::Scalar numSquashedInsts
Stat for total number of squashed instructions skipped at execute.
Definition: iew.hh:473
Stats
Definition: statistics.cc:53
curTick
Tick curTick()
The universal simulation clock.
Definition: cur_tick.hh:43
DefaultIEW::instQueue
IQ instQueue
Instruction queue.
Definition: iew.hh:364
LSQ::getMemDepViolator
DynInstPtr getMemDepViolator(ThreadID tid)
Gets the instruction that caused the memory ordering violation.
Definition: lsq.hh:928
TimeBuffer::getSize
unsigned getSize()
Definition: timebuf.hh:241
DefaultIEW::wbStatus
StageStatus wbStatus
Writeback status.
Definition: iew.hh:122
DefaultIEW::instToCommit
void instToCommit(const DynInstPtr &inst)
Sends an instruction to commit through the time buffer.
Definition: iew_impl.hh:574
TimeBuffer::advance
void advance()
Definition: timebuf.hh:176
std::list< ThreadID >
DefaultIEW::activateStage
void activateStage()
Tells CPU that the IEW stage is active and running.
Definition: iew_impl.hh:848
LSQ::commitLoads
void commitLoads(InstSeqNum &youngest_inst, ThreadID tid)
Commits loads up until the given sequence number for a specific thread.
Definition: lsq.hh:892
DefaultIEW::IEWStats::ExecutedInstStats::numSwp
Stats::Vector numSwp
Number of executed software prefetches.
Definition: iew.hh:475
Stats::total
const FlagsType total
Print the total.
Definition: info.hh:50
DefaultIEW::dispatchInsts
void dispatchInsts(ThreadID tid)
Dispatches instructions to IQ and LSQ.
Definition: iew_impl.hh:912
DefaultIEW::skidBuffer
std::queue< DynInstPtr > skidBuffer[Impl::MaxThreads]
Skid buffer between rename and IEW.
Definition: iew.hh:345
DefaultIEW::ppDispatch
ProbePointArg< DynInstPtr > * ppDispatch
Definition: iew.hh:126
DefaultIEW::_status
Status _status
Overall stage status.
Definition: iew.hh:116
LSQ::numHtmStarts
int numHtmStarts(ThreadID tid) const
Definition: lsq.hh:971
DefaultIEW::cacheUnblocked
void cacheUnblocked()
Notifies that the cache has become unblocked.
Definition: iew_impl.hh:567
DefaultIEW::fromCommit
TimeBuffer< TimeStruct >::wire fromCommit
Wire to get commit's output from backwards time buffer.
Definition: iew.hh:315
DefaultIEW::IEWStats::ExecutedInstStats::ExecutedInstStats
ExecutedInstStats(O3CPU *cpu)
Definition: iew_impl.hh:213
DefaultIEW::fromIssue
TimeBuffer< IssueStruct >::wire fromIssue
Wire to read information from the issue stage time queue.
Definition: iew.hh:330
DefaultIEW::Unblocking
@ Unblocking
Definition: iew.hh:111
DefaultIEW::IEWStats::ExecutedInstStats::numBranches
Stats::Vector numBranches
Number of executed branches.
Definition: iew.hh:481
Scoreboard
Implements a simple scoreboard to track which registers are ready.
Definition: scoreboard.hh:46
DefaultIEW::tick
void tick()
Ticks IEW stage, causing Dispatch, the IQ, the LSQ, Execute, and Writeback to run for one cycle.
Definition: iew_impl.hh:1469
DefaultIEW::Blocked
@ Blocked
Definition: iew.hh:107
panic
#define panic(...)
This implements a cprintf based panic() function.
Definition: logging.hh:171
TimeBuffer::getWire
wire getWire(int idx)
Definition: timebuf.hh:229
DefaultIEW::IEWStats::dispNonSpecInsts
Stats::Scalar dispNonSpecInsts
Stat for total number of dispatched non speculative instructions.
Definition: iew.hh:448

Generated on Tue Jun 22 2021 15:28:26 for gem5 by doxygen 1.8.17