gem5
v20.0.0.0
|
A standard instruction queue class. More...
#include <inst_queue.hh>
Classes | |
class | FUCompletion |
FU completion event class. More... | |
struct | ListOrderEntry |
Entry for the list age ordering by op class. More... | |
struct | pqCompare |
Struct for comparing entries to be added to the priority queue. More... | |
Public Types | |
typedef Impl::O3CPU | O3CPU |
typedef Impl::DynInstPtr | DynInstPtr |
typedef Impl::CPUPol::IEW | IEW |
typedef Impl::CPUPol::MemDepUnit | MemDepUnit |
typedef Impl::CPUPol::IssueStruct | IssueStruct |
typedef Impl::CPUPol::TimeStruct | TimeStruct |
typedef std::list< DynInstPtr >::iterator | ListIt |
Public Member Functions | |
InstructionQueue (O3CPU *cpu_ptr, IEW *iew_ptr, DerivO3CPUParams *params) | |
Constructs an IQ. More... | |
~InstructionQueue () | |
Destructs the IQ. More... | |
std::string | name () const |
Returns the name of the IQ. More... | |
void | regStats () |
Registers statistics. More... | |
void | resetState () |
Resets all instruction queue state. More... | |
void | setActiveThreads (std::list< ThreadID > *at_ptr) |
Sets active threads list. More... | |
void | setIssueToExecuteQueue (TimeBuffer< IssueStruct > *i2eQueue) |
Sets the timer buffer between issue and execute. More... | |
void | setTimeBuffer (TimeBuffer< TimeStruct > *tb_ptr) |
Sets the global time buffer. More... | |
bool | isDrained () const |
Determine if we are drained. More... | |
void | drainSanityCheck () const |
Perform sanity checks after a drain. More... | |
void | takeOverFrom () |
Takes over execution from another CPU's thread. More... | |
int | entryAmount (ThreadID num_threads) |
Number of entries needed for given amount of threads. More... | |
void | resetEntries () |
Resets max entries for all threads. More... | |
unsigned | numFreeEntries () |
Returns total number of free entries. More... | |
unsigned | numFreeEntries (ThreadID tid) |
Returns number of free entries for a thread. More... | |
bool | isFull () |
Returns whether or not the IQ is full. More... | |
bool | isFull (ThreadID tid) |
Returns whether or not the IQ is full for a specific thread. More... | |
bool | hasReadyInsts () |
Returns if there are any ready instructions in the IQ. More... | |
void | insert (const DynInstPtr &new_inst) |
Inserts a new instruction into the IQ. More... | |
void | insertNonSpec (const DynInstPtr &new_inst) |
Inserts a new, non-speculative instruction into the IQ. More... | |
void | insertBarrier (const DynInstPtr &barr_inst) |
Inserts a memory or write barrier into the IQ to make sure loads and stores are ordered properly. More... | |
DynInstPtr | getInstToExecute () |
Returns the oldest scheduled instruction, and removes it from the list of instructions waiting to execute. More... | |
DynInstPtr | getDeferredMemInstToExecute () |
Gets a memory instruction that was referred due to a delayed DTB translation if it is now ready to execute. More... | |
DynInstPtr | getBlockedMemInstToExecute () |
Gets a memory instruction that was blocked on the cache. More... | |
void | recordProducer (const DynInstPtr &inst) |
Records the instruction as the producer of a register without adding it to the rest of the IQ. More... | |
void | processFUCompletion (const DynInstPtr &inst, int fu_idx) |
Process FU completion event. More... | |
void | scheduleReadyInsts () |
Schedules ready instructions, adding the ready ones (oldest first) to the queue to execute. More... | |
void | scheduleNonSpec (const InstSeqNum &inst) |
Schedules a single specific non-speculative instruction. More... | |
void | commit (const InstSeqNum &inst, ThreadID tid=0) |
Commits all instructions up to and including the given sequence number, for a specific thread. More... | |
int | wakeDependents (const DynInstPtr &completed_inst) |
Wakes all dependents of a completed instruction. More... | |
void | addReadyMemInst (const DynInstPtr &ready_inst) |
Adds a ready memory instruction to the ready list. More... | |
void | rescheduleMemInst (const DynInstPtr &resched_inst) |
Reschedules a memory instruction. More... | |
void | replayMemInst (const DynInstPtr &replay_inst) |
Replays a memory instruction. More... | |
void | completeMemInst (const DynInstPtr &completed_inst) |
Completes a memory operation. More... | |
void | deferMemInst (const DynInstPtr &deferred_inst) |
Defers a memory instruction when its DTB translation incurs a hw page table walk. More... | |
void | blockMemInst (const DynInstPtr &blocked_inst) |
Defers a memory instruction when it is cache blocked. More... | |
void | cacheUnblocked () |
Notify instruction queue that a previous blockage has resolved. More... | |
void | violation (const DynInstPtr &store, const DynInstPtr &faulting_load) |
Indicates an ordering violation between a store and a load. More... | |
void | squash (ThreadID tid) |
Squashes instructions for a thread. More... | |
unsigned | getCount (ThreadID tid) |
Returns the number of used entries for a thread. More... | |
void | printInsts () |
Debug function to print all instructions. More... | |
Private Types | |
typedef std::priority_queue< DynInstPtr, std::vector< DynInstPtr >, pqCompare > | ReadyInstQueue |
typedef std::map< InstSeqNum, DynInstPtr >::iterator | NonSpecMapIt |
typedef std::list< ListOrderEntry >::iterator | ListOrderIt |
Private Member Functions | |
void | doSquash (ThreadID tid) |
Does the actual squashing. More... | |
void | addToOrderList (OpClass op_class) |
Add an op class to the age order list. More... | |
void | moveToYoungerInst (ListOrderIt age_order_it) |
Called when the oldest instruction has been removed from a ready queue; this places that ready queue into the proper spot in the age order list. More... | |
bool | addToDependents (const DynInstPtr &new_inst) |
Adds an instruction to the dependency graph, as a consumer. More... | |
void | addToProducers (const DynInstPtr &new_inst) |
Adds an instruction to the dependency graph, as a producer. More... | |
void | addIfReady (const DynInstPtr &inst) |
Moves an instruction to the ready queue if it is ready. More... | |
int | countInsts () |
Debugging function to count how many entries are in the IQ. More... | |
void | dumpLists () |
Debugging function to dump all the list sizes, as well as print out the list of nonspeculative instructions. More... | |
void | dumpInsts () |
Debugging function to dump out all instructions that are in the IQ. More... | |
Private Attributes | |
O3CPU * | cpu |
Pointer to the CPU. More... | |
MemInterface * | dcacheInterface |
Cache interface. More... | |
IEW * | iewStage |
Pointer to IEW stage. More... | |
MemDepUnit | memDepUnit [Impl::MaxThreads] |
The memory dependence unit, which tracks/predicts memory dependences between instructions. More... | |
TimeBuffer< IssueStruct > * | issueToExecuteQueue |
The queue to the execute stage. More... | |
TimeBuffer< TimeStruct > * | timeBuffer |
The backwards time buffer. More... | |
TimeBuffer< TimeStruct >::wire | fromCommit |
Wire to read information from timebuffer. More... | |
FUPool * | fuPool |
Function unit pool. More... | |
std::list< DynInstPtr > | instList [Impl::MaxThreads] |
List of all the instructions in the IQ (some of which may be issued). More... | |
std::list< DynInstPtr > | instsToExecute |
List of instructions that are ready to be executed. More... | |
std::list< DynInstPtr > | deferredMemInsts |
List of instructions waiting for their DTB translation to complete (hw page table walk in progress). More... | |
std::list< DynInstPtr > | blockedMemInsts |
List of instructions that have been cache blocked. More... | |
std::list< DynInstPtr > | retryMemInsts |
List of instructions that were cache blocked, but a retry has been seen since, so they can now be retried. More... | |
ReadyInstQueue | readyInsts [Num_OpClasses] |
List of ready instructions, per op class. More... | |
std::map< InstSeqNum, DynInstPtr > | nonSpecInsts |
List of non-speculative instructions that will be scheduled once the IQ gets a signal from commit. More... | |
std::list< ListOrderEntry > | listOrder |
List that contains the age order of the oldest instruction of each ready queue. More... | |
bool | queueOnList [Num_OpClasses] |
Tracks if each ready queue is on the age order list. More... | |
ListOrderIt | readyIt [Num_OpClasses] |
Iterators of each ready queue. More... | |
DependencyGraph< DynInstPtr > | dependGraph |
SMTQueuePolicy | iqPolicy |
IQ sharing policy for SMT. More... | |
ThreadID | numThreads |
Number of Total Threads. More... | |
std::list< ThreadID > * | activeThreads |
Pointer to list of active threads. More... | |
unsigned | count [Impl::MaxThreads] |
Per Thread IQ count. More... | |
unsigned | maxEntries [Impl::MaxThreads] |
Max IQ Entries Per Thread. More... | |
unsigned | freeEntries |
Number of free IQ entries left. More... | |
unsigned | numEntries |
The number of entries in the instruction queue. More... | |
unsigned | totalWidth |
The total number of instructions that can be issued in one cycle. More... | |
unsigned | numPhysRegs |
The number of physical registers in the CPU. More... | |
int | wbOutstanding |
Number of instructions currently in flight to FUs. More... | |
Cycles | commitToIEWDelay |
Delay between commit stage and the IQ. More... | |
InstSeqNum | squashedSeqNum [Impl::MaxThreads] |
The sequence number of the squashed instruction. More... | |
std::vector< bool > | regScoreboard |
A cache of the recently woken registers. More... | |
Stats::Scalar | iqInstsAdded |
Stat for number of instructions added. More... | |
Stats::Scalar | iqNonSpecInstsAdded |
Stat for number of non-speculative instructions added. More... | |
Stats::Scalar | iqInstsIssued |
Stats::Scalar | iqIntInstsIssued |
Stat for number of integer instructions issued. More... | |
Stats::Scalar | iqFloatInstsIssued |
Stat for number of floating point instructions issued. More... | |
Stats::Scalar | iqBranchInstsIssued |
Stat for number of branch instructions issued. More... | |
Stats::Scalar | iqMemInstsIssued |
Stat for number of memory instructions issued. More... | |
Stats::Scalar | iqMiscInstsIssued |
Stat for number of miscellaneous instructions issued. More... | |
Stats::Scalar | iqSquashedInstsIssued |
Stat for number of squashed instructions that were ready to issue. More... | |
Stats::Scalar | iqSquashedInstsExamined |
Stat for number of squashed instructions examined when squashing. More... | |
Stats::Scalar | iqSquashedOperandsExamined |
Stat for number of squashed instruction operands examined when squashing. More... | |
Stats::Scalar | iqSquashedNonSpecRemoved |
Stat for number of non-speculative instructions removed due to a squash. More... | |
Stats::Distribution | numIssuedDist |
Distribution of number of instructions in the queue. More... | |
Stats::Vector | statFuBusy |
Distribution of the cycles it takes to issue an instruction. More... | |
Stats::Vector2d | statIssuedInstType |
Stat for total number issued for each instruction type. More... | |
Stats::Formula | issueRate |
Number of instructions issued per cycle. More... | |
Stats::Vector | fuBusy |
Number of times the FU was busy. More... | |
Stats::Formula | fuBusyRate |
Number of times the FU was busy per instruction issued. More... | |
A standard instruction queue class.
It holds ready instructions, in order, in seperate priority queues to facilitate the scheduling of instructions. The IQ uses a separate linked list to track dependencies. Similar to the rename map and the free list, it expects that floating point registers have their indices start after the integer registers (ie with 96 int and 96 fp registers, regs 0-95 are integer and 96-191 are fp). This remains true even for both logical and physical register indices. The IQ depends on the memory dependence unit to track when memory operations are ready in terms of ordering; register dependencies are tracked normally. Right now the IQ also handles the execution timing; this is mainly to allow back-to-back scheduling without requiring IEW to be able to peek into the IQ. At the end of the execution latency, the instruction is put into the queue to execute, where it will have the execute() function called on it.
Definition at line 81 of file inst_queue.hh.
typedef Impl::DynInstPtr InstructionQueue< Impl >::DynInstPtr |
Definition at line 86 of file inst_queue.hh.
typedef Impl::CPUPol::IEW InstructionQueue< Impl >::IEW |
Definition at line 88 of file inst_queue.hh.
typedef Impl::CPUPol::IssueStruct InstructionQueue< Impl >::IssueStruct |
Definition at line 90 of file inst_queue.hh.
typedef std::list<DynInstPtr>::iterator InstructionQueue< Impl >::ListIt |
Definition at line 94 of file inst_queue.hh.
|
private |
Definition at line 380 of file inst_queue.hh.
typedef Impl::CPUPol::MemDepUnit InstructionQueue< Impl >::MemDepUnit |
Definition at line 89 of file inst_queue.hh.
|
private |
Definition at line 363 of file inst_queue.hh.
typedef Impl::O3CPU InstructionQueue< Impl >::O3CPU |
Definition at line 85 of file inst_queue.hh.
|
private |
Definition at line 347 of file inst_queue.hh.
typedef Impl::CPUPol::TimeStruct InstructionQueue< Impl >::TimeStruct |
Definition at line 91 of file inst_queue.hh.
InstructionQueue< Impl >::InstructionQueue | ( | O3CPU * | cpu_ptr, |
IEW * | iew_ptr, | ||
DerivO3CPUParams * | params | ||
) |
Constructs an IQ.
Definition at line 85 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::dependGraph, DPRINTF, InstructionQueue< Impl >::fuPool, MemDepUnit< MemDepPred, Impl >::init(), InstructionQueue< Impl >::iqPolicy, InstructionQueue< Impl >::maxEntries, InstructionQueue< Impl >::memDepUnit, InstructionQueue< Impl >::numEntries, InstructionQueue< Impl >::numPhysRegs, InstructionQueue< Impl >::numThreads, ArmISA::NumVecElemPerVecReg, InstructionQueue< Impl >::regScoreboard, InstructionQueue< Impl >::resetState(), and MemDepUnit< MemDepPred, Impl >::setIQ().
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
InstructionQueue< Impl >::~InstructionQueue | ( | ) |
Destructs the IQ.
Definition at line 159 of file inst_queue_impl.hh.
References cprintf(), and InstructionQueue< Impl >::dependGraph.
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
|
private |
Moves an instruction to the ready queue if it is ready.
Definition at line 1449 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::addToOrderList(), DPRINTF, InstructionQueue< Impl >::listOrder, InstructionQueue< Impl >::memDepUnit, InstructionQueue< Impl >::queueOnList, InstructionQueue< Impl >::readyInsts, InstructionQueue< Impl >::readyIt, and MemDepUnit< MemDepPred, Impl >::regsReady().
Referenced by InstructionQueue< Impl >::insert(), InstructionQueue< Impl >::scheduleNonSpec(), and InstructionQueue< Impl >::wakeDependents().
void InstructionQueue< Impl >::addReadyMemInst | ( | const DynInstPtr & | ready_inst | ) |
Adds a ready memory instruction to the ready list.
Definition at line 1082 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::addToOrderList(), DPRINTF, InstructionQueue< Impl >::listOrder, InstructionQueue< Impl >::queueOnList, InstructionQueue< Impl >::readyInsts, and InstructionQueue< Impl >::readyIt.
Referenced by InstructionQueue< Impl >::recordProducer(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
Adds an instruction to the dependency graph, as a consumer.
Definition at line 1365 of file inst_queue_impl.hh.
References RegId::className(), InstructionQueue< Impl >::dependGraph, DPRINTF, PhysRegId::flatIndex(), RegId::index(), PhysRegId::isFixedMapping(), and InstructionQueue< Impl >::regScoreboard.
Referenced by InstructionQueue< Impl >::insert().
|
private |
Add an op class to the age order list.
Definition at line 696 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::listOrder, InstructionQueue< Impl >::ListOrderEntry::oldestInst, InstructionQueue< Impl >::queueOnList, InstructionQueue< Impl >::ListOrderEntry::queueType, InstructionQueue< Impl >::readyInsts, and InstructionQueue< Impl >::readyIt.
Referenced by InstructionQueue< Impl >::addIfReady(), and InstructionQueue< Impl >::addReadyMemInst().
|
private |
Adds an instruction to the dependency graph, as a producer.
Definition at line 1413 of file inst_queue_impl.hh.
References RegId::className(), InstructionQueue< Impl >::dependGraph, PhysRegId::flatIndex(), RegId::index(), PhysRegId::isFixedMapping(), panic, and InstructionQueue< Impl >::regScoreboard.
Referenced by InstructionQueue< Impl >::insert(), InstructionQueue< Impl >::insertNonSpec(), and InstructionQueue< Impl >::recordProducer().
void InstructionQueue< Impl >::blockMemInst | ( | const DynInstPtr & | blocked_inst | ) |
Defers a memory instruction when it is cache blocked.
Definition at line 1150 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::blockedMemInsts.
Referenced by InstructionQueue< Impl >::recordProducer().
void InstructionQueue< Impl >::cacheUnblocked | ( | ) |
Notify instruction queue that a previous blockage has resolved.
Definition at line 1159 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::blockedMemInsts, InstructionQueue< Impl >::cpu, and InstructionQueue< Impl >::retryMemInsts.
Referenced by InstructionQueue< Impl >::recordProducer().
void InstructionQueue< Impl >::commit | ( | const InstSeqNum & | inst, |
ThreadID | tid = 0 |
||
) |
Commits all instructions up to and including the given sequence number, for a specific thread.
Definition at line 969 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::countInsts(), DPRINTF, InstructionQueue< Impl >::freeEntries, InstructionQueue< Impl >::instList, and InstructionQueue< Impl >::numEntries.
Referenced by InstructionQueue< Impl >::recordProducer().
void InstructionQueue< Impl >::completeMemInst | ( | const DynInstPtr & | completed_inst | ) |
Completes a memory operation.
Definition at line 1126 of file inst_queue_impl.hh.
References MemDepUnit< MemDepPred, Impl >::completed(), InstructionQueue< Impl >::count, DPRINTF, InstructionQueue< Impl >::freeEntries, and InstructionQueue< Impl >::memDepUnit.
Referenced by InstructionQueue< Impl >::recordProducer(), and InstructionQueue< Impl >::wakeDependents().
|
private |
Debugging function to count how many entries are in the IQ.
It does a linear walk through the instructions, so do not call this function during normal execution.
Definition at line 1489 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::freeEntries, and InstructionQueue< Impl >::numEntries.
Referenced by InstructionQueue< Impl >::commit(), InstructionQueue< Impl >::insert(), and InstructionQueue< Impl >::insertNonSpec().
void InstructionQueue< Impl >::deferMemInst | ( | const DynInstPtr & | deferred_inst | ) |
Defers a memory instruction when its DTB translation incurs a hw page table walk.
Definition at line 1143 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::deferredMemInsts.
Referenced by InstructionQueue< Impl >::recordProducer().
|
private |
Does the actual squashing.
Definition at line 1222 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::count, InstructionQueue< Impl >::dependGraph, DPRINTF, PhysRegId::flatIndex(), InstructionQueue< Impl >::fpInstQueueWrites, InstructionQueue< Impl >::freeEntries, InstructionQueue< Impl >::instList, InstructionQueue< Impl >::intInstQueueWrites, InstructionQueue< Impl >::iqSquashedInstsExamined, InstructionQueue< Impl >::iqSquashedNonSpecRemoved, InstructionQueue< Impl >::iqSquashedOperandsExamined, PhysRegId::isFixedMapping(), NoFault, InstructionQueue< Impl >::nonSpecInsts, InstructionQueue< Impl >::squashedSeqNum, and InstructionQueue< Impl >::vecInstQueueWrites.
Referenced by InstructionQueue< Impl >::getCount(), and InstructionQueue< Impl >::squash().
void InstructionQueue< Impl >::drainSanityCheck | ( | ) | const |
Perform sanity checks after a drain.
Definition at line 470 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::dependGraph, InstructionQueue< Impl >::instsToExecute, InstructionQueue< Impl >::memDepUnit, and InstructionQueue< Impl >::numThreads.
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
|
private |
Debugging function to dump out all instructions that are in the IQ.
Definition at line 1539 of file inst_queue_impl.hh.
References cprintf(), InstructionQueue< Impl >::instList, InstructionQueue< Impl >::instsToExecute, and InstructionQueue< Impl >::numThreads.
|
private |
Debugging function to dump all the list sizes, as well as print out the list of nonspeculative instructions.
Should not be used in any other capacity, but it has no harmful sideaffects.
Definition at line 1496 of file inst_queue_impl.hh.
References cprintf(), ArmISA::i, InstructionQueue< Impl >::listOrder, InstructionQueue< Impl >::nonSpecInsts, Num_OpClasses, and InstructionQueue< Impl >::readyInsts.
int InstructionQueue< Impl >::entryAmount | ( | ThreadID | num_threads | ) |
Number of entries needed for given amount of threads.
Definition at line 487 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::iqPolicy, and InstructionQueue< Impl >::numEntries.
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
Impl::DynInstPtr InstructionQueue< Impl >::getBlockedMemInstToExecute | ( | ) |
Gets a memory instruction that was blocked on the cache.
NULL if none available.
Definition at line 1183 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::retryMemInsts.
Referenced by InstructionQueue< Impl >::scheduleReadyInsts(), and InstructionQueue< Impl >::FUCompletion::setFreeFU().
|
inline |
Returns the number of used entries for a thread.
Definition at line 268 of file inst_queue.hh.
References InstructionQueue< Impl >::count, InstructionQueue< Impl >::doSquash(), and InstructionQueue< Impl >::printInsts().
Impl::DynInstPtr InstructionQueue< Impl >::getDeferredMemInstToExecute | ( | ) |
Gets a memory instruction that was referred due to a delayed DTB translation if it is now ready to execute.
NULL if none available.
Definition at line 1168 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::deferredMemInsts.
Referenced by InstructionQueue< Impl >::scheduleReadyInsts(), and InstructionQueue< Impl >::FUCompletion::setFreeFU().
Impl::DynInstPtr InstructionQueue< Impl >::getInstToExecute | ( | ) |
Returns the oldest scheduled instruction, and removes it from the list of instructions waiting to execute.
Definition at line 679 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::fpInstQueueReads, InstructionQueue< Impl >::instsToExecute, InstructionQueue< Impl >::intInstQueueReads, and InstructionQueue< Impl >::vecInstQueueReads.
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
bool InstructionQueue< Impl >::hasReadyInsts | ( | ) |
Returns if there are any ready instructions in the IQ.
Definition at line 560 of file inst_queue_impl.hh.
References ArmISA::i, InstructionQueue< Impl >::listOrder, Num_OpClasses, and InstructionQueue< Impl >::readyInsts.
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
void InstructionQueue< Impl >::insert | ( | const DynInstPtr & | new_inst | ) |
Inserts a new instruction into the IQ.
Definition at line 577 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::addIfReady(), InstructionQueue< Impl >::addToDependents(), InstructionQueue< Impl >::addToProducers(), InstructionQueue< Impl >::count, InstructionQueue< Impl >::countInsts(), DPRINTF, InstructionQueue< Impl >::fpInstQueueWrites, InstructionQueue< Impl >::freeEntries, MemDepUnit< MemDepPred, Impl >::insert(), InstructionQueue< Impl >::instList, InstructionQueue< Impl >::intInstQueueWrites, InstructionQueue< Impl >::iqInstsAdded, InstructionQueue< Impl >::memDepUnit, InstructionQueue< Impl >::numEntries, and InstructionQueue< Impl >::vecInstQueueWrites.
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
void InstructionQueue< Impl >::insertBarrier | ( | const DynInstPtr & | barr_inst | ) |
Inserts a memory or write barrier into the IQ to make sure loads and stores are ordered properly.
Definition at line 670 of file inst_queue_impl.hh.
References MemDepUnit< MemDepPred, Impl >::insertBarrier(), InstructionQueue< Impl >::insertNonSpec(), and InstructionQueue< Impl >::memDepUnit.
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
void InstructionQueue< Impl >::insertNonSpec | ( | const DynInstPtr & | new_inst | ) |
Inserts a new, non-speculative instruction into the IQ.
Definition at line 623 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::addToProducers(), InstructionQueue< Impl >::count, InstructionQueue< Impl >::countInsts(), DPRINTF, InstructionQueue< Impl >::fpInstQueueWrites, InstructionQueue< Impl >::freeEntries, MemDepUnit< MemDepPred, Impl >::insertNonSpec(), InstructionQueue< Impl >::instList, InstructionQueue< Impl >::intInstQueueWrites, InstructionQueue< Impl >::iqNonSpecInstsAdded, InstructionQueue< Impl >::memDepUnit, InstructionQueue< Impl >::nonSpecInsts, InstructionQueue< Impl >::numEntries, and InstructionQueue< Impl >::vecInstQueueWrites.
Referenced by InstructionQueue< Impl >::insertBarrier(), and InstructionQueue< Impl >::FUCompletion::setFreeFU().
bool InstructionQueue< Impl >::isDrained | ( | ) | const |
Determine if we are drained.
Definition at line 457 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::dependGraph, InstructionQueue< Impl >::instsToExecute, InstructionQueue< Impl >::memDepUnit, InstructionQueue< Impl >::numThreads, and InstructionQueue< Impl >::wbOutstanding.
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
bool InstructionQueue< Impl >::isFull | ( | ) |
Returns whether or not the IQ is full.
Definition at line 538 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::freeEntries.
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
bool InstructionQueue< Impl >::isFull | ( | ThreadID | tid | ) |
Returns whether or not the IQ is full for a specific thread.
Definition at line 549 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::numFreeEntries().
|
private |
Called when the oldest instruction has been removed from a ready queue; this places that ready queue into the proper spot in the age order list.
Definition at line 723 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::listOrder, InstructionQueue< Impl >::ListOrderEntry::oldestInst, InstructionQueue< Impl >::ListOrderEntry::queueType, InstructionQueue< Impl >::readyInsts, and InstructionQueue< Impl >::readyIt.
Referenced by InstructionQueue< Impl >::scheduleReadyInsts().
std::string InstructionQueue< Impl >::name | ( | ) | const |
Returns the name of the IQ.
Definition at line 170 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::cpu.
Referenced by InstructionQueue< Impl >::regStats().
unsigned InstructionQueue< Impl >::numFreeEntries | ( | ) |
Returns total number of free entries.
Definition at line 522 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::freeEntries.
Referenced by InstructionQueue< Impl >::isFull(), and InstructionQueue< Impl >::FUCompletion::setFreeFU().
unsigned InstructionQueue< Impl >::numFreeEntries | ( | ThreadID | tid | ) |
Returns number of free entries for a thread.
Definition at line 529 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::count, and InstructionQueue< Impl >::maxEntries.
void InstructionQueue< Impl >::printInsts | ( | ) |
Debug function to print all instructions.
Referenced by InstructionQueue< Impl >::getCount().
void InstructionQueue< Impl >::processFUCompletion | ( | const DynInstPtr & | inst, |
int | fu_idx | ||
) |
Process FU completion event.
Definition at line 749 of file inst_queue_impl.hh.
References TimeBuffer< T >::access(), InstructionQueue< Impl >::cpu, DPRINTF, FUPool::freeUnitNextCycle(), InstructionQueue< Impl >::fuPool, InstructionQueue< Impl >::iewStage, InstructionQueue< Impl >::instsToExecute, InstructionQueue< Impl >::issueToExecuteQueue, IssueStruct< Impl >::size, and InstructionQueue< Impl >::wbOutstanding.
Referenced by InstructionQueue< Impl >::recordProducer().
|
inline |
Records the instruction as the producer of a register without adding it to the rest of the IQ.
Definition at line 207 of file inst_queue.hh.
References InstructionQueue< Impl >::addReadyMemInst(), InstructionQueue< Impl >::addToProducers(), InstructionQueue< Impl >::blockMemInst(), InstructionQueue< Impl >::cacheUnblocked(), InstructionQueue< Impl >::commit(), InstructionQueue< Impl >::completeMemInst(), InstructionQueue< Impl >::deferMemInst(), InstructionQueue< Impl >::FUCompletion::inst, InstructionQueue< Impl >::processFUCompletion(), InstructionQueue< Impl >::replayMemInst(), InstructionQueue< Impl >::rescheduleMemInst(), InstructionQueue< Impl >::scheduleNonSpec(), InstructionQueue< Impl >::scheduleReadyInsts(), Event::squash(), InstructionQueue< Impl >::violation(), and InstructionQueue< Impl >::wakeDependents().
void InstructionQueue< Impl >::regStats | ( | ) |
Registers statistics.
Definition at line 177 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::cpu, Stats::DataWrap< Derived, InfoProxyType >::desc(), Stats::dist, Stats::DataWrap< Derived, InfoProxyType >::flags(), InstructionQueue< Impl >::fpAluAccesses, InstructionQueue< Impl >::fpInstQueueReads, InstructionQueue< Impl >::fpInstQueueWakeupAccesses, InstructionQueue< Impl >::fpInstQueueWrites, InstructionQueue< Impl >::fuBusy, InstructionQueue< Impl >::fuBusyRate, ArmISA::i, Stats::VectorBase< Derived, Stor >::init(), Stats::Vector2dBase< Derived, Stor >::init(), Stats::Distribution::init(), InstructionQueue< Impl >::intAluAccesses, InstructionQueue< Impl >::intInstQueueReads, InstructionQueue< Impl >::intInstQueueWakeupAccesses, InstructionQueue< Impl >::intInstQueueWrites, InstructionQueue< Impl >::iqBranchInstsIssued, InstructionQueue< Impl >::iqFloatInstsIssued, InstructionQueue< Impl >::iqInstsAdded, InstructionQueue< Impl >::iqInstsIssued, InstructionQueue< Impl >::iqIntInstsIssued, InstructionQueue< Impl >::iqMemInstsIssued, InstructionQueue< Impl >::iqMiscInstsIssued, InstructionQueue< Impl >::iqNonSpecInstsAdded, InstructionQueue< Impl >::iqSquashedInstsExamined, InstructionQueue< Impl >::iqSquashedInstsIssued, InstructionQueue< Impl >::iqSquashedNonSpecRemoved, InstructionQueue< Impl >::iqSquashedOperandsExamined, InstructionQueue< Impl >::issueRate, InstructionQueue< Impl >::memDepUnit, InstructionQueue< Impl >::name(), Stats::DataWrap< Derived, InfoProxyType >::name(), Num_OpClasses, InstructionQueue< Impl >::numIssuedDist, InstructionQueue< Impl >::numThreads, Stats::pdf, Stats::DataWrap< Derived, InfoProxyType >::prereq(), MemDepUnit< MemDepPred, Impl >::regStats(), InstructionQueue< Impl >::statFuBusy, InstructionQueue< Impl >::statIssuedInstType, Stats::DataWrapVec< Derived, InfoProxyType >::subname(), Stats::total, InstructionQueue< Impl >::totalWidth, InstructionQueue< Impl >::vecAluAccesses, InstructionQueue< Impl >::vecInstQueueReads, InstructionQueue< Impl >::vecInstQueueWakeupAccesses, InstructionQueue< Impl >::vecInstQueueWrites, and Stats::DataWrapVec2d< Derived, InfoProxyType >::ysubnames().
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
void InstructionQueue< Impl >::replayMemInst | ( | const DynInstPtr & | replay_inst | ) |
Replays a memory instruction.
It must be rescheduled first.
Definition at line 1119 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::memDepUnit, and MemDepUnit< MemDepPred, Impl >::replay().
Referenced by InstructionQueue< Impl >::recordProducer().
void InstructionQueue< Impl >::rescheduleMemInst | ( | const DynInstPtr & | resched_inst | ) |
Reschedules a memory instruction.
It will be ready to issue once replayMemInst() is called.
Definition at line 1105 of file inst_queue_impl.hh.
References DPRINTF, InstructionQueue< Impl >::memDepUnit, and MemDepUnit< MemDepPred, Impl >::reschedule().
Referenced by InstructionQueue< Impl >::recordProducer().
void InstructionQueue< Impl >::resetEntries | ( | ) |
Resets max entries for all threads.
Definition at line 499 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::activeThreads, InstructionQueue< Impl >::iqPolicy, InstructionQueue< Impl >::maxEntries, InstructionQueue< Impl >::numEntries, and InstructionQueue< Impl >::numThreads.
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
void InstructionQueue< Impl >::resetState | ( | ) |
Resets all instruction queue state.
Definition at line 394 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::blockedMemInsts, InstructionQueue< Impl >::count, InstructionQueue< Impl >::deferredMemInsts, InstructionQueue< Impl >::freeEntries, ArmISA::i, InstructionQueue< Impl >::instList, InstructionQueue< Impl >::listOrder, InstructionQueue< Impl >::nonSpecInsts, Num_OpClasses, InstructionQueue< Impl >::numEntries, InstructionQueue< Impl >::numPhysRegs, InstructionQueue< Impl >::queueOnList, InstructionQueue< Impl >::readyInsts, InstructionQueue< Impl >::readyIt, InstructionQueue< Impl >::regScoreboard, InstructionQueue< Impl >::retryMemInsts, InstructionQueue< Impl >::squashedSeqNum, and InstructionQueue< Impl >::wbOutstanding.
Referenced by InstructionQueue< Impl >::InstructionQueue(), InstructionQueue< Impl >::FUCompletion::setFreeFU(), and InstructionQueue< Impl >::takeOverFrom().
void InstructionQueue< Impl >::scheduleNonSpec | ( | const InstSeqNum & | inst | ) |
Schedules a single specific non-speculative instruction.
Definition at line 941 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::addIfReady(), DPRINTF, InstructionQueue< Impl >::memDepUnit, MemDepUnit< MemDepPred, Impl >::nonSpecInstReady(), and InstructionQueue< Impl >::nonSpecInsts.
Referenced by InstructionQueue< Impl >::recordProducer().
void InstructionQueue< Impl >::scheduleReadyInsts | ( | ) |
Schedules ready instructions, adding the ready ones (oldest first) to the queue to execute.
Definition at line 773 of file inst_queue_impl.hh.
References TimeBuffer< T >::access(), InstructionQueue< Impl >::addReadyMemInst(), InstructionQueue< Impl >::count, InstructionQueue< Impl >::cpu, curTick(), InstructionQueue< Impl >::deferredMemInsts, DPRINTF, InstructionQueue< Impl >::fpAluAccesses, InstructionQueue< Impl >::fpInstQueueReads, InstructionQueue< Impl >::freeEntries, FUPool::freeUnitNextCycle(), InstructionQueue< Impl >::fuBusy, InstructionQueue< Impl >::fuPool, InstructionQueue< Impl >::getBlockedMemInstToExecute(), InstructionQueue< Impl >::getDeferredMemInstToExecute(), FUPool::getOpLatency(), FUPool::getUnit(), InstructionQueue< Impl >::instsToExecute, InstructionQueue< Impl >::intAluAccesses, InstructionQueue< Impl >::intInstQueueReads, InstructionQueue< Impl >::iqInstsIssued, InstructionQueue< Impl >::iqSquashedInstsIssued, FUPool::isPipelined(), MemDepUnit< MemDepPred, Impl >::issue(), InstructionQueue< Impl >::issueToExecuteQueue, InstructionQueue< Impl >::listOrder, InstructionQueue< Impl >::memDepUnit, InstructionQueue< Impl >::moveToYoungerInst(), FUPool::NoCapableFU, FUPool::NoFreeFU, InstructionQueue< Impl >::numIssuedDist, InstructionQueue< Impl >::queueOnList, InstructionQueue< Impl >::readyInsts, InstructionQueue< Impl >::readyIt, InstructionQueue< Impl >::retryMemInsts, Stats::DistBase< Derived, Stor >::sample(), InstructionQueue< Impl >::FUCompletion::setFreeFU(), IssueStruct< Impl >::size, InstructionQueue< Impl >::statFuBusy, InstructionQueue< Impl >::statIssuedInstType, InstructionQueue< Impl >::totalWidth, InstructionQueue< Impl >::vecAluAccesses, InstructionQueue< Impl >::vecInstQueueReads, and InstructionQueue< Impl >::wbOutstanding.
Referenced by InstructionQueue< Impl >::recordProducer().
void InstructionQueue< Impl >::setActiveThreads | ( | std::list< ThreadID > * | at_ptr | ) |
Sets active threads list.
Definition at line 434 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::activeThreads.
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
void InstructionQueue< Impl >::setIssueToExecuteQueue | ( | TimeBuffer< IssueStruct > * | i2eQueue | ) |
Sets the timer buffer between issue and execute.
Definition at line 441 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::issueToExecuteQueue.
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
void InstructionQueue< Impl >::setTimeBuffer | ( | TimeBuffer< TimeStruct > * | tb_ptr | ) |
Sets the global time buffer.
Definition at line 448 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::commitToIEWDelay, InstructionQueue< Impl >::fromCommit, TimeBuffer< T >::getWire(), and InstructionQueue< Impl >::timeBuffer.
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
void InstructionQueue< Impl >::squash | ( | ThreadID | tid | ) |
Squashes instructions for a thread.
Squashing information is obtained from the time buffer.
Definition at line 1205 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::doSquash(), DPRINTF, InstructionQueue< Impl >::fromCommit, InstructionQueue< Impl >::memDepUnit, MemDepUnit< MemDepPred, Impl >::squash(), and InstructionQueue< Impl >::squashedSeqNum.
void InstructionQueue< Impl >::takeOverFrom | ( | ) |
Takes over execution from another CPU's thread.
Definition at line 480 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::resetState().
Referenced by InstructionQueue< Impl >::FUCompletion::setFreeFU().
void InstructionQueue< Impl >::violation | ( | const DynInstPtr & | store, |
const DynInstPtr & | faulting_load | ||
) |
Indicates an ordering violation between a store and a load.
Definition at line 1196 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::intInstQueueWrites, InstructionQueue< Impl >::memDepUnit, and MemDepUnit< MemDepPred, Impl >::violation().
Referenced by InstructionQueue< Impl >::recordProducer().
int InstructionQueue< Impl >::wakeDependents | ( | const DynInstPtr & | completed_inst | ) |
Wakes all dependents of a completed instruction.
Definition at line 987 of file inst_queue_impl.hh.
References InstructionQueue< Impl >::addIfReady(), RegId::className(), MemDepUnit< MemDepPred, Impl >::completeBarrier(), InstructionQueue< Impl >::completeMemInst(), PhysRegId::decrNumPinnedWritesToComplete(), InstructionQueue< Impl >::dependGraph, DPRINTF, PhysRegId::flatIndex(), InstructionQueue< Impl >::fpInstQueueWakeupAccesses, PhysRegId::getNumPinnedWritesToComplete(), RegId::index(), InstructionQueue< Impl >::intInstQueueWakeupAccesses, PhysRegId::isFixedMapping(), PhysRegId::isPinned(), InstructionQueue< Impl >::memDepUnit, InstructionQueue< Impl >::regScoreboard, InstructionQueue< Impl >::vecInstQueueWakeupAccesses, and MemDepUnit< MemDepPred, Impl >::wakeDependents().
Referenced by InstructionQueue< Impl >::recordProducer().
|
private |
Pointer to list of active threads.
Definition at line 412 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::resetEntries(), and InstructionQueue< Impl >::setActiveThreads().
|
private |
List of instructions that have been cache blocked.
Definition at line 325 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::blockMemInst(), InstructionQueue< Impl >::cacheUnblocked(), and InstructionQueue< Impl >::resetState().
|
private |
Delay between commit stage and the IQ.
Definition at line 438 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::setTimeBuffer().
|
private |
Per Thread IQ count.
Definition at line 415 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::completeMemInst(), InstructionQueue< Impl >::doSquash(), InstructionQueue< Impl >::getCount(), InstructionQueue< Impl >::insert(), InstructionQueue< Impl >::insertNonSpec(), InstructionQueue< Impl >::numFreeEntries(), InstructionQueue< Impl >::resetState(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
Pointer to the CPU.
Definition at line 282 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::cacheUnblocked(), InstructionQueue< Impl >::name(), InstructionQueue< Impl >::processFUCompletion(), InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
Cache interface.
Definition at line 285 of file inst_queue.hh.
|
private |
List of instructions waiting for their DTB translation to complete (hw page table walk in progress).
Definition at line 322 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::deferMemInst(), InstructionQueue< Impl >::getDeferredMemInstToExecute(), InstructionQueue< Impl >::resetState(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
Definition at line 399 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::addToDependents(), InstructionQueue< Impl >::addToProducers(), InstructionQueue< Impl >::doSquash(), InstructionQueue< Impl >::drainSanityCheck(), InstructionQueue< Impl >::InstructionQueue(), InstructionQueue< Impl >::isDrained(), InstructionQueue< Impl >::wakeDependents(), and InstructionQueue< Impl >::~InstructionQueue().
Stats::Scalar InstructionQueue< Impl >::fpAluAccesses |
Definition at line 544 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::scheduleReadyInsts().
Stats::Scalar InstructionQueue< Impl >::fpInstQueueReads |
Definition at line 536 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::getInstToExecute(), InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::scheduleReadyInsts().
Stats::Scalar InstructionQueue< Impl >::fpInstQueueWakeupAccesses |
Definition at line 538 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::wakeDependents().
Stats::Scalar InstructionQueue< Impl >::fpInstQueueWrites |
Definition at line 537 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::doSquash(), InstructionQueue< Impl >::insert(), InstructionQueue< Impl >::insertNonSpec(), and InstructionQueue< Impl >::regStats().
|
private |
Number of free IQ entries left.
Definition at line 421 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::commit(), InstructionQueue< Impl >::completeMemInst(), InstructionQueue< Impl >::countInsts(), InstructionQueue< Impl >::doSquash(), InstructionQueue< Impl >::insert(), InstructionQueue< Impl >::insertNonSpec(), InstructionQueue< Impl >::isFull(), InstructionQueue< Impl >::numFreeEntries(), InstructionQueue< Impl >::resetState(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
Wire to read information from timebuffer.
Definition at line 304 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::setTimeBuffer(), and InstructionQueue< Impl >::squash().
|
private |
Number of times the FU was busy.
Definition at line 529 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
Number of times the FU was busy per instruction issued.
Definition at line 531 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats().
|
private |
Function unit pool.
Definition at line 307 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::InstructionQueue(), InstructionQueue< Impl >::processFUCompletion(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
Pointer to IEW stage.
Definition at line 288 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::processFUCompletion().
|
private |
List of all the instructions in the IQ (some of which may be issued).
Definition at line 314 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::commit(), InstructionQueue< Impl >::doSquash(), InstructionQueue< Impl >::dumpInsts(), InstructionQueue< Impl >::insert(), InstructionQueue< Impl >::insertNonSpec(), and InstructionQueue< Impl >::resetState().
|
private |
List of instructions that are ready to be executed.
Definition at line 317 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::drainSanityCheck(), InstructionQueue< Impl >::dumpInsts(), InstructionQueue< Impl >::getInstToExecute(), InstructionQueue< Impl >::isDrained(), InstructionQueue< Impl >::processFUCompletion(), and InstructionQueue< Impl >::scheduleReadyInsts().
Stats::Scalar InstructionQueue< Impl >::intAluAccesses |
Definition at line 543 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::scheduleReadyInsts().
Stats::Scalar InstructionQueue< Impl >::intInstQueueReads |
Definition at line 533 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::getInstToExecute(), InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::scheduleReadyInsts().
Stats::Scalar InstructionQueue< Impl >::intInstQueueWakeupAccesses |
Definition at line 535 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::wakeDependents().
Stats::Scalar InstructionQueue< Impl >::intInstQueueWrites |
Definition at line 534 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::doSquash(), InstructionQueue< Impl >::insert(), InstructionQueue< Impl >::insertNonSpec(), InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::violation().
|
private |
Stat for number of branch instructions issued.
Definition at line 488 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats().
|
private |
Stat for number of floating point instructions issued.
Definition at line 486 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats().
|
private |
Stat for number of instructions added.
Definition at line 478 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::insert(), and InstructionQueue< Impl >::regStats().
|
private |
Definition at line 482 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
Stat for number of integer instructions issued.
Definition at line 484 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats().
|
private |
Stat for number of memory instructions issued.
Definition at line 490 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats().
|
private |
Stat for number of miscellaneous instructions issued.
Definition at line 492 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats().
|
private |
Stat for number of non-speculative instructions added.
Definition at line 480 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::insertNonSpec(), and InstructionQueue< Impl >::regStats().
|
private |
IQ sharing policy for SMT.
Definition at line 406 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::entryAmount(), InstructionQueue< Impl >::InstructionQueue(), and InstructionQueue< Impl >::resetEntries().
|
private |
Stat for number of squashed instructions examined when squashing.
Definition at line 496 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::doSquash(), and InstructionQueue< Impl >::regStats().
|
private |
Stat for number of squashed instructions that were ready to issue.
Definition at line 494 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
Stat for number of non-speculative instructions removed due to a squash.
Definition at line 503 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::doSquash(), and InstructionQueue< Impl >::regStats().
|
private |
Stat for number of squashed instruction operands examined when squashing.
Definition at line 500 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::doSquash(), and InstructionQueue< Impl >::regStats().
|
private |
Number of instructions issued per cycle.
Definition at line 526 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats().
|
private |
The queue to the execute stage.
Issued instructions will be written into it.
Definition at line 298 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::processFUCompletion(), InstructionQueue< Impl >::scheduleReadyInsts(), and InstructionQueue< Impl >::setIssueToExecuteQueue().
|
private |
List that contains the age order of the oldest instruction of each ready queue.
Used to select the oldest instruction available among op classes.
Definition at line 378 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::addIfReady(), InstructionQueue< Impl >::addReadyMemInst(), InstructionQueue< Impl >::addToOrderList(), InstructionQueue< Impl >::dumpLists(), InstructionQueue< Impl >::hasReadyInsts(), InstructionQueue< Impl >::moveToYoungerInst(), InstructionQueue< Impl >::resetState(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
Max IQ Entries Per Thread.
Definition at line 418 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::InstructionQueue(), InstructionQueue< Impl >::numFreeEntries(), and InstructionQueue< Impl >::resetEntries().
|
private |
The memory dependence unit, which tracks/predicts memory dependences between instructions.
Definition at line 293 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::addIfReady(), InstructionQueue< Impl >::completeMemInst(), InstructionQueue< Impl >::drainSanityCheck(), InstructionQueue< Impl >::insert(), InstructionQueue< Impl >::insertBarrier(), InstructionQueue< Impl >::insertNonSpec(), InstructionQueue< Impl >::InstructionQueue(), InstructionQueue< Impl >::isDrained(), InstructionQueue< Impl >::regStats(), InstructionQueue< Impl >::replayMemInst(), InstructionQueue< Impl >::rescheduleMemInst(), InstructionQueue< Impl >::scheduleNonSpec(), InstructionQueue< Impl >::scheduleReadyInsts(), InstructionQueue< Impl >::squash(), InstructionQueue< Impl >::violation(), and InstructionQueue< Impl >::wakeDependents().
|
private |
List of non-speculative instructions that will be scheduled once the IQ gets a signal from commit.
While it's redundant to have the key be a part of the value (the sequence number is stored inside of DynInst), when these instructions are woken up only the sequence number will be available. Thus it is most efficient to be able to search by the sequence number alone.
Definition at line 361 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::doSquash(), InstructionQueue< Impl >::dumpLists(), InstructionQueue< Impl >::insertNonSpec(), InstructionQueue< Impl >::resetState(), and InstructionQueue< Impl >::scheduleNonSpec().
|
private |
The number of entries in the instruction queue.
Definition at line 424 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::commit(), InstructionQueue< Impl >::countInsts(), InstructionQueue< Impl >::entryAmount(), InstructionQueue< Impl >::insert(), InstructionQueue< Impl >::insertNonSpec(), InstructionQueue< Impl >::InstructionQueue(), InstructionQueue< Impl >::resetEntries(), and InstructionQueue< Impl >::resetState().
|
private |
Distribution of number of instructions in the queue.
Distribution of the number of instructions issued.
Definition at line 511 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
The number of physical registers in the CPU.
Definition at line 430 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::InstructionQueue(), and InstructionQueue< Impl >::resetState().
|
private |
Number of Total Threads.
Definition at line 409 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::drainSanityCheck(), InstructionQueue< Impl >::dumpInsts(), InstructionQueue< Impl >::InstructionQueue(), InstructionQueue< Impl >::isDrained(), InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::resetEntries().
|
private |
Tracks if each ready queue is on the age order list.
Definition at line 383 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::addIfReady(), InstructionQueue< Impl >::addReadyMemInst(), InstructionQueue< Impl >::addToOrderList(), InstructionQueue< Impl >::resetState(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
List of ready instructions, per op class.
They are separated by op class to allow for easy mapping to FUs.
Definition at line 352 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::addIfReady(), InstructionQueue< Impl >::addReadyMemInst(), InstructionQueue< Impl >::addToOrderList(), InstructionQueue< Impl >::dumpLists(), InstructionQueue< Impl >::hasReadyInsts(), InstructionQueue< Impl >::moveToYoungerInst(), InstructionQueue< Impl >::resetState(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
Iterators of each ready queue.
Points to their spot in the age order list.
Definition at line 388 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::addIfReady(), InstructionQueue< Impl >::addReadyMemInst(), InstructionQueue< Impl >::addToOrderList(), InstructionQueue< Impl >::moveToYoungerInst(), InstructionQueue< Impl >::resetState(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
A cache of the recently woken registers.
It is 1 if the register has been woken up recently, and 0 if the register has been added to the dependency graph and has not yet received its value. It is basically a secondary scoreboard, and should pretty much mirror the scoreboard that exists in the rename map.
Definition at line 449 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::addToDependents(), InstructionQueue< Impl >::addToProducers(), InstructionQueue< Impl >::InstructionQueue(), InstructionQueue< Impl >::resetState(), and InstructionQueue< Impl >::wakeDependents().
|
private |
List of instructions that were cache blocked, but a retry has been seen since, so they can now be retried.
May fail again go on the blocked list.
Definition at line 330 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::cacheUnblocked(), InstructionQueue< Impl >::getBlockedMemInstToExecute(), InstructionQueue< Impl >::resetState(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
The sequence number of the squashed instruction.
Definition at line 441 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::doSquash(), InstructionQueue< Impl >::resetState(), and InstructionQueue< Impl >::squash().
|
private |
Distribution of the cycles it takes to issue an instruction.
Number of times an instruction could not be issued because a FU was busy.
Definition at line 520 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
Stat for total number issued for each instruction type.
Definition at line 523 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::scheduleReadyInsts().
|
private |
The backwards time buffer.
Definition at line 301 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::setTimeBuffer().
|
private |
The total number of instructions that can be issued in one cycle.
Definition at line 427 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::scheduleReadyInsts().
Stats::Scalar InstructionQueue< Impl >::vecAluAccesses |
Definition at line 545 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::scheduleReadyInsts().
Stats::Scalar InstructionQueue< Impl >::vecInstQueueReads |
Definition at line 539 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::getInstToExecute(), InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::scheduleReadyInsts().
Stats::Scalar InstructionQueue< Impl >::vecInstQueueWakeupAccesses |
Definition at line 541 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::regStats(), and InstructionQueue< Impl >::wakeDependents().
Stats::Scalar InstructionQueue< Impl >::vecInstQueueWrites |
Definition at line 540 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::doSquash(), InstructionQueue< Impl >::insert(), InstructionQueue< Impl >::insertNonSpec(), and InstructionQueue< Impl >::regStats().
|
private |
Number of instructions currently in flight to FUs.
Definition at line 433 of file inst_queue.hh.
Referenced by InstructionQueue< Impl >::isDrained(), InstructionQueue< Impl >::processFUCompletion(), InstructionQueue< Impl >::resetState(), and InstructionQueue< Impl >::scheduleReadyInsts().