Go to the documentation of this file.
42 #ifndef __CPU_O3_INST_QUEUE_HH__
43 #define __CPU_O3_INST_QUEUE_HH__
56 #include "enums/SMTQueuePolicy.hh"
59 struct DerivO3CPUParams;
85 typedef typename Impl::O3CPU
O3CPU;
88 typedef typename Impl::CPUPol::IEW
IEW;
125 const DerivO3CPUParams ¶ms);
131 std::string
name()
const;
337 return lhs->seqNum > rhs->seqNum;
341 typedef std::priority_queue<DynInstPtr, std::vector<DynInstPtr>, pqCompare>
358 typedef typename std::map<InstSeqNum, DynInstPtr>::iterator
NonSpecMapIt;
555 #endif //__CPU_O3_INST_QUEUE_HH__
Stats::Scalar instsIssued
static const OpClass Num_OpClasses
std::map< InstSeqNum, DynInstPtr > nonSpecInsts
List of non-speculative instructions that will be scheduled once the IQ gets a signal from commit.
Stats::Scalar fpInstQueueWakeupAccesses
void addIfReady(const DynInstPtr &inst)
Moves an instruction to the ready queue if it is ready.
Stats::Formula issueRate
Number of instructions issued per cycle.
void takeOverFrom()
Takes over execution from another CPU's thread.
InstructionQueue::IQIOStats iqIOStats
IEW * iewStage
Pointer to IEW stage.
int wakeDependents(const DynInstPtr &completed_inst)
Wakes all dependents of a completed instruction.
void commit(const InstSeqNum &inst, ThreadID tid=0)
Commits all instructions up to and including the given sequence number, for a specific thread.
ReadyInstQueue readyInsts[Num_OpClasses]
List of ready instructions, per op class.
std::string name() const
Returns the name of the IQ.
TimeBuffer< TimeStruct >::wire fromCommit
Wire to read information from timebuffer.
DynInstPtr getDeferredMemInstToExecute()
Gets a memory instruction that was referred due to a delayed DTB translation if it is now ready to ex...
void squash(ThreadID tid)
Squashes instructions for a thread.
DynInstPtr getBlockedMemInstToExecute()
Gets a memory instruction that was blocked on the cache.
unsigned count[Impl::MaxThreads]
Per Thread IQ count.
int16_t ThreadID
Thread index/ID type.
TimeBuffer< TimeStruct > * timeBuffer
The backwards time buffer.
Cycles commitToIEWDelay
Delay between commit stage and the IQ.
SMTQueuePolicy iqPolicy
IQ sharing policy for SMT.
std::list< ListOrderEntry >::iterator ListOrderIt
void resetEntries()
Resets max entries for all threads.
Stats::Scalar memInstsIssued
Stat for number of memory instructions issued.
std::list< DynInstPtr > retryMemInsts
List of instructions that were cache blocked, but a retry has been seen since, so they can now be ret...
InstructionQueue(O3CPU *cpu_ptr, IEW *iew_ptr, const DerivO3CPUParams ¶ms)
Constructs an IQ.
void resetState()
Resets all instruction queue state.
int entryAmount(ThreadID num_threads)
Number of entries needed for given amount of threads.
void deferMemInst(const DynInstPtr &deferred_inst)
Defers a memory instruction when its DTB translation incurs a hw page table walk.
std::map< InstSeqNum, DynInstPtr >::iterator NonSpecMapIt
void drainSanityCheck() const
Perform sanity checks after a drain.
~InstructionQueue()
Destructs the IQ.
Stats::Vector statFuBusy
Distribution of the cycles it takes to issue an instruction.
int countInsts()
Debugging function to count how many entries are in the IQ.
DependencyGraph< DynInstPtr > dependGraph
std::list< DynInstPtr >::iterator ListIt
unsigned maxEntries[Impl::MaxThreads]
Max IQ Entries Per Thread.
int fuIdx
Index of the FU used for executing.
void blockMemInst(const DynInstPtr &blocked_inst)
Defers a memory instruction when it is cache blocked.
Stats::Scalar intInstsIssued
Stat for number of integer instructions issued.
void moveToYoungerInst(ListOrderIt age_order_it)
Called when the oldest instruction has been removed from a ready queue; this places that ready queue ...
void cacheUnblocked()
Notify instruction queue that a previous blockage has resolved.
Pool of FU's, specific to the new CPU model.
A vector of scalar stats.
Stats::Scalar squashedInstsIssued
Stat for number of squashed instructions that were ready to issue.
void setIssueToExecuteQueue(TimeBuffer< IssueStruct > *i2eQueue)
Sets the timer buffer between issue and execute.
std::priority_queue< DynInstPtr, std::vector< DynInstPtr >, pqCompare > ReadyInstQueue
void printInsts()
Debug function to print all instructions.
unsigned numPhysRegs
The number of physical registers in the CPU.
ListOrderIt readyIt[Num_OpClasses]
Iterators of each ready queue.
Array of linked list that maintains the dependencies between producing instructions and consuming ins...
Stats::Scalar intInstQueueWakeupAccesses
void processFUCompletion(const DynInstPtr &inst, int fu_idx)
Process FU completion event.
O3CPU * cpu
Pointer to the CPU.
Stats::Scalar vecInstQueueWakeupAccesses
Stats::Scalar vecInstQueueReads
This is a simple scalar statistic, like a counter.
FUPool * fuPool
Function unit pool.
std::list< DynInstPtr > deferredMemInsts
List of instructions waiting for their DTB translation to complete (hw page table walk in progress).
Stats::Scalar nonSpecInstsAdded
Stat for number of non-speculative instructions added.
unsigned totalWidth
The total number of instructions that can be issued in one cycle.
Stats::Scalar floatInstsIssued
Stat for number of floating point instructions issued.
Impl::CPUPol::MemDepUnit MemDepUnit
Impl::CPUPol::TimeStruct TimeStruct
Entry for the list age ordering by op class.
MemDepUnit memDepUnit[Impl::MaxThreads]
The memory dependence unit, which tracks/predicts memory dependences between instructions.
void insert(const DynInstPtr &new_inst)
Inserts a new instruction into the IQ.
void addToProducers(const DynInstPtr &new_inst)
Adds an instruction to the dependency graph, as a producer.
Stats::Scalar instsAdded
Stat for number of instructions added.
std::list< ThreadID > * activeThreads
Pointer to list of active threads.
bool isDrained() const
Determine if we are drained.
unsigned getCount(ThreadID tid)
Returns the number of used entries for a thread.
void dumpLists()
Debugging function to dump all the list sizes, as well as print out the list of nonspeculative instru...
unsigned freeEntries
Number of free IQ entries left.
ThreadID numThreads
Number of Total Threads.
InstructionQueue::IQStats iqStats
Struct for comparing entries to be added to the priority queue.
Stats::Formula fuBusyRate
Number of times the FU was busy per instruction issued.
int wbOutstanding
Number of instructions currently in flight to FUs.
void recordProducer(const DynInstPtr &inst)
Records the instruction as the producer of a register without adding it to the rest of the IQ.
Stats::Scalar squashedOperandsExamined
Stat for number of squashed instruction operands examined when squashing.
void replayMemInst(const DynInstPtr &replay_inst)
Replays a memory instruction.
Stats::Scalar fpInstQueueWrites
void dumpInsts()
Debugging function to dump out all instructions that are in the IQ.
void insertNonSpec(const DynInstPtr &new_inst)
Inserts a new, non-speculative instruction into the IQ.
void doSquash(ThreadID tid)
Does the actual squashing.
std::list< DynInstPtr > instsToExecute
List of instructions that are ready to be executed.
void scheduleReadyInsts()
Schedules ready instructions, adding the ready ones (oldest first) to the queue to execute.
A simple distribution stat.
Impl::DynInstPtr DynInstPtr
InstSeqNum squashedSeqNum[Impl::MaxThreads]
The sequence number of the squashed instruction.
void scheduleNonSpec(const InstSeqNum &inst)
Schedules a single specific non-speculative instruction.
void violation(const DynInstPtr &store, const DynInstPtr &faulting_load)
Indicates an ordering violation between a store and a load.
FUCompletion(const DynInstPtr &_inst, int fu_idx, InstructionQueue< Impl > *iq_ptr)
Construct a FU completion event.
IQStats(O3CPU *cpu, const unsigned &total_width)
Stats::Vector2d statIssuedInstType
Stat for total number issued for each instruction type.
Stats::Scalar miscInstsIssued
Stat for number of miscellaneous instructions issued.
bool queueOnList[Num_OpClasses]
Tracks if each ready queue is on the age order list.
InstructionQueue< Impl > * iqPtr
Pointer back to the instruction queue.
bool freeFU
Should the FU be added to the list to be freed upon completing this event.
virtual const char * description() const
Return a C string describing the event.
A 2-Dimensional vecto of scalar stats.
unsigned numEntries
The number of entries in the instruction queue.
Stats::Distribution numIssuedDist
Distribution of number of instructions in the queue.
bool operator()(const DynInstPtr &lhs, const DynInstPtr &rhs) const
Stats::Scalar intInstQueueReads
DynInstPtr getInstToExecute()
Returns the oldest scheduled instruction, and removes it from the list of instructions waiting to exe...
MemInterface * dcacheInterface
Cache interface.
Stats::Scalar fpInstQueueReads
Stats::Scalar fpAluAccesses
DynInstPtr inst
Executing instruction.
Stats::Vector fuBusy
Number of times the FU was busy.
Stats::Scalar intInstQueueWrites
A standard instruction queue class.
void setActiveThreads(std::list< ThreadID > *at_ptr)
Sets active threads list.
Stats::Scalar squashedInstsExamined
Stat for number of squashed instructions examined when squashing.
void addToOrderList(OpClass op_class)
Add an op class to the age order list.
Stats::Scalar squashedNonSpecRemoved
Stat for number of non-speculative instructions removed due to a squash.
void insertBarrier(const DynInstPtr &barr_inst)
Inserts a memory or write barrier into the IQ to make sure loads and stores are ordered properly.
Cycles is a wrapper class for representing cycle counts, i.e.
Stats::Scalar intAluAccesses
std::list< DynInstPtr > instList[Impl::MaxThreads]
List of all the instructions in the IQ (some of which may be issued).
std::vector< bool > regScoreboard
A cache of the recently woken registers.
std::list< DynInstPtr > blockedMemInsts
List of instructions that have been cache blocked.
bool addToDependents(const DynInstPtr &new_inst)
Adds an instruction to the dependency graph, as a consumer.
unsigned numFreeEntries()
Returns total number of free entries.
Memory dependency unit class.
FU completion event class.
Stats::Scalar branchInstsIssued
Stat for number of branch instructions issued.
void rescheduleMemInst(const DynInstPtr &resched_inst)
Reschedules a memory instruction.
void setTimeBuffer(TimeBuffer< TimeStruct > *tb_ptr)
Sets the global time buffer.
IQIOStats(Stats::Group *parent)
Stats::Scalar vecAluAccesses
Impl::CPUPol::IssueStruct IssueStruct
bool isFull()
Returns whether or not the IQ is full.
TimeBuffer< IssueStruct > * issueToExecuteQueue
The queue to the execute stage.
bool hasReadyInsts()
Returns if there are any ready instructions in the IQ.
void addReadyMemInst(const DynInstPtr &ready_inst)
Adds a ready memory instruction to the ready list.
Stats::Scalar vecInstQueueWrites
std::list< ListOrderEntry > listOrder
List that contains the age order of the oldest instruction of each ready queue.
General interface to memory device Includes functions and parameters shared across media types.
Generated on Tue Mar 23 2021 19:41:25 for gem5 by doxygen 1.8.17