Go to the documentation of this file.
55 unsigned _numPhysicalFloatRegs,
56 unsigned _numPhysicalVecRegs,
57 unsigned _numPhysicalVecPredRegs,
58 unsigned _numPhysicalCCRegs,
61 : intRegFile(_numPhysicalIntRegs),
62 floatRegFile(_numPhysicalFloatRegs),
63 vectorRegFile(_numPhysicalVecRegs),
64 vecPredRegFile(_numPhysicalVecPredRegs),
65 ccRegFile(_numPhysicalCCRegs),
66 numPhysicalIntRegs(_numPhysicalIntRegs),
67 numPhysicalFloatRegs(_numPhysicalFloatRegs),
68 numPhysicalVecRegs(_numPhysicalVecRegs),
69 numPhysicalVecElemRegs(_numPhysicalVecRegs *
71 numPhysicalVecPredRegs(_numPhysicalVecPredRegs),
72 numPhysicalCCRegs(_numPhysicalCCRegs),
73 totalNumRegs(_numPhysicalIntRegs
74 + _numPhysicalFloatRegs
77 + _numPhysicalVecPredRegs
78 + _numPhysicalCCRegs),
110 eIdx, flat_reg_idx++);
127 for (phys_reg = 0; phys_reg < regClasses.at(
MiscRegClass).size();
160 elemIdx].
index() == reg_idx);
162 elemIdx].elemIndex() == elemIdx);
192 "Trying to get elems of a %s register",
reg->className());
193 auto idx =
reg->index();
194 return std::make_pair(
220 return std::make_pair(PhysIds::iterator(),
221 PhysIds::iterator());
227 switch (
reg->classValue()) {
235 "Trying to get the register of a %s register",
reg->className());
constexpr unsigned NumVecElemPerVecReg
@ VecElemClass
Vector Register Native Elem lane.
@ CCRegClass
Condition-code register.
RegClass
Enumerate the classes of registers.
PhysRegFile(unsigned _numPhysicalIntRegs, unsigned _numPhysicalFloatRegs, unsigned _numPhysicalVecRegs, unsigned _numPhysicalVecPredRegs, unsigned _numPhysicalCCRegs, const BaseISA::RegClasses ®Classes, VecMode vmode)
Constructs a physical register file with the specified amount of integer and floating point registers...
@ FloatRegClass
Floating-point register.
@ MiscRegClass
Control (misc) register.
FreeList class that simply holds the list of free integer and floating point registers.
std::vector< PhysRegId > ccRegIds
IdRange getRegIds(RegClass cls)
Get the PhysRegIds of the elems of all vector registers.
PhysRegIdPtr getTrueId(PhysRegIdPtr reg)
Get the true physical register id.
unsigned numPhysicalVecRegs
Number of physical vector registers.
std::vector< PhysRegId > floatRegIds
std::vector< PhysRegId > miscRegIds
Misc Reg Ids.
std::vector< PhysRegId > vecElemIds
std::vector< PhysRegId > vecRegIds
void addRegs(InputIt first, InputIt last)
Adds a register back to the free list.
VecMode vecMode
Mode in which vector registers are addressed.
std::vector< PhysRegId > intRegIds
uint16_t ElemIndex
Logical vector register elem index type.
std::vector< TheISA::VecRegContainer > vectorRegFile
Vector register file.
unsigned numPhysicalIntRegs
Number of physical general purpose registers.
unsigned numPhysicalVecPredRegs
Number of physical predicate registers.
IdRange getRegElemIds(PhysRegIdPtr reg)
Get the PhysRegIds of the elems of a vector register.
@ VecRegClass
Vector Register.
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
unsigned numPhysicalCCRegs
Number of physical CC registers.
void initFreeList(UnifiedFreeList *freeList)
Initialize the free list.
std::vector< PhysRegId > vecPredRegIds
enums::VecRegRenameMode VecMode
unsigned numPhysicalFloatRegs
Number of physical floating point registers.
@ IntRegClass
Integer register.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Register ID: describe an architectural register with its class and index.
Generated on Wed Jul 28 2021 12:10:24 for gem5 by doxygen 1.8.17