https://github.com/arsenm created https://github.com/llvm/llvm-project/pull/102805
R600 has a separate CodeGenPassBuilder anyway. >From 0a6b6eee1b1c2926169ff337a16ee291d5f72001 Mon Sep 17 00:00:00 2001 From: Matt Arsenault <matthew.arsena...@amd.com> Date: Sun, 11 Aug 2024 11:55:22 +0400 Subject: [PATCH] AMDGPU: Use GCNTargetMachine in AMDGPUCodeGenPassBuilder R600 has a separate CodeGenPassBuilder anyway. --- .../Target/AMDGPU/AMDGPUCodeGenPassBuilder.cpp | 2 +- .../lib/Target/AMDGPU/AMDGPUCodeGenPassBuilder.h | 6 +++--- llvm/lib/Target/AMDGPU/AMDGPUTargetMachine.cpp | 16 ++++++++-------- llvm/lib/Target/AMDGPU/AMDGPUTargetMachine.h | 12 ++++++------ 4 files changed, 18 insertions(+), 18 deletions(-) diff --git a/llvm/lib/Target/AMDGPU/AMDGPUCodeGenPassBuilder.cpp b/llvm/lib/Target/AMDGPU/AMDGPUCodeGenPassBuilder.cpp index cc4285f130fc82..0d829b6aeafe8f 100644 --- a/llvm/lib/Target/AMDGPU/AMDGPUCodeGenPassBuilder.cpp +++ b/llvm/lib/Target/AMDGPU/AMDGPUCodeGenPassBuilder.cpp @@ -15,7 +15,7 @@ using namespace llvm; AMDGPUCodeGenPassBuilder::AMDGPUCodeGenPassBuilder( - AMDGPUTargetMachine &TM, const CGPassBuilderOption &Opts, + GCNTargetMachine &TM, const CGPassBuilderOption &Opts, PassInstrumentationCallbacks *PIC) : CodeGenPassBuilder(TM, Opts, PIC) { Opt.RequiresCodeGenSCCOrder = true; diff --git a/llvm/lib/Target/AMDGPU/AMDGPUCodeGenPassBuilder.h b/llvm/lib/Target/AMDGPU/AMDGPUCodeGenPassBuilder.h index 5f79e309703a33..e656e166b3eb2e 100644 --- a/llvm/lib/Target/AMDGPU/AMDGPUCodeGenPassBuilder.h +++ b/llvm/lib/Target/AMDGPU/AMDGPUCodeGenPassBuilder.h @@ -14,12 +14,12 @@ namespace llvm { -class AMDGPUTargetMachine; +class GCNTargetMachine; class AMDGPUCodeGenPassBuilder - : public CodeGenPassBuilder<AMDGPUCodeGenPassBuilder, AMDGPUTargetMachine> { + : public CodeGenPassBuilder<AMDGPUCodeGenPassBuilder, GCNTargetMachine> { public: - AMDGPUCodeGenPassBuilder(AMDGPUTargetMachine &TM, + AMDGPUCodeGenPassBuilder(GCNTargetMachine &TM, const CGPassBuilderOption &Opts, PassInstrumentationCallbacks *PIC); diff --git a/llvm/lib/Target/AMDGPU/AMDGPUTargetMachine.cpp b/llvm/lib/Target/AMDGPU/AMDGPUTargetMachine.cpp index 202466f18d1bd6..62cf9c6cd61140 100644 --- a/llvm/lib/Target/AMDGPU/AMDGPUTargetMachine.cpp +++ b/llvm/lib/Target/AMDGPU/AMDGPUTargetMachine.cpp @@ -660,14 +660,6 @@ parseAMDGPUAtomicOptimizerStrategy(StringRef Params) { return make_error<StringError>("invalid parameter", inconvertibleErrorCode()); } -Error AMDGPUTargetMachine::buildCodeGenPipeline( - ModulePassManager &MPM, raw_pwrite_stream &Out, raw_pwrite_stream *DwoOut, - CodeGenFileType FileType, const CGPassBuilderOption &Opts, - PassInstrumentationCallbacks *PIC) { - AMDGPUCodeGenPassBuilder CGPB(*this, Opts, PIC); - return CGPB.buildPipeline(MPM, Out, DwoOut, FileType); -} - void AMDGPUTargetMachine::registerPassBuilderCallbacks(PassBuilder &PB) { #define GET_PASS_REGISTRY "AMDGPUPassRegistry.def" @@ -900,6 +892,14 @@ GCNTargetMachine::getTargetTransformInfo(const Function &F) const { return TargetTransformInfo(GCNTTIImpl(this, F)); } +Error GCNTargetMachine::buildCodeGenPipeline( + ModulePassManager &MPM, raw_pwrite_stream &Out, raw_pwrite_stream *DwoOut, + CodeGenFileType FileType, const CGPassBuilderOption &Opts, + PassInstrumentationCallbacks *PIC) { + AMDGPUCodeGenPassBuilder CGPB(*this, Opts, PIC); + return CGPB.buildPipeline(MPM, Out, DwoOut, FileType); +} + //===----------------------------------------------------------------------===// // AMDGPU Pass Setup //===----------------------------------------------------------------------===// diff --git a/llvm/lib/Target/AMDGPU/AMDGPUTargetMachine.h b/llvm/lib/Target/AMDGPU/AMDGPUTargetMachine.h index 0f74fbc22fa84f..6bb8788cc73b0c 100644 --- a/llvm/lib/Target/AMDGPU/AMDGPUTargetMachine.h +++ b/llvm/lib/Target/AMDGPU/AMDGPUTargetMachine.h @@ -52,12 +52,6 @@ class AMDGPUTargetMachine : public LLVMTargetMachine { return TLOF.get(); } - Error buildCodeGenPipeline(ModulePassManager &MPM, raw_pwrite_stream &Out, - raw_pwrite_stream *DwoOut, - CodeGenFileType FileType, - const CGPassBuilderOption &Opts, - PassInstrumentationCallbacks *PIC) override; - void registerPassBuilderCallbacks(PassBuilder &PB) override; void registerDefaultAliasAnalyses(AAManager &) override; @@ -103,6 +97,12 @@ class GCNTargetMachine final : public AMDGPUTargetMachine { return true; } + Error buildCodeGenPipeline(ModulePassManager &MPM, raw_pwrite_stream &Out, + raw_pwrite_stream *DwoOut, + CodeGenFileType FileType, + const CGPassBuilderOption &Opts, + PassInstrumentationCallbacks *PIC) override; + void registerMachineRegisterInfoCallback(MachineFunction &MF) const override; MachineFunctionInfo * _______________________________________________ llvm-branch-commits mailing list llvm-branch-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-branch-commits