Go to the documentation of this file.
46 #include "arch/vecregs.hh"
48 #include "debug/Rename.hh"
83 renamed_reg = prev_reg;
90 renamed_reg = prev_reg;
100 DPRINTF(
Rename,
"Renamed reg %d to physical reg %d (%d) old mapping was"
RegId zeroReg
The architectural index of the zero register.
int getNumPinnedWrites() const
@ VecElemClass
Vector Register Native Elem lane.
RegIndex flatIndex() const
Index flattening.
Free list for a single class of registers (e.g., integer or floating point).
@ CCRegClass
Condition-code register.
int getNumPinnedWrites() const
SimpleFreeList * freeList
Pointer to the free list from which new physical registers should be allocated in rename()
FreeList class that simply holds the list of free integer and floating point registers.
SimpleRenameMap intMap
The integer register rename map.
SimpleFreeList vecElemList
The list of free vector element registers.
RegIndex index() const
Index accessors.
SimpleRenameMap vecElemMap
The vector element register rename map.
SimpleFreeList floatList
The list of free floating point registers.
SimpleRenameMap predMap
The predicate register rename map.
@ FloatRegClass
Floating-point register.
void decrNumPinnedWrites()
const RegIndex & flatIndex() const
Flat index accessor.
SimpleFreeList predList
The list of free predicate registers.
SimpleRenameMap ccMap
The condition-code register rename map.
Simple physical register file class.
SimpleRenameMap vecMap
The vector register rename map.
RenameInfo rename(const RegId &arch_reg)
Tell rename map to get a new free physical register to remap the specified architectural register.
SimpleRenameMap floatMap
The floating-point register rename map.
std::pair< PhysRegIdPtr, PhysRegIdPtr > RenameInfo
Pair of a physical register and a physical register.
PhysRegIdPtr getReg()
Get the next available register from the free list.
@ IntRegClass
Integer register.
Rename handles both single threaded and SMT rename.
void init(const RegClass ®_class, SimpleFreeList *_freeList)
Because we have an array of rename maps (one per thread) in the CPU, it's awkward to initialize this ...
SimpleFreeList ccList
The list of free condition-code registers.
void setNumPinnedWrites(int numWrites)
void setNumPinnedWritesToComplete(int numWrites)
@ VecRegClass
Vector Register.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
void init(const BaseISA::RegClasses ®Classes, PhysRegFile *_regFile, UnifiedFreeList *freeList)
Initializes rename map with given parameters.
SimpleFreeList intList
The list of free integer registers.
RegIndex index() const
Visible RegId methods.
Arch2PhysMap map
The acutal arch-to-phys register map.
PhysRegFile * regFile
The register file object is used only to get PhysRegIdPtr on MiscRegs, as they are stored in it.
Register ID: describe an architectural register with its class and index.
SimpleFreeList vecList
The following two are exclusive interfaces.
Generated on Tue Dec 21 2021 11:34:26 for gem5 by doxygen 1.8.17