Go to the documentation of this file.
41 #ifndef __CPU_O3_COMMIT_HH__
42 #define __CPU_O3_COMMIT_HH__
56 #include "enums/CommitPolicy.hh"
135 Commit(
CPU *_cpu,
const O3CPUParams ¶ms);
138 std::string
name()
const;
525 #endif // __CPU_O3_COMMIT_HH__
bool drainPending
Is a drain pending? Commit is looking for an instruction boundary while there are no pending interrup...
This is a simple scalar statistic, like a counter.
void setActiveThreads(std::list< ThreadID > *at_ptr)
Sets pointer to list of active threads.
UnifiedRenameMap * renameMap[MaxThreads]
Rename map interface.
void setROB(ROB *rob_ptr)
Sets pointer to the ROB.
const Cycles fetchToCommitDelay
void takeOverFrom()
Takes over from another CPU's thread.
statistics::Vector instsCommitted
Total number of instructions committed.
statistics::Scalar commitEligibleSamples
Number of cycles where the commit bandwidth limit is reached.
void squashFromTC(ThreadID tid)
Handles squashing due to an TC write.
void regProbePoints()
Registers probes.
Commit(CPU *_cpu, const O3CPUParams ¶ms)
Construct a Commit with the given parameters.
statistics::Vector loads
Stat for the total number of committed loads.
const unsigned renameWidth
Rename width, in instructions.
A simple distribution stat.
void setIEWQueue(TimeBuffer< IEWStruct > *iq_ptr)
Sets the pointer to the queue coming from IEW.
statistics::Distribution numCommittedDist
Distribution of the number of committed instructions each cycle.
void drain()
Initializes the draining of commit.
statistics::Vector2d committedInstType
Committed instructions by instruction type (OpClass)
TheISA::PCState pc[MaxThreads]
The commit PC state of each thread.
TimeBuffer< RenameStruct > * renameQueue
Rename instruction queue interface, for ROB.
ProbePointArg< DynInstPtr > * ppSquash
To probe when an instruction is squashed.
DynInstPtr squashAfterInst[MaxThreads]
Instruction passed to squashAfter().
void setThreads(std::vector< ThreadState * > &threads)
Sets the list of threads.
TimeBuffer< TimeStruct > * timeBuffer
Time buffer interface.
TimeBuffer< IEWStruct >::wire fromIEW
Wire to read information from IEW queue.
std::list< ThreadID > priority_list
Priority List used for Commit Policy.
bool wroteToTimeBuffer
Records that commit has written to the time buffer this cycle.
bool changedROBEntries()
Returns if any of the threads have the number of ROB entries changed on this cycle.
void startupStage()
Initializes stage by sending back the number of free entries.
void pcState(const TheISA::PCState &val, ThreadID tid)
Sets the PC of a specific thread.
void setRenameMap(UnifiedRenameMap rm_ptr[MaxThreads])
Sets pointer to the commited state rename map.
A 2-Dimensional vecto of scalar stats.
void commitInsts()
Commits as many instructions as possible.
ProbePointArg< DynInstPtr > * ppCommit
Probe Points.
A vector of scalar stats.
ThreadStatus
Individual thread status.
void squashFromSquashAfter(ThreadID tid)
Handles a squash from a squashAfter() request.
void setRenameQueue(TimeBuffer< RenameStruct > *rq_ptr)
Sets the pointer to the queue coming from rename.
CommitStatus
Overall commit status.
bool committedStores[MaxThreads]
Records if there were any stores committed this cycle.
void generateTrapEvent(ThreadID tid, Fault inst_fault)
Generates an event to schedule a squash due to a trap.
void deactivateThread(ThreadID tid)
Deschedules a thread from scheduling.
const Cycles commitToIEWDelay
Commit to IEW delay.
size_t numROBFreeEntries(ThreadID tid)
Returns the number of free ROB entries for a specific thread.
Cycles is a wrapper class for representing cycle counts, i.e.
int htmStarts[MaxThreads]
std::string name() const
Returns the name of the Commit.
gem5::o3::Commit::CommitStats stats
statistics::Scalar branchMispredicts
Stat for the total number of branch mispredicts that caused a squash.
IEW * iewStage
The pointer to the IEW stage.
std::list< ThreadID > * activeThreads
Pointer to the list of active threads.
bool changedROBNumEntries[MaxThreads]
Records if the number of ROB entries has changed this cycle.
TimeBuffer< IEWStruct > * iewQueue
IEW instruction queue interface.
void generateTCEvent(ThreadID tid)
Records that commit needs to initiate a squash due to an external state update through the TC.
const Cycles renameToROBDelay
Rename to ROB delay.
void squashAll(ThreadID tid)
Squashes all in flight instructions.
statistics::Vector floating
Total number of floating point instructions.
O3CPU class, has each of the stages (fetch through commit) within it, as well as all of the time buff...
Commit handles single threaded and SMT commit.
void propagateInterrupt()
Get fetch redirecting so we can handle an interrupt.
std::shared_ptr< FaultBase > Fault
void processTrapEvent(ThreadID tid)
Mark the thread as processing a trap.
bool isDrained() const
Has the stage drained?
ThreadStatus commitStatus[MaxThreads]
Per-thread status.
ThreadID roundRobin()
Returns the thread ID to use based on a round robin policy.
Addr microPC(ThreadID tid)
Reads the micro PC of a specific thread.
void getInsts()
Gets instructions from rename and inserts them into the ROB.
bool avoidQuiesceLiveLock
Have we had an interrupt pending and then seen it de-asserted because of a masking change?...
GenericISA::DelaySlotPCState< 4 > PCState
IEW handles both single threaded and SMT IEW (issue/execute/writeback).
bool commitHead(const DynInstPtr &head_inst, unsigned inst_num)
Tries to commit the head ROB instruction passed in.
TimeBuffer< TimeStruct >::wire toIEW
Wire to write information heading to previous stages.
void resetHtmStartsStops(ThreadID)
void squashAfter(ThreadID tid, const DynInstPtr &head_inst)
Handle squashing from instruction with SquashAfter set.
ThreadID oldestReady()
Returns the thread ID to use based on an oldest instruction policy.
statistics::Scalar commitSquashedInsts
Stat for the total number of squashed instructions discarded by commit.
const unsigned commitWidth
Commit width, in instructions.
void clearStates(ThreadID tid)
Clear all thread-specific states.
std::vector< ThreadState * > thread
Vector of all of the threads.
CPU * cpu
Pointer to O3CPU.
bool checkEmptyROB[MaxThreads]
Records if commit should check if the ROB is truly empty (see commit_impl.hh).
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
statistics::Vector integer
Total number of integer instructions.
Addr instAddr(ThreadID tid)
Returns the PC of a specific thread.
TimeBuffer< FetchStruct >::wire fromFetch
statistics::Vector vectorInstructions
Total number of vector instructions.
void updateComInstStats(const DynInstPtr &inst)
Updates commit stats based on this instruction.
ThreadID getCommittingThread()
Gets the thread to commit, based on the SMT policy.
ProbePointArg generates a point for the class of Arg.
void commit()
Handles any squashes that are sent from IEW, and adds instructions to the ROB and tries to commit ins...
static constexpr int MaxThreads
statistics::Vector amos
Stat for the total number of committed atomics.
void drainResume()
Resumes execution after draining.
bool executingHtmTransaction(ThreadID) const
Is the CPU currently processing a HTM transaction?
Fault interrupt
The interrupt fault.
InstSeqNum lastCommitedSeqNum[MaxThreads]
The sequence number of the last commited instruction.
void setFetchQueue(TimeBuffer< FetchStruct > *fq_ptr)
bool trapSquash[MaxThreads]
Records if a thread has to squash this cycle due to a trap.
CommitPolicy commitPolicy
Commit policy used in SMT mode.
bool trapInFlight[MaxThreads]
Records if there is a trap currently in flight.
CommitStatus _status
Overall commit status.
TheISA::PCState pcState(ThreadID tid)
Reads the PC of a specific thread.
statistics::Vector memRefs
Stat for the total number of committed memory references.
CommitStatus _nextStatus
Next commit status, to be set at the end of the cycle.
statistics::Vector opsCommitted
Total number of ops (including micro ops) committed.
CommitStats(CPU *cpu, Commit *commit)
statistics::Scalar commitNonSpecStalls
Stat for the total number of times commit has had to stall due to a non-speculative instruction reach...
void tick()
Ticks the commit stage, which tries to commit instructions.
ProbePointArg< DynInstPtr > * ppCommitStall
InstSeqNum youngestSeqNum[MaxThreads]
The sequence number of the youngest valid instruction in the ROB.
statistics::Vector functionCalls
Total number of function calls.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
const ThreadID numThreads
Number of Active Threads.
void markCompletedInsts()
Marks completed instructions using information sent from IEW.
bool drainImminent
Is a drain imminent? Commit has found an instruction boundary while no interrupts were present or in ...
void updateStatus()
Updates the overall status of commit with the nextStatus, and tell the CPU if commit is active/inacti...
void setTimeBuffer(TimeBuffer< TimeStruct > *tb_ptr)
Sets the main time buffer pointer, used for backwards communication.
void squashFromTrap(ThreadID tid)
Handles squashing due to a trap.
const Cycles trapLatency
The latency to handle a trap.
bool canHandleInterrupts
True if last committed microop can be followed by an interrupt.
void handleInterrupt()
Handles processing an interrupt.
void setIEWStage(IEW *iew_stage)
Sets the pointer to the IEW stage.
TimeBuffer< RenameStruct >::wire fromRename
Wire to read information from rename queue.
statistics::Vector branches
Total number of committed branches.
void drainSanityCheck() const
Perform sanity checks after a drain.
int16_t ThreadID
Thread index/ID type.
Addr nextInstAddr(ThreadID tid)
Returns the next PC of a specific thread.
statistics::Vector membars
Total number of committed memory barriers.
Unified register rename map for all classes of registers.
const Cycles iewToCommitDelay
IEW to Commit delay.
TimeBuffer< TimeStruct >::wire robInfoFromIEW
Wire to read information from IEW (for ROB).
TimeBuffer< FetchStruct > * fetchQueue
bool tcSquash[MaxThreads]
Records if a thread has to squash this cycle due to an XC write.
Generated on Tue Sep 7 2021 14:53:44 for gem5 by doxygen 1.8.17