Go to the documentation of this file.
42 #ifndef __CPU_O3_RENAME_MAP_HH__
43 #define __CPU_O3_RENAME_MAP_HH__
248 panic(
"rename rename(): unknown reg class %s\n",
288 panic(
"rename lookup(): unknown reg class %s\n",
329 assert(phys_reg ==
lookup(arch_reg));
333 panic(
"rename setEntry(): unknown reg class %s\n",
369 canRename(uint32_t intRegs, uint32_t floatRegs, uint32_t vectorRegs,
370 uint32_t vecElemRegs, uint32_t vecPredRegs,
371 uint32_t ccRegs)
const
385 #endif //__CPU_O3_RENAME_MAP_HH__
unsigned numFreePredEntries() const
RegId zeroReg
The architectural index of the zero register.
SimpleRenameMap::RenameInfo RenameInfo
@ 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).
bool canRename(uint32_t intRegs, uint32_t floatRegs, uint32_t vectorRegs, uint32_t vecElemRegs, uint32_t vecPredRegs, uint32_t ccRegs) const
Return whether there are enough registers to serve the request.
@ CCRegClass
Condition-code register.
const_iterator begin() const
const_iterator end() const
unsigned numFreeEntries() const
Return the number of free entries on the associated free list.
SimpleFreeList * freeList
Pointer to the free list from which new physical registers should be allocated in rename()
iterator end()
Forward end/cend to the map.
Arch2PhysMap::iterator iterator
FreeList class that simply holds the list of free integer and floating point registers.
SimpleRenameMap intMap
The integer register rename map.
unsigned numFreeFloatEntries() const
unsigned numFreeRegs() const
Return the number of free registers on the list.
SimpleRenameMap vecElemMap
The vector element register rename map.
SimpleRenameMap predMap
The predicate register rename map.
@ FloatRegClass
Floating-point register.
SimpleRenameMap ccMap
The condition-code register rename map.
iterator begin()
Forward begin/cbegin to the map.
unsigned numFreeVecElemEntries() const
Simple physical register file class.
unsigned numFreeIntEntries() const
const_iterator cend() const
SimpleRenameMap vecMap
The vector register rename map.
PhysRegIdPtr lookup(const RegId &arch_reg) const
Look up the physical register mapped to an architectural register.
size_t numArchRegs() const
UnifiedRenameMap()
Default constructor.
~UnifiedRenameMap()
Destructor.
const char * className() const
Return a const char* with the register class name.
RegClassType classValue() const
Class accessor.
RenameInfo rename(const RegId &arch_reg)
Tell rename map to get a new free physical register to remap the specified architectural register.
unsigned numFreeCCEntries() const
SimpleRenameMap floatMap
The floating-point register rename map.
std::pair< PhysRegIdPtr, PhysRegIdPtr > RenameInfo
Pair of a physical register and a physical register.
@ IntRegClass
Integer register.
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 ...
unsigned numFreeEntries() const
Return the minimum number of free entries across all of the register classes.
@ MiscRegClass
Control (misc) register.
PhysRegIdPtr getMiscRegId(RegIndex reg_idx)
Gets a misc register PhysRegIdPtr.
bool is(RegClassType reg_class) const
PhysRegIdPtr lookup(const RegId &arch_reg) const
Look up the physical register mapped to an architectural register.
unsigned numFreeVecEntries() const
const_iterator cbegin() const
@ VecRegClass
Vector Register.
void setEntry(const RegId &arch_reg, PhysRegIdPtr phys_reg)
Update rename map with a specific mapping.
Arch2PhysMap::const_iterator const_iterator
Register rename map for a single class of registers (e.g., integer or floating point).
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.
RenameInfo rename(const RegId &arch_reg)
Tell rename map to get a new free physical register to remap the specified architectural register.
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.
#define panic(...)
This implements a cprintf based panic() function.
void setEntry(const RegId &arch_reg, PhysRegIdPtr phys_reg)
Update rename map with a specific mapping.
Unified register rename map for all classes of registers.
Generated on Tue Dec 21 2021 11:34:26 for gem5 by doxygen 1.8.17