gem5
v22.0.0.0
|
Register ID: describe an architectural register with its class and index. More...
#include <reg_class.hh>
Public Member Functions | |
constexpr | RegId () |
constexpr | RegId (RegClassType reg_class, RegIndex reg_idx) |
constexpr | operator RegIndex () const |
constexpr bool | operator== (const RegId &that) const |
constexpr bool | operator!= (const RegId &that) const |
constexpr bool | operator< (const RegId &that) const |
Order operator. More... | |
constexpr bool | isRenameable () const |
Return true if this register can be renamed. More... | |
constexpr bool | is (RegClassType reg_class) const |
Protected Attributes | |
RegClassType | regClass |
RegIndex | regIdx |
int | numPinnedWrites |
Static Protected Attributes | |
static const char * | regClassStrings [] |
Friends | |
struct | std::hash< RegId > |
std::ostream & | operator<< (std::ostream &os, const RegId &rid) |
constexpr RegIndex | index () const |
Index accessors. More... | |
constexpr RegClassType | classValue () const |
Class accessor. More... | |
constexpr const char * | className () const |
Return a const char* with the register class name. More... | |
int | getNumPinnedWrites () const |
void | setNumPinnedWrites (int num_writes) |
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 126 of file reg_class.hh.
|
inlineconstexpr |
Definition at line 137 of file reg_class.hh.
|
inlineconstexpr |
Definition at line 139 of file reg_class.hh.
|
inlineconstexpr |
Return a const char* with the register class name.
Definition at line 194 of file reg_class.hh.
References regClass, and regClassStrings.
Referenced by gem5::o3::Rename::renameDestRegs(), gem5::o3::Rename::renameSrcRegs(), and gem5::o3::ElasticTrace::updateRegDep().
|
inlineconstexpr |
Class accessor.
Definition at line 191 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 |
Definition at line 199 of file reg_class.hh.
References numPinnedWrites.
Referenced by gem5::o3::SimpleRenameMap::rename(), and gem5::o3::Rename::renameDestRegs().
|
inlineconstexpr |
Index accessors.
Definition at line 188 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(), gem5::o3::SimpleRenameMap::lookup(), gem5::o3::UnifiedRenameMap::lookup(), operator RegIndex(), std::hash< gem5::RegId >::operator()(), operator<(), operator==(), gem5::Iris::ThreadContext::readVecPredReg(), gem5::Iris::ThreadContext::readVecReg(), gem5::o3::SimpleRenameMap::rename(), gem5::o3::Rename::renameDestRegs(), gem5::o3::Rename::renameSrcRegs(), gem5::o3::SimpleRenameMap::setEntry(), and gem5::CheckerCPU::setMiscRegOperand().
|
inlineconstexpr |
Definition at line 181 of file reg_class.hh.
References regClass.
Referenced by gem5::o3::SimpleRenameMap::rename(), and gem5::o3::ElasticTrace::updateRegDep().
|
inlineconstexpr |
Return true if this register can be renamed.
Definition at line 174 of file reg_class.hh.
References gem5::InvalidRegClass, gem5::MiscRegClass, and regClass.
Referenced by gem5::PhysRegId::isFixedMapping(), gem5::o3::UnifiedRenameMap::rename(), and gem5::o3::UnifiedRenameMap::setEntry().
|
inlineconstexpr |
Definition at line 143 of file reg_class.hh.
References index().
|
inlineconstexpr |
Definition at line 155 of file reg_class.hh.
Referenced by gem5::PhysRegId::operator!=().
|
inlineconstexpr |
Order operator.
The order is required to implement maps with key type RegId
Definition at line 164 of file reg_class.hh.
References classValue(), index(), regClass, and regIdx.
Referenced by gem5::PhysRegId::operator<().
|
inlineconstexpr |
Definition at line 149 of file reg_class.hh.
References classValue(), index(), regClass, and regIdx.
Referenced by gem5::PhysRegId::operator==().
|
inline |
Definition at line 200 of file reg_class.hh.
References numPinnedWrites.
Referenced by gem5::o3::Rename::renameDestRegs().
|
friend |
Definition at line 203 of file reg_class.hh.
|
friend |
Definition at line 134 of file reg_class.hh.
|
protected |
Definition at line 132 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 130 of file reg_class.hh.
Referenced by className(), classValue(), is(), isRenameable(), std::hash< gem5::RegId >::operator()(), operator<(), and operator==().
|
staticprotected |
Definition at line 129 of file reg_class.hh.
Referenced by className().
|
protected |
Definition at line 131 of file reg_class.hh.
Referenced by index(), operator<(), and operator==().