[llvm] AMDGPU: Move spill pseudo special case out of adjustAllocatableRegClass (PR #158246)
Matt Arsenault via llvm-commits
llvm-commits at lists.llvm.org
Fri Sep 12 02:04:41 PDT 2025
https://github.com/arsenm updated https://github.com/llvm/llvm-project/pull/158246
>From 368a9ed292fd221a458cf615afb029964807dfb8 Mon Sep 17 00:00:00 2001
From: Matt Arsenault <Matthew.Arsenault at amd.com>
Date: Fri, 5 Sep 2025 17:27:37 +0900
Subject: [PATCH 1/2] AMDGPU: Move spill pseudo special case out of
adjustAllocatableRegClass
This is special for the same reason av_mov_b64_imm_pseudo is special.
---
llvm/lib/Target/AMDGPU/SIInstrInfo.cpp | 8 +++-----
llvm/lib/Target/AMDGPU/SIInstrInfo.h | 6 ++++--
2 files changed, 7 insertions(+), 7 deletions(-)
diff --git a/llvm/lib/Target/AMDGPU/SIInstrInfo.cpp b/llvm/lib/Target/AMDGPU/SIInstrInfo.cpp
index 5c3340703ba3b..b1a61886802f4 100644
--- a/llvm/lib/Target/AMDGPU/SIInstrInfo.cpp
+++ b/llvm/lib/Target/AMDGPU/SIInstrInfo.cpp
@@ -5976,8 +5976,7 @@ SIInstrInfo::getWholeWaveFunctionSetup(MachineFunction &MF) const {
static const TargetRegisterClass *
adjustAllocatableRegClass(const GCNSubtarget &ST, const SIRegisterInfo &RI,
const MCInstrDesc &TID, unsigned RCID) {
- if (!ST.hasGFX90AInsts() && (((TID.mayLoad() || TID.mayStore()) &&
- !(TID.TSFlags & SIInstrFlags::Spill)))) {
+ if (!ST.hasGFX90AInsts() && (((TID.mayLoad() || TID.mayStore())))) {
switch (RCID) {
case AMDGPU::AV_32RegClassID:
RCID = AMDGPU::VGPR_32RegClassID;
@@ -6012,10 +6011,9 @@ const TargetRegisterClass *SIInstrInfo::getRegClass(const MCInstrDesc &TID,
if (OpNum >= TID.getNumOperands())
return nullptr;
auto RegClass = TID.operands()[OpNum].RegClass;
- if (TID.getOpcode() == AMDGPU::AV_MOV_B64_IMM_PSEUDO) {
- // Special pseudos have no alignment requirement
+ // Special pseudos have no alignment requirement
+ if (TID.getOpcode() == AMDGPU::AV_MOV_B64_IMM_PSEUDO || isSpill(TID))
return RI.getRegClass(RegClass);
- }
return adjustAllocatableRegClass(ST, RI, TID, RegClass);
}
diff --git a/llvm/lib/Target/AMDGPU/SIInstrInfo.h b/llvm/lib/Target/AMDGPU/SIInstrInfo.h
index f7dde2b90b68e..e0373e7768435 100644
--- a/llvm/lib/Target/AMDGPU/SIInstrInfo.h
+++ b/llvm/lib/Target/AMDGPU/SIInstrInfo.h
@@ -797,10 +797,12 @@ class SIInstrInfo final : public AMDGPUGenInstrInfo {
return get(Opcode).TSFlags & SIInstrFlags::Spill;
}
- static bool isSpill(const MachineInstr &MI) {
- return MI.getDesc().TSFlags & SIInstrFlags::Spill;
+ static bool isSpill(const MCInstrDesc &Desc) {
+ return Desc.TSFlags & SIInstrFlags::Spill;
}
+ static bool isSpill(const MachineInstr &MI) { return isSpill(MI.getDesc()); }
+
static bool isWWMRegSpillOpcode(uint16_t Opcode) {
return Opcode == AMDGPU::SI_SPILL_WWM_V32_SAVE ||
Opcode == AMDGPU::SI_SPILL_WWM_AV32_SAVE ||
>From f34d220d4df238dfda14d284b6253256e461e030 Mon Sep 17 00:00:00 2001
From: Matt Arsenault <Matthew.Arsenault at amd.com>
Date: Fri, 12 Sep 2025 18:01:24 +0900
Subject: [PATCH 2/2] Remove extra parens
---
llvm/lib/Target/AMDGPU/SIInstrInfo.cpp | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/llvm/lib/Target/AMDGPU/SIInstrInfo.cpp b/llvm/lib/Target/AMDGPU/SIInstrInfo.cpp
index b1a61886802f4..9a29cf8c2d398 100644
--- a/llvm/lib/Target/AMDGPU/SIInstrInfo.cpp
+++ b/llvm/lib/Target/AMDGPU/SIInstrInfo.cpp
@@ -5976,7 +5976,7 @@ SIInstrInfo::getWholeWaveFunctionSetup(MachineFunction &MF) const {
static const TargetRegisterClass *
adjustAllocatableRegClass(const GCNSubtarget &ST, const SIRegisterInfo &RI,
const MCInstrDesc &TID, unsigned RCID) {
- if (!ST.hasGFX90AInsts() && (((TID.mayLoad() || TID.mayStore())))) {
+ if (!ST.hasGFX90AInsts() && (TID.mayLoad() || TID.mayStore())) {
switch (RCID) {
case AMDGPU::AV_32RegClassID:
RCID = AMDGPU::VGPR_32RegClassID;
More information about the llvm-commits
mailing list