|
LLVM 23.0.0git
|
#include "Target/RISCV/RISCVRegisterInfo.h"
Static Public Member Functions | |
| static bool | isVRRegClass (const TargetRegisterClass *RC) |
| static bool | isVRNRegClass (const TargetRegisterClass *RC) |
| static bool | isRVVRegClass (const TargetRegisterClass *RC) |
Definition at line 64 of file RISCVRegisterInfo.h.
| RISCVRegisterInfo::RISCVRegisterInfo | ( | unsigned | HwMode | ) |
Definition at line 57 of file RISCVRegisterInfo.cpp.
| void RISCVRegisterInfo::adjustReg | ( | MachineBasicBlock & | MBB, |
| MachineBasicBlock::iterator | II, | ||
| const DebugLoc & | DL, | ||
| Register | DestReg, | ||
| Register | SrcReg, | ||
| StackOffset | Offset, | ||
| MachineInstr::MIFlag | Flag, | ||
| MaybeAlign | RequiredAlign ) const |
Definition at line 248 of file RISCVRegisterInfo.cpp.
References llvm::MachineInstrBuilder::addImm(), llvm::MachineInstrBuilder::addReg(), assert(), llvm::BuildMI(), contains(), llvm::MachineRegisterInfo::createVirtualRegister(), DL, llvm::MachineInstr::FrameDestroy, llvm::MachineInstr::FrameSetup, llvm::StackOffset::getFixed(), llvm::getKillRegState(), llvm::MachineFunction::getRegInfo(), llvm::MachineFunction::getSubtarget(), II, llvm::isInt(), llvm::isShiftedInt(), llvm::isUInt(), llvm::Kill, MBB, llvm::Offset, Opc, llvm::reportFatalUsageError(), llvm::RISCV::RVVBytesPerBlock, llvm::MachineInstrBuilder::setMIFlag(), TII, llvm::Align::value(), and llvm::MaybeAlign::valueOrOne().
Referenced by llvm::RISCVFrameLowering::allocateStack(), llvm::RISCVFrameLowering::eliminateCallFramePseudoInstr(), eliminateFrameIndex(), and llvm::RISCVFrameLowering::emitEpilogue().
|
override |
Definition at line 556 of file RISCVRegisterInfo.cpp.
References adjustReg(), assert(), llvm::MachineRegisterInfo::createVirtualRegister(), DL, llvm::StackOffset::get(), llvm::StackOffset::getFixed(), llvm::MachineFunction::getRegInfo(), II, llvm::isInt(), llvm::RISCV::isRVVSpill(), llvm::isUInt(), lowerSegmentSpillReload(), MI, llvm::MachineInstr::NoFlags, llvm::Offset, Opc, llvm::reportFatalUsageError(), and llvm::SignExtend64().
| Register RISCVRegisterInfo::findVRegWithEncoding | ( | const TargetRegisterClass & | RegClass, |
| uint16_t | Encoding ) const |
Definition at line 1140 of file RISCVRegisterInfo.cpp.
References llvm::RISCVRI::getLMul(), llvm::RISCVVType::LMUL_1, and llvm::TargetRegisterClass::TSFlags.
Referenced by lowerSegmentSpillReload().
|
override |
Definition at line 67 of file RISCVRegisterInfo.cpp.
References llvm::RISCVABI::ABI_ILP32, llvm::RISCVABI::ABI_ILP32D, llvm::RISCVABI::ABI_ILP32E, llvm::RISCVABI::ABI_ILP32F, llvm::RISCVABI::ABI_LP64, llvm::RISCVABI::ABI_LP64D, llvm::RISCVABI::ABI_LP64E, llvm::RISCVABI::ABI_LP64F, llvm::Function::getCallingConv(), llvm::MachineFunction::getFunction(), llvm::MachineFunction::getSubtarget(), llvm::CallingConv::GHC, llvm::Function::hasFnAttribute(), llvm_unreachable, llvm::CallingConv::PreserveMost, and llvm::CallingConv::RISCV_VectorCall.
|
override |
Definition at line 819 of file RISCVRegisterInfo.cpp.
References llvm::RISCVABI::ABI_ILP32, llvm::RISCVABI::ABI_ILP32D, llvm::RISCVABI::ABI_ILP32E, llvm::RISCVABI::ABI_ILP32F, llvm::RISCVABI::ABI_LP64, llvm::RISCVABI::ABI_LP64D, llvm::RISCVABI::ABI_LP64E, llvm::RISCVABI::ABI_LP64F, llvm::MachineFunction::getSubtarget(), llvm::CallingConv::GHC, llvm_unreachable, llvm::CallingConv::PreserveMost, and llvm::CallingConv::RISCV_VectorCall.
|
override |
Definition at line 123 of file RISCVRegisterInfo.cpp.
References llvm::dyn_cast(), llvm::MachineRegisterInfo::getMF(), llvm::MachineOperand::getReg(), getRegClassForTypeOnBank(), llvm::MachineRegisterInfo::getRegClassOrRegBank(), llvm::MachineFunction::getSubtarget(), llvm::MachineRegisterInfo::getType(), and llvm::RISCVSubtarget::is64Bit().
|
inlineoverride |
Definition at line 71 of file RISCVRegisterInfo.h.
|
override |
Definition at line 797 of file RISCVRegisterInfo.cpp.
References assert(), llvm::RISCVII::getFormat(), llvm::RISCVII::InstFormatI, llvm::RISCVII::InstFormatS, and MI.
Referenced by isFrameOffsetLegal(), and resolveFrameIndex().
|
override |
Definition at line 807 of file RISCVRegisterInfo.cpp.
References llvm::TargetFrameLowering::hasFP().
|
override |
Definition at line 62 of file RISCVRegisterInfo.cpp.
|
override |
Definition at line 856 of file RISCVRegisterInfo.cpp.
Definition at line 244 of file RISCVRegisterInfo.cpp.
|
override |
Definition at line 871 of file RISCVRegisterInfo.cpp.
References AbstractManglingParser< Derived, Alloc >::Ops, llvm::DIExpression::appendOffset(), assert(), getDwarfRegNum(), and llvm::Offset.
|
inlineoverride |
Definition at line 139 of file RISCVRegisterInfo.h.
|
override |
Definition at line 912 of file RISCVRegisterInfo.cpp.
References contains(), llvm::SmallSet< T, N, C >::count(), DisableRegAllocHints, llvm::VirtRegMap::getPhys(), llvm::MachineRegisterInfo::getRegAllocationHint(), llvm::TargetRegisterInfo::getRegAllocationHints(), llvm::MachineFunction::getRegInfo(), llvm::MachineOperand::getSubReg(), llvm::MachineFunction::getSubtarget(), llvm::VirtRegMap::hasPhys(), I, llvm::MCRegister::id(), llvm::SmallSet< T, N, C >::insert(), llvm::is_contained(), llvm::isInt(), llvm::Register::isPhysical(), llvm::MachineRegisterInfo::isReserved(), llvm::Register::isVirtual(), Matrix, MBB, MI, OpIdx, llvm::SmallVectorTemplateBase< T, bool >::push_back(), llvm::MachineRegisterInfo::reg_nodbg_operands(), Register, llvm::RISCVRI::RegPairEven, llvm::RISCVRI::RegPairOdd, and llvm::skipDebugInstructionsBackward().
|
override |
Definition at line 812 of file RISCVRegisterInfo.cpp.
References llvm::TargetRegisterInfo::getRegAsmName().
| const TargetRegisterClass * RISCVRegisterInfo::getRegClassForTypeOnBank | ( | LLT | Ty, |
| const RegisterBank & | RB, | ||
| bool | Is64Bit ) const |
Definition at line 140 of file RISCVRegisterInfo.cpp.
References llvm::RegisterBank::getID().
Referenced by getConstrainedRegClassForOperand().
|
override |
Definition at line 899 of file RISCVRegisterInfo.cpp.
References DisableCostPerUse, and llvm::MachineFunction::getSubtarget().
|
override |
Definition at line 173 of file RISCVRegisterInfo.cpp.
References assert(), llvm::RISCVABI::getBPReg(), llvm::Function::getCallingConv(), llvm::MachineFunction::getFunction(), llvm::MachineFunction::getSubtarget(), llvm::CallingConv::GRAAL, llvm::RISCVFrameLowering::hasBP(), llvm::TargetFrameLowering::hasFP(), llvm::reportFatalUsageError(), and llvm::Reserved.
|
override |
Definition at line 905 of file RISCVRegisterInfo.cpp.
|
override |
Definition at line 239 of file RISCVRegisterInfo.cpp.
References llvm::MachineFunction::getSubtarget(), and llvm::TargetSubtargetInfo::isRegisterReservedByUser().
|
override |
Definition at line 742 of file RISCVRegisterInfo.cpp.
References assert(), getFrameIndexInstrOffset(), llvm::isInt(), MI, and llvm::Offset.
Referenced by needsFrameBaseReg().
|
inlinestatic |
Definition at line 174 of file RISCVRegisterInfo.h.
References llvm::RISCVRI::isVRegClass(), and llvm::TargetRegisterClass::TSFlags.
Referenced by llvm::RISCVFrameLowering::assignCalleeSavedSpillSlots(), llvm::RISCVInstrInfo::copyPhysReg(), llvm::RISCV::isVectorCopy(), llvm::RISCVInstrInfo::isVRegCopy(), llvm::RISCVInstrInfo::loadRegFromStackSlot(), and llvm::RISCVInstrInfo::storeRegToStackSlot().
|
inlinestatic |
Definition at line 170 of file RISCVRegisterInfo.h.
References llvm::RISCVRI::getNF(), llvm::RISCVRI::isVRegClass(), and llvm::TargetRegisterClass::TSFlags.
|
inlinestatic |
Definition at line 165 of file RISCVRegisterInfo.h.
References llvm::RISCVRI::getNF(), llvm::RISCVRI::isVRegClass(), and llvm::TargetRegisterClass::TSFlags.
| void RISCVRegisterInfo::lowerSegmentSpillReload | ( | MachineBasicBlock::iterator | II, |
| bool | IsSpill ) const |
Definition at line 463 of file RISCVRegisterInfo.cpp.
References _, llvm::MachineInstrBuilder::addImm(), llvm::MachineInstrBuilder::addMemOperand(), llvm::MachineInstrBuilder::addReg(), assert(), llvm::sampleprof::Base, llvm::BuildMI(), llvm::MachineRegisterInfo::createVirtualRegister(), llvm::RISCVVType::decodeVLMUL(), llvm::details::FixedOrScalableQuantity< LeafTy, ValueTy >::divideCoefficientBy(), DL, findVRegWithEncoding(), llvm::getDefRegState(), llvm::RISCVSubtarget::getInstrInfo(), llvm::getKillRegState(), llvm::MachineFunction::getMachineMemOperand(), llvm::RISCVSubtarget::getRealVLen(), llvm::MachineFunction::getRegInfo(), llvm::RISCVSubtarget::getRegisterInfo(), getSpillReloadInfo(), llvm::MachineFunction::getSubtarget(), llvm::LocationSize::getValue(), I, II, llvm::Implicit, llvm::details::FixedOrScalableQuantity< LeafTy, ValueTy >::isKnownMultipleOf(), llvm::LocationSize::isPrecise(), llvm::RISCV::isRVVSpillForZvlsseg(), llvm::Kill, llvm::Log2_32(), MBB, llvm::RISCVInstrInfo::movImm(), llvm::Offset, TII, and TRI.
Referenced by eliminateFrameIndex().
|
override |
Definition at line 759 of file RISCVRegisterInfo.cpp.
References llvm::MachineInstrBuilder::addFrameIndex(), llvm::MachineInstrBuilder::addImm(), llvm::BuildMI(), llvm::MachineRegisterInfo::createVirtualRegister(), DL, llvm::TargetSubtargetInfo::getInstrInfo(), llvm::MachineFunction::getRegInfo(), llvm::MachineFunction::getSubtarget(), MBB, MBBI, llvm::Offset, and TII.
|
override |
Definition at line 686 of file RISCVRegisterInfo.cpp.
References assert(), contains(), llvm::MachineRegisterInfo::getCalleeSavedRegs(), llvm::RISCVII::getFormat(), llvm::MachineFunction::getFrameInfo(), llvm::MachineFrameInfo::getLocalFrameSize(), llvm::MachineFunction::getRegInfo(), llvm::MachineFunction::getSubtarget(), llvm::TargetFrameLowering::hasFP(), llvm::RISCVII::InstFormatI, llvm::RISCVII::InstFormatS, isFrameOffsetLegal(), MI, and llvm::Offset.
|
inlineoverride |
Definition at line 134 of file RISCVRegisterInfo.h.
|
inlineoverride |
Definition at line 130 of file RISCVRegisterInfo.h.
|
override |
Definition at line 677 of file RISCVRegisterInfo.cpp.
|
override |
Definition at line 779 of file RISCVRegisterInfo.cpp.
References assert(), getFrameIndexInstrOffset(), MI, and llvm::Offset.
|
override |