aboutsummaryrefslogtreecommitdiff
path: root/lib/Target/ARM/ARM.h
blob: 6d49d33e6d85bd2665f13e55ba0e8960ee956ff3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
//===-- ARM.h - Top-level interface for ARM representation ------*- C++ -*-===//
//
//                     The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
//
// This file contains the entry points for global functions defined in the LLVM
// ARM back-end.
//
//===----------------------------------------------------------------------===//

#ifndef TARGET_ARM_H
#define TARGET_ARM_H

#include "MCTargetDesc/ARMBaseInfo.h"
#include "MCTargetDesc/ARMMCTargetDesc.h"
#include "llvm/Support/DataTypes.h"
#include "llvm/Target/TargetMachine.h"

// @LOCALMOD (for LowerARMMachineInstrToMCInstPCRel)
#include "llvm/MC/MCSymbol.h"

namespace llvm {

class ARMAsmPrinter;
class ARMBaseTargetMachine;
class FunctionPass;
class JITCodeEmitter;
class MachineInstr;
class MCInst;

FunctionPass *createARMISelDag(ARMBaseTargetMachine &TM,
                               CodeGenOpt::Level OptLevel);

FunctionPass *createARMJITCodeEmitterPass(ARMBaseTargetMachine &TM,
                                          JITCodeEmitter &JCE);

FunctionPass *createA15SDOptimizerPass();
FunctionPass *createARMLoadStoreOptimizationPass(bool PreAlloc = false);
FunctionPass *createARMExpandPseudoPass();
FunctionPass *createARMGlobalBaseRegPass();
FunctionPass *createARMGlobalMergePass(const TargetLowering* tli);
FunctionPass *createARMConstantIslandPass();
FunctionPass *createMLxExpansionPass();
FunctionPass *createThumb2ITBlockPass();
FunctionPass *createThumb2SizeReductionPass();

/* @LOCALMOD-START */
FunctionPass *createARMNaClRewritePass();
/* @LOCALMOD-END */

/// \brief Creates an ARM-specific Target Transformation Info pass.
ImmutablePass *createARMTargetTransformInfoPass(const ARMBaseTargetMachine *TM);


void LowerARMMachineInstrToMCInst(const MachineInstr *MI, MCInst &OutMI,
                                  ARMAsmPrinter &AP);

                                          
/* @LOCALMOD-START */
// Used to lower the pc-relative MOVi16PIC / MOVTi16PIC pseudo instructions
// into the real MOVi16 / MOVTi16 instructions.
// See comment on MOVi16PIC for more details.
void LowerARMMachineInstrToMCInstPCRel(const MachineInstr *MI,
                                       MCInst &OutMI,
                                       ARMAsmPrinter &AP,
                                       unsigned ImmIndex,
                                       unsigned PCIndex,
                                       MCSymbol *PCLabel,
                                       unsigned PCAdjustment);
/* @LOCALMOD-END */

} // end namespace llvm;

#endif