LLVM 23.0.0git
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
21#include "llvm/Pass.h"
22#include "llvm/PassRegistry.h"
25#include <map>
26#include <memory>
27#include <unordered_map>
28
29struct AArch64O0PreLegalizerCombinerImplRuleConfig;
30struct AArch64PreLegalizerCombinerImplRuleConfig;
31struct AArch64PostLegalizerLoweringImplRuleConfig;
32
33namespace llvm {
34
38enum class CodeGenOptLevel;
39class FunctionPass;
41class ModulePass;
42
51 CodeGenOptLevel OptLevel);
70
72
80 const AArch64Subtarget &,
83 : public OptionalPassInfoMixin<AArch64O0PreLegalizerCombinerPass> {
84 std::unique_ptr<AArch64O0PreLegalizerCombinerImplRuleConfig> RuleConfig;
85
86public:
90
93};
94
96 : public OptionalPassInfoMixin<AArch64PreLegalizerCombinerPass> {
97 std::unique_ptr<AArch64PreLegalizerCombinerImplRuleConfig> RuleConfig;
98
99public:
103
106};
107
109 : public OptionalPassInfoMixin<AArch64PostSelectOptimizePass> {
110public:
113};
114
132
135FunctionPass *createAArch64PostLegalizerCombiner(bool IsOptNone);
137FunctionPass *createAArch64PostSelectOptimize();
138FunctionPass *createAArch64StackTaggingPass(bool IsOptNone);
141
184
186 : public OptionalPassInfoMixin<AArch64StackTaggingPreRAPass> {
187public:
190};
191
193 : public OptionalPassInfoMixin<AArch64A57FPLoadBalancingPass> {
194public:
197};
198
200 : public OptionalPassInfoMixin<AArch64LoadStoreOptPass> {
201public:
204};
205
207 : public OptionalPassInfoMixin<AArch64A53Fix835769Pass> {
208public:
211};
212
214 : public OptionalPassInfoMixin<AArch64BranchTargetsPass> {
215public:
218};
219
221 : public OptionalPassInfoMixin<AArch64RedundantCondBranchPass> {
222public:
225};
226
228 : public OptionalPassInfoMixin<AArch64AdvSIMDScalarPass> {
229public:
232};
233
235 : public OptionalPassInfoMixin<AArch64CollectLOHPass> {
236public:
239};
240
242 : public OptionalPassInfoMixin<AArch64CompressJumpTablesPass> {
243public:
246};
247
249 : public OptionalPassInfoMixin<AArch64DeadRegisterDefinitionsPass> {
250public:
253};
254
256 : public OptionalPassInfoMixin<AArch64ExpandPseudoPass> {
257public:
260};
261
263 : public OptionalPassInfoMixin<AArch64MIPeepholeOptPass> {
264public:
267};
268
270 : public OptionalPassInfoMixin<AArch64ConditionOptimizerPass> {
271public:
274};
275
277 : public OptionalPassInfoMixin<AArch64SIMDInstrOptPass> {
278 std::map<std::pair<unsigned, std::string>, bool> SIMDInstrTable;
279 std::unordered_map<std::string, bool> InterlEarlyExit;
280
281public:
284};
285
287 : public OptionalPassInfoMixin<AArch64PointerAuthPass> {
288public:
291};
292
293class AArch64SLSHardeningPass : public PassInfoMixin<AArch64SLSHardeningPass> {
294public:
297};
298
300 : public OptionalPassInfoMixin<AArch64PostCoalescerPass> {
301public:
304};
305
307 : public OptionalPassInfoMixin<AArch64RedundantCopyEliminationPass> {
308public:
311};
312
314 : public OptionalPassInfoMixin<AArch64ConditionalComparesPass> {
315public:
318};
319
320} // end namespace llvm
321
322#endif
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
AArch64O0PreLegalizerCombinerPass(AArch64O0PreLegalizerCombinerPass &&)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
AArch64PostLegalizerLoweringPass(AArch64PostLegalizerLoweringPass &&)
MachineFunctionProperties getRequiredProperties() const
Definition AArch64.h:127
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
AArch64PreLegalizerCombinerPass(AArch64PreLegalizerCombinerPass &&)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
This class provides the information for the target register banks.
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
FunctionPass class - This class is used to implement most global optimizations.
Definition Pass.h:314
Properties which a MachineFunction may have at a given point in time.
MachineFunctionProperties & set(Property P)
ModulePass class - This class is used to implement unstructured interprocedural optimizations and ana...
Definition Pass.h:255
PassRegistry - This class manages the registration and intitialization of the pass subsystem as appli...
A set of analyses that are preserved following a run of a transformation pass.
Definition Analysis.h:112
This is an optimization pass for GlobalISel generic memory operations.
FunctionPass * createAArch64PreLegalizerCombiner()
void initializeLDTLSCleanupPass(PassRegistry &)
void initializeMachineSMEABIPass(PassRegistry &)
FunctionPass * createAArch64PostSelectOptimize()
void initializeAArch64CFIFixupPass(PassRegistry &)
FunctionPass * createAArch64ConditionOptimizerLegacyPass()
void initializeAArch64A53Fix835769LegacyPass(PassRegistry &)
void initializeAArch64SRLTDefineSuperRegsPass(PassRegistry &)
void initializeAArch64SpeculationHardeningPass(PassRegistry &)
FunctionPass * createAArch64RedundantCopyEliminationPass()
void initializeAArch64PostLegalizerCombinerPass(PassRegistry &)
void initializeAArch64StackTaggingPreRALegacyPass(PassRegistry &)
FunctionPass * createMachineSMEABIPass(CodeGenOptLevel)
FunctionPass * createAArch64A53Fix835769LegacyPass()
void initializeAArch64BranchTargetsLegacyPass(PassRegistry &)
FunctionPass * createAArch64PostCoalescerPass()
void initializeAArch64PromoteConstantPass(PassRegistry &)
FunctionPass * createFalkorMarkStridedAccessesPass()
FunctionPass * createAArch64PointerAuthPass()
FunctionPass * createFalkorHWPFFixPass()
FunctionPass * createAArch64SRLTDefineSuperRegsPass()
FunctionPass * createAArch64O0PreLegalizerCombiner()
FunctionPass * createAArch64SLSHardeningLegacyPass()
void initializeAArch64CollectLOHLegacyPass(PassRegistry &)
AnalysisManager< MachineFunction > MachineFunctionAnalysisManager
FunctionPass * createAArch64LoadStoreOptLegacyPass()
createAArch64LoadStoreOptimizationPass - returns an instance of the load / store optimization pass.
FunctionPass * createAArch64CondBrTuning()
void initializeAArch64Arm64ECCallLoweringPass(PassRegistry &)
void initializeAArch64SIMDInstrOptLegacyPass(PassRegistry &)
FunctionPass * createAArch64A57FPLoadBalancingLegacyPass()
FunctionPass * createAArch64DeadRegisterDefinitions()
void initializeAArch64RedundantCondBranchLegacyPass(PassRegistry &)
void initializeAArch64PostSelectOptimizeLegacyPass(PassRegistry &)
FunctionPass * createSMEPeepholeOptPass()
FunctionPass * createAArch64PostLegalizerLowering()
FunctionPass * createAArch64StackTaggingPreRALegacyPass()
InstructionSelector * createAArch64InstructionSelector(const AArch64TargetMachine &, const AArch64Subtarget &, const AArch64RegisterBankInfo &)
void initializeAArch64CodeLayoutOptPass(PassRegistry &)
void initializeAArch64AsmPrinterPass(PassRegistry &)
FunctionPass * createAArch64MIPeepholeOptLegacyPass()
void initializeAArch64AdvSIMDScalarLegacyPass(PassRegistry &)
FunctionPass * createAArch64CompressJumpTablesPass()
FunctionPass * createAArch64ConditionalCompares()
FunctionPass * createAArch64ExpandPseudoLegacyPass()
Returns an instance of the pseudo instruction expansion pass.
void initializeAArch64PointerAuthLegacyPass(PassRegistry &)
void initializeFalkorMarkStridedAccessesLegacyPass(PassRegistry &)
void initializeAArch64StackTaggingPass(PassRegistry &)
void initializeAArch64PostLegalizerLoweringLegacyPass(PassRegistry &)
ModulePass * createAArch64Arm64ECCallLoweringPass()
void initializeAArch64ConditionOptimizerLegacyPass(PassRegistry &)
FunctionPass * createAArch64SIMDInstrOptPass()
Returns an instance of the high cost ASIMD instruction replacement optimization pass.
void initializeSMEPeepholeOptPass(PassRegistry &)
FunctionPass * createAArch64StorePairSuppressPass()
void initializeAArch64PostCoalescerLegacyPass(PassRegistry &)
ModulePass * createSVEIntrinsicOptsPass()
FunctionPass * createAArch64CollectLOHPass()
CodeGenOptLevel
Code generation optimization level.
Definition CodeGen.h:82
void initializeAArch64SLSHardeningLegacyPass(PassRegistry &)
FunctionPass * createAArch64PostLegalizerCombiner(bool IsOptNone)
void initializeAArch64StorePairSuppressPass(PassRegistry &)
void initializeAArch64LowerHomogeneousPrologEpilogPass(PassRegistry &)
void initializeAArch64PreLegalizerCombinerLegacyPass(PassRegistry &)
FunctionPass * createAArch64ISelDag(AArch64TargetMachine &TM, CodeGenOptLevel OptLevel)
createAArch64ISelDag - This pass converts a legalized DAG into a AArch64-specific DAG,...
void initializeAArch64CondBrTuningPass(PassRegistry &)
void initializeAArch64A57FPLoadBalancingLegacyPass(PassRegistry &)
FunctionPass * createAArch64BranchTargetsPass()
void initializeFalkorHWPFFixPass(PassRegistry &)
void initializeAArch64ExpandPseudoLegacyPass(PassRegistry &)
ModulePass * createAArch64LowerHomogeneousPrologEpilogPass()
FunctionPass * createAArch64StackTaggingPass(bool IsOptNone)
FunctionPass * createAArch64CleanupLocalDynamicTLSPass()
ModulePass * createAArch64PromoteConstantPass()
void initializeAArch64CompressJumpTablesLegacyPass(PassRegistry &)
void initializeAArch64RedundantCopyEliminationLegacyPass(PassRegistry &)
FunctionPass * createAArch64CodeLayoutOptPass()
FunctionPass * createAArch64AdvSIMDScalar()
FunctionPass * createAArch64RedundantCondBranchPass()
void initializeAArch64DAGToDAGISelLegacyPass(PassRegistry &)
FunctionPass * createAArch64SpeculationHardeningPass()
Returns an instance of the pseudo instruction expansion pass.
void initializeSVEIntrinsicOptsPass(PassRegistry &)
void initializeAArch64MIPeepholeOptLegacyPass(PassRegistry &)
void initializeAArch64DeadRegisterDefinitionsLegacyPass(PassRegistry &)
void initializeAArch64ConditionalComparesLegacyPass(PassRegistry &)
void initializeAArch64O0PreLegalizerCombinerLegacyPass(PassRegistry &)
void initializeAArch64LoadStoreOptLegacyPass(PassRegistry &)
A CRTP mix-in for passes that can be skipped.
A CRTP mix-in to automatically provide informational APIs needed for passes.
Definition PassManager.h:89