1 //===-- ARM64.h - Top-level interface for ARM64 representation --*- 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_ARM64_H
16 #define TARGET_ARM64_H
18 #include "Utils/ARM64BaseInfo.h"
19 #include "MCTargetDesc/ARM64MCTargetDesc.h"
20 #include "llvm/Target/TargetMachine.h"
21 #include "llvm/Support/DataTypes.h"
25 class ARM64TargetMachine;
27 class MachineFunctionPass;
29 FunctionPass *createARM64DeadRegisterDefinitions();
30 FunctionPass *createARM64ConditionalCompares();
31 FunctionPass *createARM64AdvSIMDScalar();
32 FunctionPass *createARM64BranchRelaxation();
33 FunctionPass *createARM64ISelDag(ARM64TargetMachine &TM,
34 CodeGenOpt::Level OptLevel);
35 FunctionPass *createARM64StorePairSuppressPass();
36 FunctionPass *createARM64ExpandPseudoPass();
37 FunctionPass *createARM64LoadStoreOptimizationPass();
38 ModulePass *createARM64PromoteConstantPass();
39 FunctionPass *createARM64AddressTypePromotionPass();
40 /// \brief Creates an ARM-specific Target Transformation Info pass.
41 ImmutablePass *createARM64TargetTransformInfoPass(const ARM64TargetMachine *TM);
43 FunctionPass *createARM64CleanupLocalDynamicTLSPass();
45 FunctionPass *createARM64CollectLOHPass();
46 } // end namespace llvm