[llvm] [NFC][PowerPC] clang-format spill and restore opcodes (PR #141675)
Lei Huang via llvm-commits
llvm-commits at lists.llvm.org
Tue May 27 14:51:45 PDT 2025
https://github.com/lei137 updated https://github.com/llvm/llvm-project/pull/141675
>From e684eea01703020640ef2b1f8f5943632f5d6df2 Mon Sep 17 00:00:00 2001
From: Lei Huang <lei at ca.ibm.com>
Date: Tue, 27 May 2025 16:43:44 -0500
Subject: [PATCH 1/2] [NFC][PowerPC] clang-format spill and restore opcodes
---
llvm/lib/Target/PowerPC/PPCInstrInfo.h | 185 ++++++++++++++++++-------
1 file changed, 137 insertions(+), 48 deletions(-)
diff --git a/llvm/lib/Target/PowerPC/PPCInstrInfo.h b/llvm/lib/Target/PowerPC/PPCInstrInfo.h
index 83bc39e0c06bd..0f4699c337d88 100644
--- a/llvm/lib/Target/PowerPC/PPCInstrInfo.h
+++ b/llvm/lib/Target/PowerPC/PPCInstrInfo.h
@@ -102,68 +102,157 @@ enum PPCMachineCombinerPattern : unsigned {
// Define list of load and store spill opcodes.
#define NoInstr PPC::INSTRUCTION_LIST_END
#define Pwr8LoadOpcodes \
- { \
- PPC::LWZ, PPC::LD, PPC::LFD, PPC::LFS, PPC::RESTORE_CR, \
- PPC::RESTORE_CRBIT, PPC::LVX, PPC::LXVD2X, PPC::LXSDX, PPC::LXSSPX, \
- PPC::SPILLTOVSR_LD, NoInstr, NoInstr, NoInstr, NoInstr, PPC::EVLDD, \
- PPC::RESTORE_QUADWORD \
- }
+ {PPC::LWZ, \
+ PPC::LD, \
+ PPC::LFD, \
+ PPC::LFS, \
+ PPC::RESTORE_CR, \
+ PPC::RESTORE_CRBIT, \
+ PPC::LVX, \
+ PPC::LXVD2X, \
+ PPC::LXSDX, \
+ PPC::LXSSPX, \
+ PPC::SPILLTOVSR_LD, \
+ NoInstr, \
+ NoInstr, \
+ NoInstr, \
+ NoInstr, \
+ PPC::EVLDD, \
+ PPC::RESTORE_QUADWORD}
#define Pwr9LoadOpcodes \
- { \
- PPC::LWZ, PPC::LD, PPC::LFD, PPC::LFS, PPC::RESTORE_CR, \
- PPC::RESTORE_CRBIT, PPC::LVX, PPC::LXV, PPC::DFLOADf64, \
- PPC::DFLOADf32, PPC::SPILLTOVSR_LD, NoInstr, NoInstr, NoInstr, \
- NoInstr, NoInstr, PPC::RESTORE_QUADWORD \
- }
+ {PPC::LWZ, \
+ PPC::LD, \
+ PPC::LFD, \
+ PPC::LFS, \
+ PPC::RESTORE_CR, \
+ PPC::RESTORE_CRBIT, \
+ PPC::LVX, \
+ PPC::LXV, \
+ PPC::DFLOADf64, \
+ PPC::DFLOADf32, \
+ PPC::SPILLTOVSR_LD, \
+ NoInstr, \
+ NoInstr, \
+ NoInstr, \
+ NoInstr, \
+ NoInstr, \
+ PPC::RESTORE_QUADWORD}
#define Pwr10LoadOpcodes \
- { \
- PPC::LWZ, PPC::LD, PPC::LFD, PPC::LFS, PPC::RESTORE_CR, \
- PPC::RESTORE_CRBIT, PPC::LVX, PPC::LXV, PPC::DFLOADf64, \
- PPC::DFLOADf32, PPC::SPILLTOVSR_LD, PPC::LXVP, PPC::RESTORE_ACC, \
- PPC::RESTORE_UACC, NoInstr, NoInstr, PPC::RESTORE_QUADWORD \
- }
+ {PPC::LWZ, \
+ PPC::LD, \
+ PPC::LFD, \
+ PPC::LFS, \
+ PPC::RESTORE_CR, \
+ PPC::RESTORE_CRBIT, \
+ PPC::LVX, \
+ PPC::LXV, \
+ PPC::DFLOADf64, \
+ PPC::DFLOADf32, \
+ PPC::SPILLTOVSR_LD, \
+ PPC::LXVP, \
+ PPC::RESTORE_ACC, \
+ PPC::RESTORE_UACC, \
+ NoInstr, \
+ NoInstr, \
+ PPC::RESTORE_QUADWORD}
#define FutureLoadOpcodes \
- { \
- PPC::LWZ, PPC::LD, PPC::LFD, PPC::LFS, PPC::RESTORE_CR, \
- PPC::RESTORE_CRBIT, PPC::LVX, PPC::LXV, PPC::DFLOADf64, \
- PPC::DFLOADf32, PPC::SPILLTOVSR_LD, PPC::LXVP, PPC::RESTORE_ACC, \
- PPC::RESTORE_UACC, PPC::RESTORE_WACC, NoInstr, PPC::RESTORE_QUADWORD \
- }
+ {PPC::LWZ, \
+ PPC::LD, \
+ PPC::LFD, \
+ PPC::LFS, \
+ PPC::RESTORE_CR, \
+ PPC::RESTORE_CRBIT, \
+ PPC::LVX, \
+ PPC::LXV, \
+ PPC::DFLOADf64, \
+ PPC::DFLOADf32, \
+ PPC::SPILLTOVSR_LD, \
+ PPC::LXVP, \
+ PPC::RESTORE_ACC, \
+ PPC::RESTORE_UACC, \
+ PPC::RESTORE_WACC, \
+ NoInstr, \
+ PPC::RESTORE_QUADWORD}
#define Pwr8StoreOpcodes \
- { \
- PPC::STW, PPC::STD, PPC::STFD, PPC::STFS, PPC::SPILL_CR, PPC::SPILL_CRBIT, \
- PPC::STVX, PPC::STXVD2X, PPC::STXSDX, PPC::STXSSPX, \
- PPC::SPILLTOVSR_ST, NoInstr, NoInstr, NoInstr, NoInstr, PPC::EVSTDD, \
- PPC::SPILL_QUADWORD \
- }
+ {PPC::STW, \
+ PPC::STD, \
+ PPC::STFD, \
+ PPC::STFS, \
+ PPC::SPILL_CR, \
+ PPC::SPILL_CRBIT, \
+ PPC::STVX, \
+ PPC::STXVD2X, \
+ PPC::STXSDX, \
+ PPC::STXSSPX, \
+ PPC::SPILLTOVSR_ST, \
+ NoInstr, \
+ NoInstr, \
+ NoInstr, \
+ NoInstr, \
+ PPC::EVSTDD, \
+ PPC::SPILL_QUADWORD}
#define Pwr9StoreOpcodes \
- { \
- PPC::STW, PPC::STD, PPC::STFD, PPC::STFS, PPC::SPILL_CR, PPC::SPILL_CRBIT, \
- PPC::STVX, PPC::STXV, PPC::DFSTOREf64, PPC::DFSTOREf32, \
- PPC::SPILLTOVSR_ST, NoInstr, NoInstr, NoInstr, NoInstr, NoInstr, \
- PPC::SPILL_QUADWORD \
- }
+ {PPC::STW, \
+ PPC::STD, \
+ PPC::STFD, \
+ PPC::STFS, \
+ PPC::SPILL_CR, \
+ PPC::SPILL_CRBIT, \
+ PPC::STVX, \
+ PPC::STXV, \
+ PPC::DFSTOREf64, \
+ PPC::DFSTOREf32, \
+ PPC::SPILLTOVSR_ST, \
+ NoInstr, \
+ NoInstr, \
+ NoInstr, \
+ NoInstr, \
+ NoInstr, \
+ PPC::SPILL_QUADWORD}
#define Pwr10StoreOpcodes \
- { \
- PPC::STW, PPC::STD, PPC::STFD, PPC::STFS, PPC::SPILL_CR, PPC::SPILL_CRBIT, \
- PPC::STVX, PPC::STXV, PPC::DFSTOREf64, PPC::DFSTOREf32, \
- PPC::SPILLTOVSR_ST, PPC::STXVP, PPC::SPILL_ACC, PPC::SPILL_UACC, \
- NoInstr, NoInstr, PPC::SPILL_QUADWORD \
- }
+ {PPC::STW, \
+ PPC::STD, \
+ PPC::STFD, \
+ PPC::STFS, \
+ PPC::SPILL_CR, \
+ PPC::SPILL_CRBIT, \
+ PPC::STVX, \
+ PPC::STXV, \
+ PPC::DFSTOREf64, \
+ PPC::DFSTOREf32, \
+ PPC::SPILLTOVSR_ST, \
+ PPC::STXVP, \
+ PPC::SPILL_ACC, \
+ PPC::SPILL_UACC, \
+ NoInstr, \
+ NoInstr, \
+ PPC::SPILL_QUADWORD}
#define FutureStoreOpcodes \
- { \
- PPC::STW, PPC::STD, PPC::STFD, PPC::STFS, PPC::SPILL_CR, PPC::SPILL_CRBIT, \
- PPC::STVX, PPC::STXV, PPC::DFSTOREf64, PPC::DFSTOREf32, \
- PPC::SPILLTOVSR_ST, PPC::STXVP, PPC::SPILL_ACC, PPC::SPILL_UACC, \
- PPC::SPILL_WACC, NoInstr, PPC::SPILL_QUADWORD \
- }
+ {NoInstr, \
+ PPC::STW, \
+ PPC::STD, \
+ PPC::STFD, \
+ PPC::STFS, \
+ PPC::SPILL_CR, \
+ PPC::SPILL_CRBIT, \
+ PPC::STVX, \
+ PPC::STXV, \
+ PPC::DFSTOREf64, \
+ PPC::DFSTOREf32, \
+ PPC::SPILLTOVSR_ST, \
+ PPC::STXVP, \
+ PPC::SPILL_ACC, \
+ PPC::SPILL_UACC, \
+ PPC::SPILL_WACC, \
+ NoInstr, \
+ PPC::SPILL_QUADWORD}
// Initialize arrays for load and store spill opcodes on supported subtargets.
#define StoreOpcodesForSpill \
>From 42a59ee1c4dd39b3f3a464eddebbf954c9118ff8 Mon Sep 17 00:00:00 2001
From: Lei Huang <lei at ca.ibm.com>
Date: Tue, 27 May 2025 16:51:28 -0500
Subject: [PATCH 2/2] fix accidental additiona
---
llvm/lib/Target/PowerPC/PPCInstrInfo.h | 3 +--
1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/llvm/lib/Target/PowerPC/PPCInstrInfo.h b/llvm/lib/Target/PowerPC/PPCInstrInfo.h
index 0f4699c337d88..d0db90b029f61 100644
--- a/llvm/lib/Target/PowerPC/PPCInstrInfo.h
+++ b/llvm/lib/Target/PowerPC/PPCInstrInfo.h
@@ -235,8 +235,7 @@ enum PPCMachineCombinerPattern : unsigned {
PPC::SPILL_QUADWORD}
#define FutureStoreOpcodes \
- {NoInstr, \
- PPC::STW, \
+ {PPC::STW, \
PPC::STD, \
PPC::STFD, \
PPC::STFS, \
More information about the llvm-commits
mailing list