Go to the documentation of this file.
42 #ifndef __CPU_O3_REGFILE_HH__
43 #define __CPU_O3_REGFILE_HH__
49 #include "arch/vecregs.hh"
51 #include "config/the_isa.hh"
54 #include "debug/IEW.hh"
62 class UnifiedFreeList;
142 unsigned _numPhysicalFloatRegs,
143 unsigned _numPhysicalVecRegs,
144 unsigned _numPhysicalVecPredRegs,
145 unsigned _numPhysicalCCRegs,
174 DPRINTF(
IEW,
"RegFile: Access to int register %i, has data %#x\n",
179 DPRINTF(
IEW,
"RegFile: Access to float register %i has data %#x\n",
184 DPRINTF(
IEW,
"RegFile: Access to vector element register %i "
185 "has data %#x\n", idx,
val);
189 DPRINTF(
IEW,
"RegFile: Access to cc register %i has data %#x\n",
193 panic(
"Unsupported register class type %d.",
type);
212 DPRINTF(
IEW,
"RegFile: Access to vector register %i, has "
220 DPRINTF(
IEW,
"RegFile: Access to predicate register %i, has "
227 panic(
"Unrecognized register class type %d.",
type);
243 panic(
"Unrecognized register class type %d.",
type);
258 DPRINTF(
IEW,
"RegFile: Setting int register %i to %#x\n",
263 DPRINTF(
IEW,
"RegFile: Setting float register %i to %#x\n",
268 DPRINTF(
IEW,
"RegFile: Setting vector element register %i to "
273 DPRINTF(
IEW,
"RegFile: Setting cc register %i to %#x\n",
277 panic(
"Unsupported register class type %d.",
type);
295 DPRINTF(
IEW,
"RegFile: Setting vector register %i to %s\n",
303 DPRINTF(
IEW,
"RegFile: Setting predicate register %i to %s\n",
311 panic(
"Unrecognized register class type %d.",
type);
333 #endif //__CPU_O3_REGFILE_HH__
unsigned numPhysicalVecElemRegs
Number of physical vector element registers.
RegFile vectorElemRegFile
Vector element register file.
@ VecElemClass
Vector Register Native Elem lane.
RegFile ccRegFile
Condition-code register file.
IdRange getRegIds(RegClassType cls)
Get the PhysRegIds of the elems of all vector registers.
@ CCRegClass
Condition-code register.
void * getWritableReg(PhysRegIdPtr phys_reg)
void get(size_t idx, void *val) const
std::string valString(const void *val) const
void setReg(PhysRegIdPtr phys_reg, RegVal val)
FreeList class that simply holds the list of free integer and floating point registers.
std::vector< PhysRegId > ccRegIds
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 getTrueId(PhysRegIdPtr reg)
Get the true physical register id.
unsigned numPhysicalVecRegs
Number of physical vector registers.
std::vector< PhysRegId > floatRegIds
@ FloatRegClass
Floating-point register.
std::vector< PhysRegId > miscRegIds
Misc Reg Ids.
std::vector< PhysRegId > vecElemIds
void setReg(PhysRegIdPtr phys_reg, const void *val)
Simple physical register file class.
RegVal getReg(PhysRegIdPtr phys_reg) const
IEW handles both single threaded and SMT IEW (issue/execute/writeback).
RegFile vectorRegFile
Vector register file.
std::vector< PhysRegId > vecRegIds
std::pair< PhysIds::iterator, PhysIds::iterator > IdRange
const RegClass & regClass
std::vector< PhysRegId > intRegIds
unsigned numPhysicalIntRegs
Number of physical general purpose registers.
~PhysRegFile()
Destructor to free resources.
unsigned numPhysicalVecPredRegs
Number of physical predicate registers.
void getReg(PhysRegIdPtr phys_reg, void *val) const
@ IntRegClass
Integer register.
RegClassType
Enumerate the classes of registers.
PhysRegIdPtr getMiscRegId(RegIndex reg_idx)
Gets a misc register PhysRegIdPtr.
unsigned totalNumRegs
Total number of physical registers.
unsigned numPhysicalCCRegs
Number of physical CC registers.
void initFreeList(UnifiedFreeList *freeList)
Initialize the free list.
std::vector< PhysRegId > vecPredRegIds
void set(size_t idx, const void *val)
constexpr RegIndex index() const
Visible RegId methods.
unsigned numPhysicalFloatRegs
Number of physical floating point registers.
@ VecRegClass
Vector Register.
RegFile vecPredRegFile
Predicate register file.
RegFile floatRegFile
Floating point register file.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
constexpr RegClassType classValue() const
Class accessor.
RegFile intRegFile
Integer register file.
#define panic(...)
This implements a cprintf based panic() function.
unsigned totalNumPhysRegs() const
Generated on Wed Jul 13 2022 10:39:16 for gem5 by doxygen 1.8.17