[llvm] [AMDGPU] Support block load/store for CSR (PR #130013)
Diana Picus via llvm-commits
llvm-commits at lists.llvm.org
Wed Mar 12 06:45:31 PDT 2025
================
@@ -239,6 +240,36 @@ const MCExpr *AMDGPUAsmPrinter::lowerConstant(const Constant *CV) {
return AsmPrinter::lowerConstant(CV);
}
+static void emitVGPRBlockComment(const MachineInstr *MI, MCStreamer &OS) {
+ // The instruction will only transfer a subset of the registers in the block,
+ // based on the mask that is stored in m0. We could search for the instruction
+ // that sets m0, but most of the time we'll already have the mask stored in
+ // the machine function info. Try to use that. This assumes that we only use
+ // block loads/stores for CSR spills.
+ const MachineFunction *MF = MI->getParent()->getParent();
+ const SIMachineFunctionInfo *MFI = MF->getInfo<SIMachineFunctionInfo>();
+ const TargetRegisterInfo &TRI = *MF->getSubtarget().getRegisterInfo();
+ const SIInstrInfo *TII = MF->getSubtarget<GCNSubtarget>().getInstrInfo();
+
+ Register RegBlock =
+ TII->getNamedOperand(*MI, MI->mayLoad() ? AMDGPU::OpName::vdst
+ : AMDGPU::OpName::vdata)
+ ->getReg();
+ Register FirstRegInBlock = TRI.getSubReg(RegBlock, AMDGPU::sub0);
+ uint32_t Mask = MFI->getMaskForVGPRBlockOps(RegBlock);
+
+ SmallString<512> TransferredRegs;
+ for (unsigned I = 0; I < 32; ++I) {
----------------
rovka wrote:
They're already hardcoded in the uint32_t above.
https://github.com/llvm/llvm-project/pull/130013
More information about the llvm-commits
mailing list