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
| import("//llvm/utils/TableGen/tablegen.gni")
tablegen("HexagonGenCallingConv") {
visibility = [ ":LLVMHexagonCodeGen" ]
args = [ "-gen-callingconv" ]
td_file = "Hexagon.td"
}
tablegen("HexagonGenDAGISel") {
visibility = [ ":LLVMHexagonCodeGen" ]
args = [ "-gen-dag-isel" ]
td_file = "Hexagon.td"
}
tablegen("HexagonGenDFAPacketizer") {
visibility = [ ":LLVMHexagonCodeGen" ]
args = [ "-gen-dfa-packetizer" ]
td_file = "Hexagon.td"
}
static_library("LLVMHexagonCodeGen") {
deps = [
":HexagonGenCallingConv",
":HexagonGenDAGISel",
":HexagonGenDFAPacketizer",
"MCTargetDesc",
"TargetInfo",
"//llvm/include/llvm/Config:llvm-config",
"//llvm/lib/Analysis",
"//llvm/lib/CodeGen",
"//llvm/lib/CodeGen/AsmPrinter",
"//llvm/lib/CodeGen/SelectionDAG",
"//llvm/lib/IR",
"//llvm/lib/MC",
"//llvm/lib/Passes",
"//llvm/lib/Support",
"//llvm/lib/Target",
"//llvm/lib/Transforms/Utils",
]
include_dirs = [ "." ]
sources = [
"BitTracker.cpp",
"HexagonAsmPrinter.cpp",
"HexagonBitSimplify.cpp",
"HexagonBitTracker.cpp",
"HexagonBlockRanges.cpp",
"HexagonBranchRelaxation.cpp",
"HexagonCFGOptimizer.cpp",
"HexagonCommonGEP.cpp",
"HexagonConstExtenders.cpp",
"HexagonConstPropagation.cpp",
"HexagonCopyToCombine.cpp",
"HexagonEarlyIfConv.cpp",
"HexagonExpandCondsets.cpp",
"HexagonFixupHwLoops.cpp",
"HexagonFrameLowering.cpp",
"HexagonGenExtract.cpp",
"HexagonGenInsert.cpp",
"HexagonGenMux.cpp",
"HexagonGenPredicate.cpp",
"HexagonHardwareLoops.cpp",
"HexagonHazardRecognizer.cpp",
"HexagonISelDAGToDAG.cpp",
"HexagonISelDAGToDAGHVX.cpp",
"HexagonISelLowering.cpp",
"HexagonISelLoweringHVX.cpp",
"HexagonInstrInfo.cpp",
"HexagonLoopIdiomRecognition.cpp",
"HexagonMCInstLower.cpp",
"HexagonMachineFunctionInfo.cpp",
"HexagonMachineScheduler.cpp",
"HexagonNewValueJump.cpp",
"HexagonOptAddrMode.cpp",
"HexagonOptimizeSZextends.cpp",
"HexagonPeephole.cpp",
"HexagonRDFOpt.cpp",
"HexagonRegisterInfo.cpp",
"HexagonSelectionDAGInfo.cpp",
"HexagonSplitConst32AndConst64.cpp",
"HexagonSplitDouble.cpp",
"HexagonStoreWidening.cpp",
"HexagonSubtarget.cpp",
"HexagonTargetMachine.cpp",
"HexagonTargetObjectFile.cpp",
"HexagonTargetTransformInfo.cpp",
"HexagonVExtract.cpp",
"HexagonVLIWPacketizer.cpp",
"HexagonVectorLoopCarriedReuse.cpp",
"HexagonVectorPrint.cpp",
"RDFCopy.cpp",
"RDFDeadCode.cpp",
"RDFGraph.cpp",
"RDFLiveness.cpp",
"RDFRegisters.cpp",
]
}
# This is a bit different from most build files: Due to this group
# having the directory's name, "//llvm/lib/Target/Hexagon" 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("Hexagon") {
deps = [
":LLVMHexagonCodeGen",
"AsmParser",
"Disassembler",
"MCTargetDesc",
"TargetInfo",
]
}
|