gem5
v20.0.0.3
|
Physical register ID. More...
#include <reg_class.hh>
Public Member Functions | |
PhysRegId () | |
PhysRegId (RegClass _regClass, PhysRegIndex _regIdx, PhysRegIndex _flatIdx) | |
Scalar PhysRegId constructor. More... | |
PhysRegId (RegClass _regClass, PhysRegIndex _regIdx, ElemIndex elem_idx, PhysRegIndex flat_idx) | |
Vector PhysRegId constructor (w/ elemIndex). More... | |
bool | isIntPhysReg () const |
bool | isFloatPhysReg () const |
bool | isCCPhysReg () const |
true if it is a condition-code physical register. More... | |
bool | isVectorPhysReg () const |
true if it is a vector physical register. More... | |
bool | isVectorPhysElem () const |
true if it is a vector element physical register. More... | |
bool | isVecPredPhysReg () const |
bool | isMiscPhysReg () const |
true if it is a condition-code physical register. More... | |
bool | isFixedMapping () const |
Returns true if this register is always associated to the same architectural register. More... | |
const PhysRegIndex & | flatIndex () const |
Flat index accessor. More... | |
int | getNumPinnedWrites () const |
void | setNumPinnedWrites (int numWrites) |
void | decrNumPinnedWrites () |
void | incrNumPinnedWrites () |
bool | isPinned () const |
int | getNumPinnedWritesToComplete () const |
void | setNumPinnedWritesToComplete (int numWrites) |
void | decrNumPinnedWritesToComplete () |
void | incrNumPinnedWritesToComplete () |
bool | operator< (const PhysRegId &that) const |
Explicit forward methods, to prevent comparisons of PhysRegId with RegIds. More... | |
bool | operator== (const PhysRegId &that) const |
bool | operator!= (const PhysRegId &that) const |
Static Public Member Functions | |
static PhysRegId | elemId (PhysRegId *vid, ElemIndex elem) |
Private Attributes | |
PhysRegIndex | flatIdx |
int | numPinnedWritesToComplete |
bool | pinned |
![]() | |
RegClass | regClass |
RegIndex | regIdx |
ElemIndex | elemIdx |
int | numPinnedWrites |
Additional Inherited Members | |
![]() | |
RegId () | |
RegId (RegClass reg_class, RegIndex reg_idx) | |
RegId (RegClass reg_class, RegIndex reg_idx, ElemIndex elem_idx) | |
bool | operator== (const RegId &that) const |
bool | operator!= (const RegId &that) const |
bool | operator< (const RegId &that) const |
Order operator. More... | |
bool | isRenameable () const |
Return true if this register can be renamed. More... | |
bool | isZeroReg () const |
Check if this is the zero register. More... | |
bool | isIntReg () const |
bool | isFloatReg () const |
bool | isVecReg () const |
true if it is a condition-code physical register. More... | |
bool | isVecElem () const |
true if it is a condition-code physical register. More... | |
bool | isVecPredReg () const |
true if it is a predicate physical register. More... | |
bool | isCCReg () const |
true if it is a condition-code physical register. More... | |
bool | isMiscReg () const |
true if it is a condition-code physical register. More... | |
bool | isRenameable () |
Return true if this register can be renamed. More... | |
const RegIndex & | elemIndex () const |
Elem accessor. More... | |
const RegClass & | classValue () const |
Class accessor. More... | |
const char * | className () const |
Return a const char* with the register class name. More... | |
int | getNumPinnedWrites () const |
void | setNumPinnedWrites (int num_writes) |
const RegIndex & | index () const |
Index accessors. More... | |
RegIndex & | index () |
RegIndex | flatIndex () const |
Index flattening. More... | |
![]() | |
static const char * | regClassStrings [] |
static constexpr size_t | Scale = TheISA::NumVecElemPerVecReg |
Physical register ID.
Like a register ID but physical. The inheritance is private because the only relationship between this types is functional, and it is done to prevent code replication.
Definition at line 223 of file reg_class.hh.
|
inlineexplicit |
Definition at line 230 of file reg_class.hh.
|
inlineexplicit |
Scalar PhysRegId constructor.
Definition at line 235 of file reg_class.hh.
|
inlineexplicit |
Vector PhysRegId constructor (w/ elemIndex).
Definition at line 242 of file reg_class.hh.
References RegId::className(), RegId::classValue(), RegId::elemIndex(), RegId::index(), and RegId::isZeroReg().
|
inline |
Definition at line 327 of file reg_class.hh.
References RegId::numPinnedWrites.
Referenced by SimpleRenameMap::rename().
|
inline |
Definition at line 342 of file reg_class.hh.
Referenced by InstructionQueue< Impl >::wakeDependents().
Definition at line 307 of file reg_class.hh.
References RegId::index(), isVectorPhysReg(), and VecElemClass.
|
inline |
Flat index accessor.
Definition at line 305 of file reg_class.hh.
Referenced by InstructionQueue< Impl >::addToDependents(), InstructionQueue< Impl >::addToProducers(), InstructionQueue< Impl >::doSquash(), Scoreboard::getReg(), SimpleRenameMap::rename(), DefaultRename< Impl >::renameSrcRegs(), Scoreboard::setReg(), Scoreboard::unsetReg(), ElasticTrace::updateRegDep(), and InstructionQueue< Impl >::wakeDependents().
|
inline |
Definition at line 313 of file reg_class.hh.
References RegId::numPinnedWrites.
Referenced by SimpleRenameMap::rename().
|
inline |
Definition at line 332 of file reg_class.hh.
Referenced by InstructionQueue< Impl >::wakeDependents().
|
inline |
Definition at line 328 of file reg_class.hh.
References RegId::numPinnedWrites.
Referenced by BaseDynInst< Impl >::setSquashed().
|
inline |
Definition at line 343 of file reg_class.hh.
Referenced by BaseDynInst< Impl >::setSquashed().
|
inline |
true if it is a condition-code physical register.
Definition at line 281 of file reg_class.hh.
References RegId::isCCReg().
Referenced by PhysRegFile::readCCReg(), PhysRegFile::setCCReg(), and UnifiedRenameMap::setEntry().
|
inline |
Returns true if this register is always associated to the same architectural register.
Definition at line 299 of file reg_class.hh.
References RegId::isRenameable().
Referenced by InstructionQueue< Impl >::addToDependents(), InstructionQueue< Impl >::addToProducers(), InstructionQueue< Impl >::doSquash(), Scoreboard::getReg(), Scoreboard::setReg(), Scoreboard::unsetReg(), and InstructionQueue< Impl >::wakeDependents().
|
inline |
Definition at line 278 of file reg_class.hh.
References RegId::isFloatReg().
Referenced by PhysRegFile::readFloatReg(), UnifiedRenameMap::setEntry(), and PhysRegFile::setFloatReg().
|
inline |
Definition at line 275 of file reg_class.hh.
References RegId::isIntReg().
Referenced by PhysRegFile::readIntReg(), UnifiedRenameMap::setEntry(), and PhysRegFile::setIntReg().
|
inline |
true if it is a condition-code physical register.
Definition at line 293 of file reg_class.hh.
References RegId::isMiscReg().
|
inline |
Definition at line 330 of file reg_class.hh.
Referenced by BaseDynInst< Impl >::renameDestReg(), BaseDynInst< Impl >::setSquashed(), and InstructionQueue< Impl >::wakeDependents().
|
inline |
Definition at line 290 of file reg_class.hh.
References RegId::isVecPredReg().
Referenced by PhysRegFile::readVecPredReg(), UnifiedRenameMap::setEntry(), and PhysRegFile::setVecPredReg().
|
inline |
true if it is a vector element physical register.
Definition at line 287 of file reg_class.hh.
References RegId::isVecElem().
Referenced by PhysRegFile::getTrueId(), PhysRegFile::readVecElem(), UnifiedRenameMap::setEntry(), and PhysRegFile::setVecElem().
|
inline |
true if it is a vector physical register.
Definition at line 284 of file reg_class.hh.
References RegId::isVecReg().
Referenced by elemId(), PhysRegFile::readVecReg(), UnifiedRenameMap::setEntry(), PhysRegFile::setVecLane(), and PhysRegFile::setVecReg().
|
inline |
Definition at line 269 of file reg_class.hh.
References RegId::operator!=().
|
inline |
Explicit forward methods, to prevent comparisons of PhysRegId with RegIds.
Definition at line 261 of file reg_class.hh.
References RegId::operator<().
|
inline |
Definition at line 265 of file reg_class.hh.
References RegId::operator==().
|
inline |
Definition at line 315 of file reg_class.hh.
References RegId::numPinnedWrites.
Referenced by SimpleRenameMap::rename().
|
inline |
Definition at line 337 of file reg_class.hh.
Referenced by SimpleRenameMap::rename().
|
private |
Definition at line 225 of file reg_class.hh.
|
private |
Definition at line 226 of file reg_class.hh.
|
private |
Definition at line 227 of file reg_class.hh.