Go to the documentation of this file.
42 #ifndef __CPU_O3_REGFILE_HH__
43 #define __CPU_O3_REGFILE_HH__
48 #include "arch/vecregs.hh"
50 #include "config/the_isa.hh"
52 #include "debug/IEW.hh"
60 class UnifiedFreeList;
141 unsigned _numPhysicalFloatRegs,
142 unsigned _numPhysicalVecRegs,
143 unsigned _numPhysicalVecPredRegs,
144 unsigned _numPhysicalCCRegs,
185 DPRINTF(
IEW,
"RegFile: Access to int register %i, has data "
197 DPRINTF(
IEW,
"RegFile: Access to float register %i as int, "
198 "has data %#x\n", phys_reg->
index(), floatRegBits);
209 DPRINTF(
IEW,
"RegFile: Access to vector register %i, has "
210 "data %s\n",
int(phys_reg->
index()),
232 DPRINTF(
IEW,
"RegFile: Access to element %d of vector register %i,"
233 " has data %#x\n", phys_reg->
elemIndex(),
245 DPRINTF(
IEW,
"RegFile: Access to predicate register %i, has "
246 "data %s\n",
int(phys_reg->
index()),
266 DPRINTF(
IEW,
"RegFile: Access to cc register %i, has "
267 "data %#x\n", phys_reg->
index(),
279 DPRINTF(
IEW,
"RegFile: Setting int register %i to %#x\n",
291 DPRINTF(
IEW,
"RegFile: Setting float register %i to %#x\n",
303 DPRINTF(
IEW,
"RegFile: Setting vector register %i to %s\n",
315 DPRINTF(
IEW,
"RegFile: Setting element %d of vector register %i to"
329 DPRINTF(
IEW,
"RegFile: Setting predicate register %i to %s\n",
341 DPRINTF(
IEW,
"RegFile: Setting cc register %i to %#x\n",
365 #endif //__CPU_O3_REGFILE_HH__
void setCCReg(PhysRegIdPtr phys_reg, RegVal val)
Sets a condition-code register to the given value.
constexpr unsigned NumVecElemPerVecReg
TheISA::VecRegContainer & getWritableVecReg(PhysRegIdPtr phys_reg)
Reads a vector register for modification.
void setVecElem(PhysRegIdPtr phys_reg, RegVal val)
Sets a vector register to the given value.
const TheISA::VecRegContainer & readVecReg(PhysRegIdPtr phys_reg) const
Reads a vector register.
VecPredReg::Container VecPredRegContainer
unsigned numPhysicalVecElemRegs
Number of physical vector element registers.
void setVecPredReg(PhysRegIdPtr phys_reg, const TheISA::VecPredRegContainer &val)
Sets a predicate register to the given value.
@ VecElemClass
Vector Register Native Elem lane.
unsigned numIntPhysRegs() const
RegVal readFloatReg(PhysRegIdPtr phys_reg) const
IdRange getRegIds(RegClassType cls)
Get the PhysRegIds of the elems of all vector registers.
std::vector< RegVal > intRegFile
Integer register file.
RegVal readIntReg(PhysRegIdPtr phys_reg) const
Reads an integer register.
@ CCRegClass
Condition-code register.
unsigned numFloatPhysRegs() const
FreeList class that simply holds the list of free integer and floating point registers.
std::vector< PhysRegId > ccRegIds
TheISA::VecPredRegContainer & getWritableVecPredReg(PhysRegIdPtr phys_reg)
RegIndex index() const
Index accessors.
PhysRegIdPtr getTrueId(PhysRegIdPtr reg)
Get the true physical register id.
unsigned numPhysicalVecRegs
Number of physical vector registers.
unsigned numCCPhysRegs() const
std::vector< PhysRegId > floatRegIds
@ FloatRegClass
Floating-point register.
std::vector< PhysRegId > miscRegIds
Misc Reg Ids.
std::vector< PhysRegId > vecElemIds
RegVal readVecElem(PhysRegIdPtr phys_reg) const
Reads a vector element.
Simple physical register file class.
unsigned numPredPhysRegs() const
IEW handles both single threaded and SMT IEW (issue/execute/writeback).
std::vector< PhysRegId > vecRegIds
gem5::VecRegContainer< NumVecElemPerVecReg *sizeof(VecElem)> VecRegContainer
std::pair< PhysIds::iterator, PhysIds::iterator > IdRange
std::vector< PhysRegId > intRegIds
std::vector< TheISA::VecPredRegContainer > vecPredRegFile
Predicate register file.
std::vector< TheISA::VecRegContainer > vectorRegFile
Vector register file.
unsigned numPhysicalIntRegs
Number of physical general purpose registers.
unsigned numVecPhysRegs() const
~PhysRegFile()
Destructor to free resources.
unsigned numPhysicalVecPredRegs
Number of physical predicate registers.
@ IntRegClass
Integer register.
RegIndex elemIndex() const
Elem accessor.
RegClassType
Enumerate the classes of registers.
PhysRegFile(unsigned _numPhysicalIntRegs, unsigned _numPhysicalFloatRegs, unsigned _numPhysicalVecRegs, unsigned _numPhysicalVecPredRegs, unsigned _numPhysicalCCRegs, const BaseISA::RegClasses ®Classes)
Constructs a physical register file with the specified amount of integer and floating point registers...
PhysRegIdPtr getMiscRegId(RegIndex reg_idx)
Gets a misc register PhysRegIdPtr.
std::vector< RegVal > floatRegFile
Floating point register file.
unsigned totalNumRegs
Total number of physical registers.
unsigned numPhysicalCCRegs
Number of physical CC registers.
bool is(RegClassType reg_class) const
const TheISA::VecPredRegContainer & readVecPredReg(PhysRegIdPtr phys_reg) const
Reads a predicate register.
void initFreeList(UnifiedFreeList *freeList)
Initialize the free list.
std::vector< PhysRegId > vecPredRegIds
void setFloatReg(PhysRegIdPtr phys_reg, RegVal val)
void setIntReg(PhysRegIdPtr phys_reg, RegVal val)
Sets an integer register to the given value.
std::vector< RegVal > ccRegFile
Condition-code register file.
unsigned numPhysicalFloatRegs
Number of physical floating point registers.
@ VecRegClass
Vector Register.
void setVecReg(PhysRegIdPtr phys_reg, const TheISA::VecRegContainer &val)
Sets a vector register to the given value.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
RegVal readCCReg(PhysRegIdPtr phys_reg)
Reads a condition-code register.
std::vector< RegVal > vectorElemRegFile
Vector element register file.
RegIndex index() const
Visible RegId methods.
unsigned numVecElemPhysRegs() const
Register ID: describe an architectural register with its class and index.
unsigned totalNumPhysRegs() const
Generated on Tue Dec 21 2021 11:34:26 for gem5 by doxygen 1.8.17