53 unsigned _numPhysicalFloatRegs,
54 unsigned _numPhysicalVecRegs,
55 unsigned _numPhysicalVecPredRegs,
56 unsigned _numPhysicalMatRegs,
57 unsigned _numPhysicalCCRegs,
59 : intRegFile(*reg_classes.
at(
IntRegClass), _numPhysicalIntRegs),
61 vectorRegFile(*reg_classes.
at(
VecRegClass), _numPhysicalVecRegs),
62 vectorElemRegFile(*reg_classes.
at(
VecElemClass), _numPhysicalVecRegs * (
66 _numPhysicalVecPredRegs),
67 matRegFile(*reg_classes.
at(
MatRegClass), _numPhysicalMatRegs),
68 ccRegFile(*reg_classes.
at(
CCRegClass), _numPhysicalCCRegs),
69 numPhysicalIntRegs(_numPhysicalIntRegs),
70 numPhysicalFloatRegs(_numPhysicalFloatRegs),
71 numPhysicalVecRegs(_numPhysicalVecRegs),
72 numPhysicalVecElemRegs(_numPhysicalVecRegs * (
75 numPhysicalVecPredRegs(_numPhysicalVecPredRegs),
76 numPhysicalMatRegs(_numPhysicalMatRegs),
77 numPhysicalCCRegs(_numPhysicalCCRegs),
78 totalNumRegs(_numPhysicalIntRegs
79 + _numPhysicalFloatRegs
81 + numPhysicalVecElemRegs
82 + _numPhysicalVecPredRegs
92 phys_reg, flat_reg_idx++);
99 phys_reg, flat_reg_idx++);
137 for (phys_reg = 0; phys_reg < reg_classes.at(
MiscRegClass)->numRegs();
std::vector< PhysRegId > vecElemIds
std::vector< PhysRegId > ccRegIds
std::vector< PhysRegId > miscRegIds
Misc Reg Ids.
unsigned numPhysicalVecRegs
Number of physical vector registers.
unsigned numPhysicalCCRegs
Number of physical CC registers.
unsigned numPhysicalMatRegs
Number of physical matrix registers.
unsigned numPhysicalVecPredRegs
Number of physical predicate registers.
PhysRegFile(unsigned _numPhysicalIntRegs, unsigned _numPhysicalFloatRegs, unsigned _numPhysicalVecRegs, unsigned _numPhysicalVecPredRegs, unsigned _numPhysicalMatRegs, unsigned _numPhysicalCCRegs, const BaseISA::RegClasses &classes)
Constructs a physical register file with the specified amount of integer and floating point registers...
std::vector< PhysRegId > floatRegIds
std::vector< PhysRegId > vecRegIds
unsigned numPhysicalVecElemRegs
Number of physical vector element registers.
unsigned numPhysicalFloatRegs
Number of physical floating point registers.
std::vector< PhysRegId > matRegIds
std::vector< PhysRegId > intRegIds
std::vector< PhysRegId > vecPredRegIds
unsigned numPhysicalIntRegs
Number of physical general purpose registers.
void initFreeList(UnifiedFreeList *freeList)
Initialize the free list.
FreeList class that simply holds the list of free integer and floating point registers.
void addRegs(InputIt first, InputIt last)
Adds a register back to the free list.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
@ MatRegClass
Matrix Register.
@ FloatRegClass
Floating-point register.
@ CCRegClass
Condition-code register.
@ VecRegClass
Vector Register.
@ IntRegClass
Integer register.
@ MiscRegClass
Control (misc) register.
@ VecElemClass
Vector Register Native Elem lane.