|
LLVM 22.0.0git
|
SI implementation of the TargetRegisterInfo class. More...
#include "AMDGPU.h"#include "AMDGPURegisterBankInfo.h"#include "GCNSubtarget.h"#include "MCTargetDesc/AMDGPUInstPrinter.h"#include "MCTargetDesc/AMDGPUMCTargetDesc.h"#include "SIMachineFunctionInfo.h"#include "SIRegisterInfo.h"#include "llvm/CodeGen/LiveIntervals.h"#include "llvm/CodeGen/LiveRegUnits.h"#include "llvm/CodeGen/MachineDominators.h"#include "llvm/CodeGen/MachineFrameInfo.h"#include "llvm/CodeGen/RegisterScavenging.h"#include "AMDGPUGenRegisterInfo.inc"Go to the source code of this file.
Classes | |
| struct | llvm::SGPRSpillBuilder |
| struct | llvm::SGPRSpillBuilder::PerVGPRData |
Namespaces | |
| namespace | llvm |
| This is an optimization pass for GlobalISel generic memory operations. | |
Macros | |
| #define | GET_REGINFO_TARGET_DESC |
Variables | |
| static cl::opt< bool > | EnableSpillSGPRToVGPR ("amdgpu-spill-sgpr-to-vgpr", cl::desc("Enable spilling SGPRs to VGPRs"), cl::ReallyHidden, cl::init(true)) |
| static const std::array< unsigned, 17 > | SubRegFromChannelTableWidthMap |
SI implementation of the TargetRegisterInfo class.
Definition in file SIRegisterInfo.cpp.
| #define GET_REGINFO_TARGET_DESC |
Definition at line 29 of file SIRegisterInfo.cpp.
|
static |
Definition at line 1432 of file SIRegisterInfo.cpp.
References llvm::MachineInstrBuilder::add(), llvm::MachineInstrBuilder::addImm(), llvm::BuildMI(), llvm::MachineInstrBuilder::cloneMemRefs(), DL, llvm::MachineInstrBuilder::getInstr(), getOffsetMUBUFLoad(), getOffsetMUBUFStore(), MBB, MI, llvm::Offset, Opc, Reg, spillVGPRtoAGPR(), and TII.
Referenced by llvm::SIRegisterInfo::eliminateFrameIndex().
|
static |
Definition at line 48 of file SIRegisterInfo.cpp.
References llvm::LLVMContext::diagnose(), llvm::Function::getContext(), and MI.
Referenced by llvm::SGPRSpillBuilder::prepare(), and llvm::SGPRSpillBuilder::readWriteTmpVGPR().
|
static |
Definition at line 3446 of file SIRegisterInfo.cpp.
References llvm::BitWidth.
Referenced by llvm::SIRegisterInfo::getAGPRClassForBitWidth(), and llvm::SIRegisterInfo::getProperlyAlignedRC().
|
static |
Definition at line 3520 of file SIRegisterInfo.cpp.
References llvm::BitWidth.
Referenced by llvm::SIRegisterInfo::getProperlyAlignedRC(), and llvm::SIRegisterInfo::getVectorSuperClassForBitWidth().
|
static |
Definition at line 3336 of file SIRegisterInfo.cpp.
References llvm::BitWidth.
Referenced by llvm::SIRegisterInfo::getProperlyAlignedRC(), and llvm::SIRegisterInfo::getVGPRClassForBitWidth().
|
static |
Definition at line 3414 of file SIRegisterInfo.cpp.
References llvm::BitWidth.
Referenced by llvm::SIRegisterInfo::getAGPRClassForBitWidth().
|
static |
Definition at line 3488 of file SIRegisterInfo.cpp.
References llvm::BitWidth.
Referenced by llvm::SIRegisterInfo::getVectorSuperClassForBitWidth().
|
static |
Definition at line 3304 of file SIRegisterInfo.cpp.
References llvm::BitWidth.
Referenced by llvm::SIRegisterInfo::getVGPRClassForBitWidth().
|
static |
Definition at line 1469 of file SIRegisterInfo.cpp.
References llvm::AMDGPU::getFlatScratchInstSTfromSS(), llvm::AMDGPU::getFlatScratchInstSVfromSS(), llvm::AMDGPU::hasNamedOperand(), llvm_unreachable, and TII.
Referenced by llvm::SIRegisterInfo::buildSpillLoadStore().
|
static |
Definition at line 1125 of file SIRegisterInfo.cpp.
References llvm_unreachable, MI, llvm::popcount(), and TII.
Referenced by llvm::SIRegisterInfo::eliminateFrameIndex().
|
static |
Definition at line 1354 of file SIRegisterInfo.cpp.
References Opc.
Referenced by llvm::SIRegisterInfo::buildSpillLoadStore().
|
static |
Definition at line 1331 of file SIRegisterInfo.cpp.
References Opc.
Referenced by llvm::SIRegisterInfo::buildSpillLoadStore().
|
static |
Definition at line 1296 of file SIRegisterInfo.cpp.
References Opc.
Referenced by buildMUBUFOffsetLoadStore().
|
static |
Definition at line 1273 of file SIRegisterInfo.cpp.
References Opc.
Referenced by buildMUBUFOffsetLoadStore().
|
static |
Definition at line 836 of file SIRegisterInfo.cpp.
References assert(), llvm::MachineOperand::getReg(), llvm::MachineOperand::isFI(), llvm::MachineOperand::isImm(), llvm::MachineOperand::isReg(), MI, and TRI.
Referenced by llvm::SIRegisterInfo::needsFrameBaseReg().
|
static |
Definition at line 1389 of file SIRegisterInfo.cpp.
References llvm::MachineInstrBuilder::addReg(), llvm::BuildMI(), DL, llvm::MachineFunction::getInfo(), llvm::getKillRegState(), llvm::MachineFunction::getRegInfo(), llvm::SIMachineFunctionInfo::getVGPRToAGPRSpill(), MBB, MI, MRI, Opc, Reg, llvm::MachineInstr::ReloadReuse, llvm::MachineInstr::setAsmPrinterFlag(), TII, and TRI.
Referenced by buildMUBUFOffsetLoadStore(), and llvm::SIRegisterInfo::buildSpillLoadStore().
|
static |
Referenced by llvm::SIRegisterInfo::SIRegisterInfo().
Definition at line 45 of file SIRegisterInfo.cpp.
Referenced by llvm::SIRegisterInfo::getSubRegFromChannel(), and llvm::SIRegisterInfo::SIRegisterInfo().