1//==-- AArch64.h - Top-level interface for AArch64 --------------*- C++ -*-==//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file contains the entry points for global functions defined in the LLVM
10// AArch64 back-end.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_LIB_TARGET_AARCH64_AARCH64_H
15#define LLVM_LIB_TARGET_AARCH64_AARCH64_H
16
17#include "MCTargetDesc/AArch64MCTargetDesc.h"
18#include "Utils/AArch64BaseInfo.h"
19#include "llvm/CodeGen/MachineFunctionAnalysisManager.h"
20#include "llvm/Pass.h"
21#include "llvm/PassRegistry.h"
22#include "llvm/Support/DataTypes.h"
23#include "llvm/Target/TargetMachine.h"
24
25namespace llvm {
26
27class AArch64RegisterBankInfo;
28class AArch64Subtarget;
29class AArch64TargetMachine;
30enum class CodeGenOptLevel;
31class FunctionPass;
32class InstructionSelector;
33class ModulePass;
34
35FunctionPass *createAArch64DeadRegisterDefinitions();
36FunctionPass *createAArch64RedundantCopyEliminationPass();
37FunctionPass *createAArch64RedundantCondBranchPass();
38FunctionPass *createAArch64CondBrTuning();
39FunctionPass *createAArch64CompressJumpTablesPass();
40FunctionPass *createAArch64ConditionalCompares();
41FunctionPass *createAArch64AdvSIMDScalar();
42FunctionPass *createAArch64ISelDag(AArch64TargetMachine &TM,
43 CodeGenOptLevel OptLevel);
44FunctionPass *createAArch64StorePairSuppressPass();
45FunctionPass *createAArch64ExpandPseudoPass();
46FunctionPass *createAArch64SLSHardeningPass();
47FunctionPass *createAArch64SpeculationHardeningPass();
48FunctionPass *createAArch64LoadStoreOptLegacyPass();
49ModulePass *createAArch64LowerHomogeneousPrologEpilogPass();
50FunctionPass *createAArch64SIMDInstrOptPass();
51ModulePass *createAArch64PromoteConstantPass();
52FunctionPass *createAArch64ConditionOptimizerLegacyPass();
53FunctionPass *createAArch64A57FPLoadBalancing();
54FunctionPass *createAArch64A53Fix835769LegacyPass();
55FunctionPass *createFalkorHWPFFixPass();
56FunctionPass *createFalkorMarkStridedAccessesPass();
57FunctionPass *createAArch64PointerAuthPass();
58FunctionPass *createAArch64BranchTargetsPass();
59FunctionPass *createAArch64MIPeepholeOptPass();
60FunctionPass *createAArch64PostCoalescerPass();
61
62FunctionPass *createAArch64CleanupLocalDynamicTLSPass();
63
64FunctionPass *createAArch64CollectLOHPass();
65FunctionPass *createSMEABIPass();
66FunctionPass *createSMEPeepholeOptPass();
67FunctionPass *createMachineSMEABIPass(CodeGenOptLevel);
68FunctionPass *createAArch64SRLTDefineSuperRegsPass();
69ModulePass *createSVEIntrinsicOptsPass();
70InstructionSelector *
71createAArch64InstructionSelector(const AArch64TargetMachine &,
72 const AArch64Subtarget &,
73 const AArch64RegisterBankInfo &);
74FunctionPass *createAArch64O0PreLegalizerCombiner();
75FunctionPass *createAArch64PreLegalizerCombiner();
76FunctionPass *createAArch64PostLegalizerCombiner(bool IsOptNone);
77FunctionPass *createAArch64PostLegalizerLowering();
78FunctionPass *createAArch64PostSelectOptimize();
79FunctionPass *createAArch64StackTaggingPass(bool IsOptNone);
80FunctionPass *createAArch64StackTaggingPreRAPass();
81ModulePass *createAArch64Arm64ECCallLoweringPass();
82
83void initializeAArch64A53Fix835769LegacyPass(PassRegistry &);
84void initializeAArch64A57FPLoadBalancingPass(PassRegistry&);
85void initializeAArch64AdvSIMDScalarLegacyPass(PassRegistry &);
86void initializeAArch64AsmPrinterPass(PassRegistry &);
87void initializeAArch64PointerAuthPass(PassRegistry&);
88void initializeAArch64BranchTargetsLegacyPass(PassRegistry &);
89void initializeAArch64CFIFixupPass(PassRegistry&);
90void initializeAArch64CollectLOHLegacyPass(PassRegistry &);
91void initializeAArch64CompressJumpTablesLegacyPass(PassRegistry &);
92void initializeAArch64CondBrTuningPass(PassRegistry &);
93void initializeAArch64ConditionOptimizerLegacyPass(PassRegistry &);
94void initializeAArch64ConditionalComparesPass(PassRegistry &);
95void initializeAArch64DAGToDAGISelLegacyPass(PassRegistry &);
96void initializeAArch64DeadRegisterDefinitionsPass(PassRegistry&);
97void initializeAArch64ExpandPseudoPass(PassRegistry &);
98void initializeAArch64LoadStoreOptLegacyPass(PassRegistry &);
99void initializeAArch64LowerHomogeneousPrologEpilogPass(PassRegistry &);
100void initializeAArch64MIPeepholeOptPass(PassRegistry &);
101void initializeAArch64O0PreLegalizerCombinerPass(PassRegistry &);
102void initializeAArch64PostCoalescerPass(PassRegistry &);
103void initializeAArch64PostLegalizerCombinerPass(PassRegistry &);
104void initializeAArch64PostLegalizerLoweringPass(PassRegistry &);
105void initializeAArch64PostSelectOptimizePass(PassRegistry &);
106void initializeAArch64PreLegalizerCombinerPass(PassRegistry &);
107void initializeAArch64PromoteConstantPass(PassRegistry&);
108void initializeAArch64RedundantCopyEliminationPass(PassRegistry&);
109void initializeAArch64RedundantCondBranchPass(PassRegistry &);
110void initializeAArch64SIMDInstrOptPass(PassRegistry &);
111void initializeAArch64SLSHardeningPass(PassRegistry &);
112void initializeAArch64SpeculationHardeningPass(PassRegistry &);
113void initializeAArch64StackTaggingPass(PassRegistry &);
114void initializeAArch64StackTaggingPreRAPass(PassRegistry &);
115void initializeAArch64StorePairSuppressPass(PassRegistry&);
116void initializeFalkorHWPFFixPass(PassRegistry&);
117void initializeFalkorMarkStridedAccessesLegacyPass(PassRegistry&);
118void initializeLDTLSCleanupPass(PassRegistry&);
119void initializeSMEABIPass(PassRegistry &);
120void initializeSMEPeepholeOptPass(PassRegistry &);
121void initializeMachineSMEABIPass(PassRegistry &);
122void initializeAArch64SRLTDefineSuperRegsPass(PassRegistry &);
123void initializeSVEIntrinsicOptsPass(PassRegistry &);
124void initializeAArch64Arm64ECCallLoweringPass(PassRegistry &);
125
126class AArch64LoadStoreOptPass : public PassInfoMixin<AArch64LoadStoreOptPass> {
127public:
128 PreservedAnalyses run(MachineFunction &MF,
129 MachineFunctionAnalysisManager &MFAM);
130};
131
132class AArch64A53Fix835769Pass : public PassInfoMixin<AArch64A53Fix835769Pass> {
133public:
134 PreservedAnalyses run(MachineFunction &MF,
135 MachineFunctionAnalysisManager &MFAM);
136};
137
138class AArch64BranchTargetsPass
139 : public PassInfoMixin<AArch64BranchTargetsPass> {
140public:
141 PreservedAnalyses run(MachineFunction &MF,
142 MachineFunctionAnalysisManager &MFAM);
143};
144
145class AArch64AdvSIMDScalarPass
146 : public PassInfoMixin<AArch64AdvSIMDScalarPass> {
147public:
148 PreservedAnalyses run(MachineFunction &MF,
149 MachineFunctionAnalysisManager &MFAM);
150};
151
152class AArch64CollectLOHPass : public PassInfoMixin<AArch64CollectLOHPass> {
153public:
154 PreservedAnalyses run(MachineFunction &MF,
155 MachineFunctionAnalysisManager &MFAM);
156};
157
158class AArch64CompressJumpTablesPass
159 : public PassInfoMixin<AArch64CompressJumpTablesPass> {
160public:
161 PreservedAnalyses run(MachineFunction &MF,
162 MachineFunctionAnalysisManager &MFAM);
163};
164
165class AArch64ConditionOptimizerPass
166 : public PassInfoMixin<AArch64ConditionOptimizerPass> {
167public:
168 PreservedAnalyses run(MachineFunction &MF,
169 MachineFunctionAnalysisManager &MFAM);
170};
171
172} // end namespace llvm
173
174#endif
175