1 //==-- AArch64.h - Top-level interface for AArch64 --------------*- C++ -*-==//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // This file contains the entry points for global functions defined in the LLVM
13 //===----------------------------------------------------------------------===//
15 #ifndef TARGET_AArch64_H
16 #define TARGET_AArch64_H
18 #include "MCTargetDesc/AArch64MCTargetDesc.h"
19 #include "Utils/AArch64BaseInfo.h"
20 #include "llvm/Support/DataTypes.h"
21 #include "llvm/Target/TargetMachine.h"
25 class AArch64TargetMachine;
27 class MachineFunctionPass;
29 FunctionPass *createAArch64DeadRegisterDefinitions();
30 FunctionPass *createAArch64ConditionalCompares();
31 FunctionPass *createAArch64AdvSIMDScalar();
32 FunctionPass *createAArch64BranchRelaxation();
33 FunctionPass *createAArch64ISelDag(AArch64TargetMachine &TM,
34 CodeGenOpt::Level OptLevel);
35 FunctionPass *createAArch64StorePairSuppressPass();
36 FunctionPass *createAArch64ExpandPseudoPass();
37 FunctionPass *createAArch64LoadStoreOptimizationPass();
38 ModulePass *createAArch64PromoteConstantPass();
39 FunctionPass *createAArch64AddressTypePromotionPass();
40 /// \brief Creates an ARM-specific Target Transformation Info pass.
42 createAArch64TargetTransformInfoPass(const AArch64TargetMachine *TM);
44 FunctionPass *createAArch64CleanupLocalDynamicTLSPass();
46 FunctionPass *createAArch64CollectLOHPass();
47 } // end namespace llvm