111 lines
3.1 KiB
Plaintext
111 lines
3.1 KiB
Plaintext
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",
|
|
"HexagonVectorCombine.cpp",
|
|
"HexagonVectorLoopCarriedReuse.cpp",
|
|
"HexagonVectorPrint.cpp",
|
|
"RDFCopy.cpp",
|
|
"RDFDeadCode.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",
|
|
]
|
|
}
|