Go to the documentation of this file.
42 #ifndef __CPU_O3_RENAME_HH__
43 #define __CPU_O3_RENAME_HH__
128 Rename(
CPU *_cpu,
const O3CPUParams ¶ms);
131 std::string
name()
const;
541 #endif // __CPU_O3_RENAME_HH__
bool isDrained() const
Has the stage drained?
This is a simple scalar statistic, like a counter.
int decodeToRenameDelay
Delay between decode and rename, in ticks.
FreeEntries freeEntries[MaxThreads]
Per-thread tracking of the number of free entries of back-end structures.
int storesInProgress[MaxThreads]
Count of Store instructions in progress that have been sent off to the IQ and ROB,...
void tick()
Ticks rename, which processes all input signals and attempts to rename as many instructions as possib...
PhysRegIdPtr newPhysReg
The new physical register that the arch.
bool serializeOnNextInst[MaxThreads]
Records if rename needs to serialize on the next instruction for any thread.
void drainSanityCheck() const
Perform sanity checks after a drain.
void squash(const InstSeqNum &squash_seq_num, ThreadID tid)
Squashes all instructions in a thread.
IEW * iew_ptr
Pointer to IEW stage.
void dumpHistory()
Debugging function used to dump history buffer of renamings.
void setRenameQueue(TimeBuffer< RenameStruct > *rq_ptr)
Sets pointer to time buffer used to communicate to the next stage.
int calcFreeROBEntries(ThreadID tid)
Calculates the number of free ROB entries for a specific thread.
unsigned validInsts()
Returns the number of valid instructions coming from decode.
statistics::Scalar blockCycles
Stat for total number of cycles spent blocking.
void setRenameMap(UnifiedRenameMap rm_ptr[MaxThreads])
Sets pointer to rename maps (per-thread structures).
statistics::Scalar runCycles
Stat for total number of cycles spent running normally.
bool wroteToTimeBuffer
Variable that tracks if decode has written to the time buffer this cycle.
RenameStatus _status
Rename status.
bool resumeSerialize
Whether or not rename needs to resume a serialize instruction after squashing.
int instsInProgress[MaxThreads]
Count of instructions in progress that have been sent off to the IQ and ROB, but are not yet included...
void skidInsert(ThreadID tid)
Inserts unused instructions from a given thread into the skid buffer, to be renamed once rename unblo...
unsigned commitToRenameDelay
Delay between commit and rename, in ticks.
void removeFromHistory(InstSeqNum inst_seq_num, ThreadID tid)
Removes a committed instruction's rename history.
RenameStats(statistics::Group *parent)
UnifiedFreeList * freeList
Free list interface.
TimeBuffer< RenameStruct > * renameQueue
Rename instruction queue.
void setScoreboard(Scoreboard *_scoreboard)
Sets pointer to the scoreboard.
statistics::Scalar renamedInsts
Stat for total number of renamed instructions.
statistics::Scalar vecPredLookups
std::list< RenameHistory > historyBuffer[MaxThreads]
A per-thread list of all destination register renames, used to either undo rename mappings or free ol...
bool block(ThreadID tid)
Switches rename to blocking, and signals back that rename has become blocked.
bool unblock(ThreadID tid)
Switches rename to unblocking if the skid buffer is empty, and signals back that rename has unblocked...
TimeBuffer< TimeStruct > * timeBuffer
Pointer to main time buffer used for backwards communication.
void renameDestRegs(const DynInstPtr &inst, ThreadID tid)
Renames the destination registers of an instruction.
ThreadStatus
Individual thread status.
ProbePointArg< SeqNumRegPair > * ppSquashInRename
To probe when an instruction is squashed and the register mapping for it needs to be undone.
FreeList class that simply holds the list of free integer and floating point registers.
statistics::Scalar fpLookups
Implements a simple scoreboard to track which registers are ready.
ThreadID numThreads
The number of threads active in rename.
bool skidsEmpty()
Returns if all of the skid buffers are empty.
statistics::Scalar SQFullEvents
Stat for total number of times that the SQ starts a stall in rename.
void sortInsts()
Separates instructions from decode into individual lists of instructions sorted by thread.
unsigned skidBufferMax
The maximum skid buffer size.
statistics::Scalar undoneMaps
Stat for total number of mappings that were undone due to a squash.
RenameHistory(InstSeqNum _instSeqNum, const RegId &_archReg, PhysRegIdPtr _newPhysReg, PhysRegIdPtr _prevPhysReg)
statistics::Scalar serializeStallCycles
Stat for total number of cycles spent stalling for a serializing inst.
statistics::Scalar skidInsts
Number of instructions inserted into skid buffers.
statistics::Scalar unblockCycles
Stat for total number of cycles spent unblocking.
int calcFreeLQEntries(ThreadID tid)
Calculates the number of free LQ entries for a specific thread.
statistics::Scalar serializing
Number of serialize instructions handled.
TimeBuffer< DecodeStruct > * decodeQueue
Decode instruction queue interface.
void rename(bool &status_change, ThreadID tid)
Determines what to do based on rename's current status.
void clearStates(ThreadID tid)
Clear all thread-specific states.
void renameSrcRegs(const DynInstPtr &inst, ThreadID tid)
Renames the source registers of an instruction.
unsigned renameWidth
Rename width, in instructions.
Scoreboard * scoreboard
Pointer to the scoreboard.
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.
Stalls stalls[MaxThreads]
Tracks which stages are telling decode to stall.
InstSeqNum instSeqNum
The sequence number of the instruction that renamed.
std::string name() const
Returns the name of rename.
void updateStatus()
Updates overall rename status based on all of the threads' statuses.
statistics::Scalar idleCycles
Stat for total number of cycles spent idle.
TimeBuffer< DecodeStruct >::wire fromDecode
Wire to get decode's output from decode queue.
ProbePointArg< DynInstPtr > * ppRename
To probe when register renaming for an instruction is complete.
statistics::Scalar tempSerializing
Number of instructions marked as temporarily serializing.
IEW handles both single threaded and SMT IEW (issue/execute/writeback).
void doSquash(const InstSeqNum &squash_seq_num, ThreadID tid)
Executes actual squash, removing squashed instructions.
bool checkStall(ThreadID tid)
Checks if any stages are telling rename to block.
void resetStage()
Reset this pipeline stage.
Holds the information for each destination register rename.
InstQueue insts[MaxThreads]
Queue of all instructions coming from decode this cycle.
int calcFreeIQEntries(ThreadID tid)
Calculates the number of free IQ entries for a specific thread.
int loadsInProgress[MaxThreads]
Count of Load instructions in progress that have been sent off to the IQ and ROB, but are not yet inc...
RegId archReg
The architectural register index that was renamed.
statistics::Scalar lookups
Stat for total number of source register rename lookups.
unsigned toIEWIndex
The index of the instruction in the time buffer to IEW that rename is currently using.
UnifiedRenameMap * renameMap[MaxThreads]
Rename map interface.
statistics::Scalar fullRegistersEvents
Stat for total number of times that rename runs out of free registers to use to rename.
statistics::Scalar renamedOperands
Stat for total number of renamed destination registers.
PhysRegIdPtr prevPhysReg
The old physical register that the arch.
Source of possible stalls.
statistics::Scalar IQFullEvents
Stat for total number of times that the IQ starts a stall in rename.
void setTimeBuffer(TimeBuffer< TimeStruct > *tb_ptr)
Sets the main backwards communication time buffer pointer.
ProbePointArg generates a point for the class of Arg.
void serializeAfter(InstQueue &inst_list, ThreadID tid)
Either serializes on the next instruction available in the InstQueue, or records that it must seriali...
static constexpr int MaxThreads
Rename(CPU *_cpu, const O3CPUParams ¶ms)
Rename constructor.
Rename handles both single threaded and SMT rename.
int iewToRenameDelay
Delay between iew and rename, in ticks.
gem5::o3::Rename::RenameStats stats
statistics::Scalar ROBFullEvents
Stat for total number of times that the ROB starts a stall in rename.
void incrFullStat(const FullSource &source)
Function used to increment the stat that corresponds to the source of the stall.
int calcFreeSQEntries(ThreadID tid)
Calculates the number of free SQ entries for a specific thread.
statistics::Scalar vecLookups
void setDecodeQueue(TimeBuffer< DecodeStruct > *dq_ptr)
Sets pointer to time buffer coming from decode.
TimeBuffer< TimeStruct >::wire fromCommit
Wire to get commit's output from backwards time buffer.
bool emptyROB[MaxThreads]
Records if the ROB is empty.
void setCommitStage(Commit *commit_stage)
Sets pointer to commit stage.
bool checkSignalsAndUpdate(ThreadID tid)
Checks the signals and updates the status.
Structures whose free entries impact the amount of instructions that can be renamed.
void startupStage()
Initializes variables for the stage.
std::deque< DynInstPtr > InstQueue
void setFreeList(UnifiedFreeList *fl_ptr)
Sets pointer to the free list.
statistics::Scalar committedMaps
Stat for total number of committed renaming mappings.
void setIEWStage(IEW *iew_stage)
Sets pointer to IEW stage.
bool blockThisCycle
Whether or not rename needs to block this cycle.
FullSource
Enum to record the source of a structure full stall.
TimeBuffer< TimeStruct >::wire fromIEW
Wire to get IEW's output from backwards time buffer.
void readStallSignals(ThreadID tid)
Reads signals telling rename to block/unblock.
void regProbePoints()
Registers probes.
DynInstPtr serializeInst[MaxThreads]
The serialize instruction that rename has stalled on.
void renameInsts(ThreadID tid)
Renames instructions for the given thread.
statistics::Scalar squashedInsts
Stat for total number of squashed instructions that rename discards.
statistics::Scalar squashCycles
Stat for total number of cycles spent squashing.
TimeBuffer< TimeStruct >::wire toDecode
Wire to write infromation heading to previous stages.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
RenameStatus
Overall rename status.
void takeOverFrom()
Takes over from another CPU's thread.
std::list< ThreadID > * activeThreads
Pointer to the list of active threads.
statistics::Scalar LQFullEvents
Stat for total number of times that the LQ starts a stall in rename.
statistics::Scalar intLookups
TimeBuffer< RenameStruct >::wire toIEW
Wire to write any information heading to IEW.
ThreadStatus renameStatus[MaxThreads]
Per-thread status.
bool resumeUnblocking
Whether or not rename needs to resume clearing out the skidbuffer after squashing.
void readFreeEntries(ThreadID tid)
Gets the number of free entries for a specific thread.
std::pair< InstSeqNum, PhysRegIdPtr > SeqNumRegPair
Probe points.
int16_t ThreadID
Thread index/ID type.
Commit * commit_ptr
Pointer to commit stage.
Register ID: describe an architectural register with its class and index.
InstQueue skidBuffer[MaxThreads]
Skid buffer between rename and decode.
void setActiveThreads(std::list< ThreadID > *at_ptr)
Sets pointer to list of active threads.
Unified register rename map for all classes of registers.
Generated on Wed Jul 28 2021 12:10:24 for gem5 by doxygen 1.8.17