LLVM  9.0.0svn
AArch64.h
Go to the documentation of this file.
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 
18 #include "Utils/AArch64BaseInfo.h"
19 #include "llvm/Support/DataTypes.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 
33 FunctionPass *createAArch64CondBrTuning();
35 FunctionPass *createAArch64ConditionalCompares();
36 FunctionPass *createAArch64AdvSIMDScalar();
37 FunctionPass *createAArch64ISelDag(AArch64TargetMachine &TM,
38  CodeGenOpt::Level OptLevel);
40 FunctionPass *createAArch64ExpandPseudoPass();
43 FunctionPass *createAArch64SIMDInstrOptPass();
46 FunctionPass *createAArch64A57FPLoadBalancing();
47 FunctionPass *createAArch64A53Fix835769();
48 FunctionPass *createFalkorHWPFFixPass();
50 FunctionPass *createAArch64BranchTargetsPass();
51 
53 
54 FunctionPass *createAArch64CollectLOHPass();
55 InstructionSelector *
56 createAArch64InstructionSelector(const AArch64TargetMachine &,
57  AArch64Subtarget &, AArch64RegisterBankInfo &);
58 FunctionPass *createAArch64PreLegalizeCombiner();
59 FunctionPass *createAArch64StackTaggingPass();
60 
61 void initializeAArch64A53Fix835769Pass(PassRegistry&);
62 void initializeAArch64A57FPLoadBalancingPass(PassRegistry&);
63 void initializeAArch64AdvSIMDScalarPass(PassRegistry&);
64 void initializeAArch64BranchTargetsPass(PassRegistry&);
65 void initializeAArch64CollectLOHPass(PassRegistry&);
66 void initializeAArch64CondBrTuningPass(PassRegistry &);
67 void initializeAArch64CompressJumpTablesPass(PassRegistry&);
69 void initializeAArch64ConditionOptimizerPass(PassRegistry&);
71 void initializeAArch64ExpandPseudoPass(PassRegistry&);
73 void initializeAArch64LoadStoreOptPass(PassRegistry&);
74 void initializeAArch64SIMDInstrOptPass(PassRegistry&);
76 void initializeAArch64PromoteConstantPass(PassRegistry&);
78 void initializeAArch64StorePairSuppressPass(PassRegistry&);
79 void initializeFalkorHWPFFixPass(PassRegistry&);
81 void initializeLDTLSCleanupPass(PassRegistry&);
82 void initializeAArch64StackTaggingPass(PassRegistry&);
83 } // end namespace llvm
84 
85 #endif
void initializeAArch64A53Fix835769Pass(PassRegistry &)
This class represents lattice values for constants.
Definition: AllocatorList.h:23
FunctionPass * createFalkorMarkStridedAccessesPass()
void initializeAArch64LoadStoreOptPass(PassRegistry &)
FunctionPass * createAArch64ConditionalCompares()
void initializeAArch64RedundantCopyEliminationPass(PassRegistry &)
ModulePass * createAArch64PromoteConstantPass()
FunctionPass * createAArch64CollectLOHPass()
void initializeLDTLSCleanupPass(PassRegistry &)
FunctionPass * createAArch64RedundantCopyEliminationPass()
void initializeAArch64CollectLOHPass(PassRegistry &)
FunctionPass * createAArch64A57FPLoadBalancing()
FunctionPass * createAArch64CleanupLocalDynamicTLSPass()
void initializeAArch64SpeculationHardeningPass(PassRegistry &)
FunctionPass * createAArch64LoadStoreOptimizationPass()
createAArch64LoadStoreOptimizationPass - returns an instance of the load / store optimization pass...
void initializeAArch64A57FPLoadBalancingPass(PassRegistry &)
void initializeAArch64PromoteConstantPass(PassRegistry &)
void initializeAArch64ExpandPseudoPass(PassRegistry &)
FunctionPass * createAArch64AdvSIMDScalar()
FunctionPass * createAArch64StackTaggingPass()
void initializeFalkorMarkStridedAccessesLegacyPass(PassRegistry &)
FunctionPass * createAArch64ExpandPseudoPass()
Returns an instance of the pseudo instruction expansion pass.
FunctionPass * createAArch64SpeculationHardeningPass()
Returns an instance of the pseudo instruction expansion pass.
void initializeFalkorHWPFFixPass(PassRegistry &)
FunctionPass * createAArch64A53Fix835769()
void initializeAArch64StackTaggingPass(PassRegistry &)
void initializeAArch64PreLegalizerCombinerPass(PassRegistry &)
FunctionPass * createAArch64ConditionOptimizerPass()
void initializeAArch64BranchTargetsPass(PassRegistry &)
FunctionPass * createAArch64ISelDag(AArch64TargetMachine &TM, CodeGenOpt::Level OptLevel)
createAArch64ISelDag - This pass converts a legalized DAG into a AArch64-specific DAG...
void initializeAArch64ConditionOptimizerPass(PassRegistry &)
InstructionSelector * createAArch64InstructionSelector(const AArch64TargetMachine &, AArch64Subtarget &, AArch64RegisterBankInfo &)
FunctionPass * createAArch64StorePairSuppressPass()
FunctionPass * createAArch64CondBrTuning()
FunctionPass * createFalkorHWPFFixPass()
FunctionPass * createAArch64BranchTargetsPass()
void initializeAArch64CondBrTuningPass(PassRegistry &)
void initializeAArch64ConditionalComparesPass(PassRegistry &)
FunctionPass * createAArch64PreLegalizeCombiner()
void initializeAArch64CompressJumpTablesPass(PassRegistry &)
FunctionPass * createAArch64SIMDInstrOptPass()
Returns an instance of the high cost ASIMD instruction replacement optimization pass.
void initializeAArch64DeadRegisterDefinitionsPass(PassRegistry &)
FunctionPass * createAArch64DeadRegisterDefinitions()
void initializeAArch64SIMDInstrOptPass(PassRegistry &)
void initializeAArch64AdvSIMDScalarPass(PassRegistry &)
FunctionPass * createAArch64CompressJumpTablesPass()
void initializeAArch64StorePairSuppressPass(PassRegistry &)