Go to the documentation of this file.
41 #ifndef __CPU__REG_CLASS_HH__
42 #define __CPU__REG_CLASS_HH__
48 #include "arch/vecregs.hh"
50 #include "config/the_isa.hh"
138 "Creating vector physical index w/o element index");
141 "Creating non-vector physical index w/ element index");
199 panic(
"Trying to flatten a register without class!");
246 :
RegId(_regClass, _regIdx, elem_idx),
flatIdx(flat_idx),
309 pinned = (numWrites != 0);
347 const size_t flat_index =
static_cast<size_t>(reg_id.
flatIndex());
348 const size_t class_num =
static_cast<size_t>(reg_id.
regClass);
350 const size_t shifted_class_num =
355 const size_t concatenated_hash = flat_index | shifted_class_num;
361 "sizeof(RegIndex) should be less than sizeof(size_t)");
363 return concatenated_hash;
368 #endif // __CPU__REG_CLASS_HH__
constexpr unsigned NumVecElemPerVecReg
static PhysRegId elemId(PhysRegId *vid, ElemIndex elem)
int getNumPinnedWrites() const
size_t operator()(const gem5::RegId ®_id) const
@ VecElemClass
Vector Register Native Elem lane.
RegIndex flatIndex() const
Index flattening.
@ CCRegClass
Condition-code register.
int getNumPinnedWrites() const
PhysRegId(RegClassType _regClass, RegIndex _regIdx, ElemIndex elem_idx, RegIndex flat_idx)
Vector PhysRegId constructor (w/ elemIndex).
friend std::ostream & operator<<(std::ostream &os, const RegId &rid)
bool operator!=(const RegId &that) const
bool is(RegClassType reg_class) const
RegIndex index() const
Index accessors.
void decrNumPinnedWritesToComplete()
RegClass(size_t new_size, RegClassOps &new_ops, RegIndex new_zero=-1)
std::string regName(const RegId &id) const
@ FloatRegClass
Floating-point register.
void decrNumPinnedWrites()
void setNumPinnedWrites(int num_writes)
const RegIndex & flatIndex() const
Flat index accessor.
bool operator==(const RegId &that) const
bool isRenameable() const
Return true if this register can be renamed.
void incrNumPinnedWritesToComplete()
bool operator!=(const PhysRegId &that) const
static const char * regClassStrings[]
virtual std::string regName(const RegId &id) const =0
int getNumPinnedWritesToComplete() const
const char * className() const
Return a const char* with the register class name.
RegClassType classValue() const
Class accessor.
int numPinnedWritesToComplete
uint16_t ElemIndex
Logical vector register elem index type.
bool operator<(const RegId &that) const
Order operator.
static DefaultRegClassOps defaultOps
bool operator<(const PhysRegId &that) const
Explicit forward methods, to prevent comparisons of PhysRegId with RegIds.
@ IntRegClass
Integer register.
RegIndex elemIndex() const
Elem accessor.
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
RegClassType
Enumerate the classes of registers.
@ MiscRegClass
Control (misc) register.
Overload hash function for BasicBlockRange type.
bool is(RegClassType reg_class) const
void incrNumPinnedWrites()
RegClass(size_t new_size, RegIndex new_zero=-1)
RegId(RegClassType reg_class, RegIndex reg_idx)
void setNumPinnedWrites(int numWrites)
void setNumPinnedWritesToComplete(int numWrites)
PhysRegId(RegClassType _regClass, RegIndex _regIdx, RegIndex _flatIdx)
Scalar PhysRegId constructor.
bool isFixedMapping() const
Returns true if this register is always associated to the same architectural register.
@ VecRegClass
Vector Register.
RegId(RegClassType reg_class, RegIndex reg_idx, ElemIndex elem_idx)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
static constexpr size_t Scale
std::string regName(const RegId &id) const override
RegIndex index() const
Visible RegId methods.
static const ElemIndex IllegalElemIndex
ElemIndex value that indicates that the register is not a vector.
bool operator==(const PhysRegId &that) const
Register ID: describe an architectural register with its class and index.
#define panic(...)
This implements a cprintf based panic() function.
Generated on Tue Dec 21 2021 11:34:27 for gem5 by doxygen 1.8.17