ARM.h revision 280031
1//===-- ARM.h - Top-level interface for ARM representation ------*- C++ -*-===// 2// 3// The LLVM Compiler Infrastructure 4// 5// This file is distributed under the University of Illinois Open Source 6// License. See LICENSE.TXT for details. 7// 8//===----------------------------------------------------------------------===// 9// 10// This file contains the entry points for global functions defined in the LLVM 11// ARM back-end. 12// 13//===----------------------------------------------------------------------===// 14 15#ifndef LLVM_LIB_TARGET_ARM_ARM_H 16#define LLVM_LIB_TARGET_ARM_ARM_H 17 18#include "llvm/Support/CodeGen.h" 19 20namespace llvm { 21 22class ARMAsmPrinter; 23class ARMBaseTargetMachine; 24class FunctionPass; 25class ImmutablePass; 26class MachineInstr; 27class MCInst; 28class TargetLowering; 29class TargetMachine; 30 31FunctionPass *createARMISelDag(ARMBaseTargetMachine &TM, 32 CodeGenOpt::Level OptLevel); 33FunctionPass *createA15SDOptimizerPass(); 34FunctionPass *createARMLoadStoreOptimizationPass(bool PreAlloc = false); 35FunctionPass *createARMExpandPseudoPass(); 36FunctionPass *createARMGlobalBaseRegPass(); 37FunctionPass *createARMGlobalMergePass(const TargetLowering* tli); 38FunctionPass *createARMConstantIslandPass(); 39FunctionPass *createMLxExpansionPass(); 40FunctionPass *createThumb2ITBlockPass(); 41FunctionPass *createARMOptimizeBarriersPass(); 42FunctionPass *createThumb2SizeReductionPass(); 43 44/// \brief Creates an ARM-specific Target Transformation Info pass. 45ImmutablePass *createARMTargetTransformInfoPass(const ARMBaseTargetMachine *TM); 46 47void LowerARMMachineInstrToMCInst(const MachineInstr *MI, MCInst &OutMI, 48 ARMAsmPrinter &AP); 49 50} // end namespace llvm; 51 52#endif 53