gem5
v21.1.0.1
|
Register ID: describe an architectural register with its class and index. More...
#include <reg_class.hh>
Public Member Functions | |
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 | is (RegClass reg_class) const |
RegIndex | elemIndex () const |
Elem accessor. More... | |
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) |
RegIndex | index () const |
Index accessors. More... | |
RegIndex | flatIndex () const |
Index flattening. More... | |
Protected Attributes | |
RegClass | regClass |
RegIndex | regIdx |
ElemIndex | elemIdx |
int | numPinnedWrites |
Static Protected Attributes | |
static const char * | regClassStrings [] |
static constexpr size_t | Scale = TheISA::NumVecElemPerVecReg |
Friends | |
struct | std::hash< RegId > |
std::ostream & | operator<< (std::ostream &os, const RegId &rid) |
Register ID: describe an architectural register with its class and index.
This structure is used instead of just the register index to disambiguate between different classes of registers. For example, a integer register with index 3 is represented by Regid(IntRegClass, 3).
Definition at line 88 of file reg_class.hh.
|
inline |
Definition at line 101 of file reg_class.hh.
Definition at line 103 of file reg_class.hh.
Definition at line 106 of file reg_class.hh.
References elemIdx, gem5::IllegalElemIndex, panic_if, regClass, and gem5::VecElemClass.
|
inline |
Return a const char* with the register class name.
Definition at line 182 of file reg_class.hh.
References regClass, and regClassStrings.
Referenced by gem5::o3::UnifiedRenameMap::lookup(), gem5::o3::UnifiedRenameMap::rename(), gem5::o3::Rename::renameDestRegs(), gem5::o3::Rename::renameSrcRegs(), gem5::o3::UnifiedRenameMap::setEntry(), and gem5::o3::ElasticTrace::updateRegDep().
|
inline |
Class accessor.
Definition at line 180 of file reg_class.hh.
References regClass.
Referenced by gem5::Checker< gem5::RefCountingPtr >::copyResult(), gem5::X86ISA::ISA::flattenRegId(), gem5::SparcISA::ISA::flattenRegId(), gem5::ArmISA::ISA::flattenRegId(), gem5::o3::DynInst::forwardOldRegs(), gem5::o3::UnifiedRenameMap::lookup(), operator<(), operator==(), gem5::o3::UnifiedRenameMap::rename(), gem5::o3::Rename::renameSrcRegs(), and gem5::o3::UnifiedRenameMap::setEntry().
|
inline |
Elem accessor.
Definition at line 178 of file reg_class.hh.
References elemIdx.
Referenced by gem5::ArmISA::ISA::flattenRegId(), operator<(), and operator==().
|
inline |
Index flattening.
Required to be able to use a vector for the register mapping.
Definition at line 160 of file reg_class.hh.
References gem5::CCRegClass, elemIdx, gem5::FloatRegClass, gem5::IntRegClass, gem5::MiscRegClass, panic, regClass, regIdx, Scale, gem5::VecElemClass, gem5::VecPredRegClass, and gem5::VecRegClass.
Referenced by gem5::o3::SimpleRenameMap::lookup(), gem5::o3::UnifiedRenameMap::lookup(), std::hash< gem5::RegId >::operator()(), gem5::o3::SimpleRenameMap::rename(), and gem5::o3::SimpleRenameMap::setEntry().
|
inline |
Definition at line 184 of file reg_class.hh.
References numPinnedWrites.
Referenced by gem5::o3::SimpleRenameMap::rename(), and gem5::o3::Rename::renameDestRegs().
|
inline |
Index accessors.
Definition at line 154 of file reg_class.hh.
References regIdx.
Referenced by gem5::Checker< gem5::RefCountingPtr >::copyResult(), gem5::TimingExprSrcReg::eval(), gem5::X86ISA::ISA::flattenRegId(), gem5::SparcISA::ISA::flattenRegId(), gem5::ArmISA::ISA::flattenRegId(), operator<(), operator==(), gem5::Iris::ThreadContext::readVecPredReg(), gem5::Iris::ThreadContext::readVecReg(), gem5::o3::SimpleRenameMap::rename(), gem5::o3::Rename::renameDestRegs(), gem5::o3::Rename::renameSrcRegs(), gem5::o3::PhysRegFile::setIntReg(), gem5::CheckerCPU::setMiscRegOperand(), and gem5::o3::ElasticTrace::updateRegDep().
|
inline |
Definition at line 150 of file reg_class.hh.
References regClass.
Referenced by gem5::o3::ElasticTrace::updateRegDep().
|
inline |
Return true if this register can be renamed.
Definition at line 144 of file reg_class.hh.
References gem5::MiscRegClass, and regClass.
Referenced by gem5::PhysRegId::isFixedMapping().
|
inline |
Definition at line 126 of file reg_class.hh.
Referenced by gem5::PhysRegId::operator!=().
|
inline |
Order operator.
The order is required to implement maps with key type RegId
Definition at line 132 of file reg_class.hh.
References classValue(), elemIdx, elemIndex(), index(), regClass, and regIdx.
Referenced by gem5::PhysRegId::operator<().
|
inline |
Definition at line 120 of file reg_class.hh.
References classValue(), elemIdx, elemIndex(), index(), regClass, and regIdx.
Referenced by gem5::PhysRegId::operator==().
|
inline |
Definition at line 185 of file reg_class.hh.
References numPinnedWrites.
Referenced by gem5::o3::Rename::renameDestRegs().
|
friend |
Definition at line 188 of file reg_class.hh.
|
friend |
Definition at line 98 of file reg_class.hh.
|
protected |
Definition at line 94 of file reg_class.hh.
Referenced by elemIndex(), flatIndex(), operator<(), operator==(), and RegId().
|
protected |
Definition at line 96 of file reg_class.hh.
Referenced by gem5::PhysRegId::decrNumPinnedWrites(), getNumPinnedWrites(), gem5::PhysRegId::getNumPinnedWrites(), gem5::PhysRegId::incrNumPinnedWrites(), setNumPinnedWrites(), and gem5::PhysRegId::setNumPinnedWrites().
|
protected |
Definition at line 92 of file reg_class.hh.
Referenced by className(), classValue(), flatIndex(), is(), isRenameable(), std::hash< gem5::RegId >::operator()(), operator<(), operator==(), and RegId().
|
staticprotected |
Definition at line 91 of file reg_class.hh.
Referenced by className().
|
protected |
Definition at line 93 of file reg_class.hh.
Referenced by flatIndex(), index(), operator<(), and operator==().
|
staticconstexprprotected |
Definition at line 95 of file reg_class.hh.
Referenced by flatIndex().