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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
| import("//llvm/utils/TableGen/tablegen.gni")
tablegen("ARMGenCallingConv") {
visibility = [ ":LLVMARMCodeGen" ]
args = [ "-gen-callingconv" ]
td_file = "ARM.td"
}
tablegen("ARMGenDAGISel") {
visibility = [ ":LLVMARMCodeGen" ]
args = [ "-gen-dag-isel" ]
td_file = "ARM.td"
}
tablegen("ARMGenFastISel") {
visibility = [ ":LLVMARMCodeGen" ]
args = [ "-gen-fast-isel" ]
td_file = "ARM.td"
}
tablegen("ARMGenGlobalISel") {
visibility = [ ":LLVMARMCodeGen" ]
args = [ "-gen-global-isel" ]
td_file = "ARM.td"
}
tablegen("ARMGenMCPseudoLowering") {
visibility = [ ":LLVMARMCodeGen" ]
args = [ "-gen-pseudo-lowering" ]
td_file = "ARM.td"
}
tablegen("ARMGenRegisterBank") {
visibility = [ ":LLVMARMCodeGen" ]
args = [ "-gen-register-bank" ]
td_file = "ARM.td"
}
static_library("LLVMARMCodeGen") {
deps = [
":ARMGenCallingConv",
":ARMGenDAGISel",
":ARMGenFastISel",
":ARMGenGlobalISel",
":ARMGenMCPseudoLowering",
":ARMGenRegisterBank",
"MCTargetDesc",
"TargetInfo",
"Utils",
"//llvm/include/llvm/Config:llvm-config",
"//llvm/lib/Analysis",
"//llvm/lib/CodeGen",
"//llvm/lib/CodeGen/AsmPrinter",
"//llvm/lib/CodeGen/GlobalISel",
"//llvm/lib/CodeGen/SelectionDAG",
"//llvm/lib/IR",
"//llvm/lib/MC",
"//llvm/lib/Support",
"//llvm/lib/Target",
"//llvm/lib/Transforms/CFGuard",
"//llvm/lib/Transforms/Utils",
]
include_dirs = [ "." ]
sources = [
"A15SDOptimizer.cpp",
"ARMAsmPrinter.cpp",
"ARMBaseInstrInfo.cpp",
"ARMBaseRegisterInfo.cpp",
"ARMBasicBlockInfo.cpp",
"ARMCallLowering.cpp",
"ARMCallingConv.cpp",
"ARMCodeGenPrepare.cpp",
"ARMConstantIslandPass.cpp",
"ARMConstantPoolValue.cpp",
"ARMExpandPseudoInsts.cpp",
"ARMFastISel.cpp",
"ARMFrameLowering.cpp",
"ARMHazardRecognizer.cpp",
"ARMISelDAGToDAG.cpp",
"ARMISelLowering.cpp",
"ARMInstrInfo.cpp",
"ARMInstructionSelector.cpp",
"ARMLegalizerInfo.cpp",
"ARMLoadStoreOptimizer.cpp",
"ARMLowOverheadLoops.cpp",
"ARMMCInstLower.cpp",
"ARMMachineFunctionInfo.cpp",
"ARMMacroFusion.cpp",
"ARMOptimizeBarriersPass.cpp",
"ARMParallelDSP.cpp",
"ARMRegisterBankInfo.cpp",
"ARMRegisterInfo.cpp",
"ARMSelectionDAGInfo.cpp",
"ARMSubtarget.cpp",
"ARMTargetMachine.cpp",
"ARMTargetObjectFile.cpp",
"ARMTargetTransformInfo.cpp",
"MLxExpansionPass.cpp",
"MVETailPredication.cpp",
"MVEVPTBlockPass.cpp",
"Thumb1FrameLowering.cpp",
"Thumb1InstrInfo.cpp",
"Thumb2ITBlockPass.cpp",
"Thumb2InstrInfo.cpp",
"Thumb2SizeReduction.cpp",
"ThumbRegisterInfo.cpp",
]
}
# This is a bit different from most build files: Due to this group
# having the directory's name, "//llvm/lib/Target/ARM" will refer to this
# target, which pulls in the code in this directory *and all subdirectories*.
# For most other directories, "//llvm/lib/Foo" only pulls in the code directly
# in "llvm/lib/Foo". The forwarding targets in //llvm/lib/Target expect this
# different behavior.
group("ARM") {
deps = [
":LLVMARMCodeGen",
"AsmParser",
"Disassembler",
"MCTargetDesc",
"TargetInfo",
"Utils",
]
}
|