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/Support/DataTypes.h"
20 #include "llvm/Target/TargetMachine.h"
21 
22 namespace llvm {
23 
24 class AArch64RegisterBankInfo;
25 class AArch64Subtarget;
26 class AArch64TargetMachine;
27 class FunctionPass;
28 class InstructionSelector;
29 class MachineFunctionPass;
30 
31 FunctionPass *createAArch64DeadRegisterDefinitions();
32 FunctionPass *createAArch64RedundantCopyEliminationPass();
33 FunctionPass *createAArch64CondBrTuning();
34 FunctionPass *createAArch64CompressJumpTablesPass();
35 FunctionPass *createAArch64ConditionalCompares();
36 FunctionPass *createAArch64AdvSIMDScalar();
37 FunctionPass *createAArch64ISelDag(AArch64TargetMachine &TM,
38                                  CodeGenOpt::Level OptLevel);
39 FunctionPass *createAArch64StorePairSuppressPass();
40 FunctionPass *createAArch64ExpandPseudoPass();
41 FunctionPass *createAArch64SLSHardeningPass();
42 FunctionPass *createAArch64IndirectThunks();
43 FunctionPass *createAArch64SpeculationHardeningPass();
44 FunctionPass *createAArch64LoadStoreOptimizationPass();
45 FunctionPass *createAArch64SIMDInstrOptPass();
46 ModulePass *createAArch64PromoteConstantPass();
47 FunctionPass *createAArch64ConditionOptimizerPass();
48 FunctionPass *createAArch64A57FPLoadBalancing();
49 FunctionPass *createAArch64A53Fix835769();
50 FunctionPass *createFalkorHWPFFixPass();
51 FunctionPass *createFalkorMarkStridedAccessesPass();
52 FunctionPass *createAArch64BranchTargetsPass();
53 
54 FunctionPass *createAArch64CleanupLocalDynamicTLSPass();
55 
56 FunctionPass *createAArch64CollectLOHPass();
57 ModulePass *createSVEIntrinsicOptsPass();
58 InstructionSelector *
59 createAArch64InstructionSelector(const AArch64TargetMachine &,
60                                  AArch64Subtarget &, AArch64RegisterBankInfo &);
61 FunctionPass *createAArch64PreLegalizerCombiner(bool IsOptNone);
62 FunctionPass *createAArch64PostLegalizerCombiner(bool IsOptNone);
63 FunctionPass *createAArch64PostLegalizerLowering();
64 FunctionPass *createAArch64PostSelectOptimize();
65 FunctionPass *createAArch64StackTaggingPass(bool IsOptNone);
66 FunctionPass *createAArch64StackTaggingPreRAPass();
67 
68 void initializeAArch64A53Fix835769Pass(PassRegistry&);
69 void initializeAArch64A57FPLoadBalancingPass(PassRegistry&);
70 void initializeAArch64AdvSIMDScalarPass(PassRegistry&);
71 void initializeAArch64BranchTargetsPass(PassRegistry&);
72 void initializeAArch64CollectLOHPass(PassRegistry&);
73 void initializeAArch64CondBrTuningPass(PassRegistry &);
74 void initializeAArch64CompressJumpTablesPass(PassRegistry&);
75 void initializeAArch64ConditionalComparesPass(PassRegistry&);
76 void initializeAArch64ConditionOptimizerPass(PassRegistry&);
77 void initializeAArch64DeadRegisterDefinitionsPass(PassRegistry&);
78 void initializeAArch64ExpandPseudoPass(PassRegistry&);
79 void initializeAArch64SLSHardeningPass(PassRegistry&);
80 void initializeAArch64SpeculationHardeningPass(PassRegistry&);
81 void initializeAArch64LoadStoreOptPass(PassRegistry&);
82 void initializeAArch64SIMDInstrOptPass(PassRegistry&);
83 void initializeAArch64PreLegalizerCombinerPass(PassRegistry&);
84 void initializeAArch64PostLegalizerCombinerPass(PassRegistry &);
85 void initializeAArch64PostLegalizerLoweringPass(PassRegistry &);
86 void initializeAArch64PostSelectOptimizePass(PassRegistry &);
87 void initializeAArch64PromoteConstantPass(PassRegistry&);
88 void initializeAArch64RedundantCopyEliminationPass(PassRegistry&);
89 void initializeAArch64StorePairSuppressPass(PassRegistry&);
90 void initializeFalkorHWPFFixPass(PassRegistry&);
91 void initializeFalkorMarkStridedAccessesLegacyPass(PassRegistry&);
92 void initializeLDTLSCleanupPass(PassRegistry&);
93 void initializeSVEIntrinsicOptsPass(PassRegistry&);
94 void initializeAArch64StackTaggingPass(PassRegistry&);
95 void initializeAArch64StackTaggingPreRAPass(PassRegistry&);
96 } // end namespace llvm
97 
98 #endif
99