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