forked from OSchip/llvm-project
gn build: Add BPF target.
Differential Revision: https://reviews.llvm.org/D57436 llvm-svn: 352638
This commit is contained in:
parent
d2f83ab34c
commit
b9a0ee1e9c
|
@ -0,0 +1,23 @@
|
||||||
|
import("//llvm/utils/TableGen/tablegen.gni")
|
||||||
|
|
||||||
|
tablegen("BPFGenAsmMatcher") {
|
||||||
|
visibility = [ ":AsmParser" ]
|
||||||
|
args = [ "-gen-asm-matcher" ]
|
||||||
|
td_file = "../BPF.td"
|
||||||
|
}
|
||||||
|
|
||||||
|
static_library("AsmParser") {
|
||||||
|
output_name = "LLVMBPFAsmParser"
|
||||||
|
deps = [
|
||||||
|
":BPFGenAsmMatcher",
|
||||||
|
"//llvm/lib/MC",
|
||||||
|
"//llvm/lib/MC/MCParser",
|
||||||
|
"//llvm/lib/Support",
|
||||||
|
"//llvm/lib/Target/BPF/MCTargetDesc",
|
||||||
|
"//llvm/lib/Target/BPF/TargetInfo",
|
||||||
|
]
|
||||||
|
include_dirs = [ ".." ]
|
||||||
|
sources = [
|
||||||
|
"BPFAsmParser.cpp",
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,94 @@
|
||||||
|
import("//llvm/utils/TableGen/tablegen.gni")
|
||||||
|
|
||||||
|
tablegen("BPFGenCallingConv") {
|
||||||
|
visibility = [ ":LLVMBPFCodeGen" ]
|
||||||
|
args = [ "-gen-callingconv" ]
|
||||||
|
td_file = "BPF.td"
|
||||||
|
}
|
||||||
|
|
||||||
|
tablegen("BPFGenDAGISel") {
|
||||||
|
visibility = [ ":LLVMBPFCodeGen" ]
|
||||||
|
args = [ "-gen-dag-isel" ]
|
||||||
|
td_file = "BPF.td"
|
||||||
|
}
|
||||||
|
|
||||||
|
tablegen("BPFGenFastISel") {
|
||||||
|
visibility = [ ":LLVMBPFCodeGen" ]
|
||||||
|
args = [ "-gen-fast-isel" ]
|
||||||
|
td_file = "BPF.td"
|
||||||
|
}
|
||||||
|
|
||||||
|
tablegen("BPFGenGlobalISel") {
|
||||||
|
visibility = [ ":LLVMBPFCodeGen" ]
|
||||||
|
args = [ "-gen-global-isel" ]
|
||||||
|
td_file = "BPF.td"
|
||||||
|
}
|
||||||
|
|
||||||
|
tablegen("BPFGenMCPseudoLowering") {
|
||||||
|
visibility = [ ":LLVMBPFCodeGen" ]
|
||||||
|
args = [ "-gen-pseudo-lowering" ]
|
||||||
|
td_file = "BPF.td"
|
||||||
|
}
|
||||||
|
|
||||||
|
tablegen("BPFGenRegisterBank") {
|
||||||
|
visibility = [ ":LLVMBPFCodeGen" ]
|
||||||
|
args = [ "-gen-register-bank" ]
|
||||||
|
td_file = "BPF.td"
|
||||||
|
}
|
||||||
|
|
||||||
|
static_library("LLVMBPFCodeGen") {
|
||||||
|
deps = [
|
||||||
|
":BPFGenCallingConv",
|
||||||
|
":BPFGenDAGISel",
|
||||||
|
":BPFGenFastISel",
|
||||||
|
":BPFGenGlobalISel",
|
||||||
|
":BPFGenMCPseudoLowering",
|
||||||
|
":BPFGenRegisterBank",
|
||||||
|
"InstPrinter",
|
||||||
|
"MCTargetDesc",
|
||||||
|
"TargetInfo",
|
||||||
|
"//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",
|
||||||
|
]
|
||||||
|
include_dirs = [ "." ]
|
||||||
|
sources = [
|
||||||
|
"BPFAsmPrinter.cpp",
|
||||||
|
"BPFFrameLowering.cpp",
|
||||||
|
"BPFISelDAGToDAG.cpp",
|
||||||
|
"BPFISelLowering.cpp",
|
||||||
|
"BPFInstrInfo.cpp",
|
||||||
|
"BPFMCInstLower.cpp",
|
||||||
|
"BPFMIChecking.cpp",
|
||||||
|
"BPFMIPeephole.cpp",
|
||||||
|
"BPFRegisterInfo.cpp",
|
||||||
|
"BPFSelectionDAGInfo.cpp",
|
||||||
|
"BPFSubtarget.cpp",
|
||||||
|
"BPFTargetMachine.cpp",
|
||||||
|
"BTFDebug.cpp",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
# This is a bit different from most build files: Due to this group
|
||||||
|
# having the directory's name, "//llvm/lib/Target/BPF" 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("BPF") {
|
||||||
|
deps = [
|
||||||
|
":LLVMBPFCodeGen",
|
||||||
|
"AsmParser",
|
||||||
|
"Disassembler",
|
||||||
|
"InstPrinter",
|
||||||
|
"MCTargetDesc",
|
||||||
|
"TargetInfo",
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,22 @@
|
||||||
|
import("//llvm/utils/TableGen/tablegen.gni")
|
||||||
|
|
||||||
|
tablegen("BPFGenDisassemblerTables") {
|
||||||
|
visibility = [ ":Disassembler" ]
|
||||||
|
args = [ "-gen-disassembler" ]
|
||||||
|
td_file = "../BPF.td"
|
||||||
|
}
|
||||||
|
|
||||||
|
static_library("Disassembler") {
|
||||||
|
output_name = "LLVMBPFDisassembler"
|
||||||
|
deps = [
|
||||||
|
":BPFGenDisassemblerTables",
|
||||||
|
"//llvm/lib/MC",
|
||||||
|
"//llvm/lib/MC/MCDisassembler",
|
||||||
|
"//llvm/lib/Support",
|
||||||
|
"//llvm/lib/Target/BPF/MCTargetDesc",
|
||||||
|
]
|
||||||
|
include_dirs = [ ".." ]
|
||||||
|
sources = [
|
||||||
|
"BPFDisassembler.cpp",
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,24 @@
|
||||||
|
import("//llvm/utils/TableGen/tablegen.gni")
|
||||||
|
|
||||||
|
tablegen("BPFGenAsmWriter") {
|
||||||
|
visibility = [ ":InstPrinter" ]
|
||||||
|
args = [ "-gen-asm-writer" ]
|
||||||
|
td_file = "../BPF.td"
|
||||||
|
}
|
||||||
|
|
||||||
|
static_library("InstPrinter") {
|
||||||
|
output_name = "LLVMBPFAsmPrinter"
|
||||||
|
deps = [
|
||||||
|
":BPFGenAsmWriter",
|
||||||
|
"//llvm/lib/MC",
|
||||||
|
"//llvm/lib/Support",
|
||||||
|
|
||||||
|
# MCTargetDesc depends on InstPrinter, so we can't depend on the full
|
||||||
|
# MCTargetDesc target here: it would form a cycle.
|
||||||
|
"//llvm/lib/Target/BPF/MCTargetDesc:tablegen",
|
||||||
|
]
|
||||||
|
include_dirs = [ ".." ]
|
||||||
|
sources = [
|
||||||
|
"BPFInstPrinter.cpp",
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,60 @@
|
||||||
|
import("//llvm/utils/TableGen/tablegen.gni")
|
||||||
|
|
||||||
|
tablegen("BPFGenInstrInfo") {
|
||||||
|
visibility = [ ":tablegen" ]
|
||||||
|
args = [ "-gen-instr-info" ]
|
||||||
|
td_file = "../BPF.td"
|
||||||
|
}
|
||||||
|
|
||||||
|
tablegen("BPFGenMCCodeEmitter") {
|
||||||
|
visibility = [ ":tablegen" ]
|
||||||
|
args = [ "-gen-emitter" ]
|
||||||
|
td_file = "../BPF.td"
|
||||||
|
}
|
||||||
|
|
||||||
|
tablegen("BPFGenRegisterInfo") {
|
||||||
|
visibility = [ ":tablegen" ]
|
||||||
|
args = [ "-gen-register-info" ]
|
||||||
|
td_file = "../BPF.td"
|
||||||
|
}
|
||||||
|
|
||||||
|
tablegen("BPFGenSubtargetInfo") {
|
||||||
|
visibility = [ ":tablegen" ]
|
||||||
|
args = [ "-gen-subtarget" ]
|
||||||
|
td_file = "../BPF.td"
|
||||||
|
}
|
||||||
|
|
||||||
|
group("tablegen") {
|
||||||
|
visibility = [
|
||||||
|
":MCTargetDesc",
|
||||||
|
"../InstPrinter",
|
||||||
|
"../TargetInfo",
|
||||||
|
]
|
||||||
|
public_deps = [
|
||||||
|
":BPFGenInstrInfo",
|
||||||
|
":BPFGenMCCodeEmitter",
|
||||||
|
":BPFGenRegisterInfo",
|
||||||
|
":BPFGenSubtargetInfo",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
static_library("MCTargetDesc") {
|
||||||
|
output_name = "LLVMBPFDesc"
|
||||||
|
public_deps = [
|
||||||
|
":tablegen",
|
||||||
|
]
|
||||||
|
deps = [
|
||||||
|
"//llvm/lib/MC",
|
||||||
|
"//llvm/lib/MC/MCDisassembler",
|
||||||
|
"//llvm/lib/Support",
|
||||||
|
"//llvm/lib/Target/BPF/InstPrinter",
|
||||||
|
"//llvm/lib/Target/BPF/TargetInfo",
|
||||||
|
]
|
||||||
|
include_dirs = [ ".." ]
|
||||||
|
sources = [
|
||||||
|
"BPFAsmBackend.cpp",
|
||||||
|
"BPFELFObjectWriter.cpp",
|
||||||
|
"BPFMCCodeEmitter.cpp",
|
||||||
|
"BPFMCTargetDesc.cpp",
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,14 @@
|
||||||
|
static_library("TargetInfo") {
|
||||||
|
output_name = "LLVMBPFInfo"
|
||||||
|
deps = [
|
||||||
|
"//llvm/lib/Support",
|
||||||
|
|
||||||
|
# MCTargetDesc depends on TargetInfo, so we can't depend on the full
|
||||||
|
# MCTargetDesc target here: it would form a cycle.
|
||||||
|
"//llvm/lib/Target/BPF/MCTargetDesc:tablegen",
|
||||||
|
]
|
||||||
|
include_dirs = [ ".." ]
|
||||||
|
sources = [
|
||||||
|
"BPFTargetInfo.cpp",
|
||||||
|
]
|
||||||
|
}
|
|
@ -22,6 +22,7 @@ if (llvm_targets_to_build == "host") {
|
||||||
llvm_targets_to_build = [
|
llvm_targets_to_build = [
|
||||||
"AArch64",
|
"AArch64",
|
||||||
"ARM",
|
"ARM",
|
||||||
|
"BPF",
|
||||||
"PowerPC",
|
"PowerPC",
|
||||||
"WebAssembly",
|
"WebAssembly",
|
||||||
"X86",
|
"X86",
|
||||||
|
@ -32,6 +33,7 @@ if (llvm_targets_to_build == "host") {
|
||||||
# and remember which targets are built.
|
# and remember which targets are built.
|
||||||
llvm_build_AArch64 = false
|
llvm_build_AArch64 = false
|
||||||
llvm_build_ARM = false
|
llvm_build_ARM = false
|
||||||
|
llvm_build_BPF = false
|
||||||
llvm_build_PowerPC = false
|
llvm_build_PowerPC = false
|
||||||
llvm_build_WebAssembly = false
|
llvm_build_WebAssembly = false
|
||||||
llvm_build_X86 = false
|
llvm_build_X86 = false
|
||||||
|
@ -40,6 +42,8 @@ foreach(target, llvm_targets_to_build) {
|
||||||
llvm_build_AArch64 = true
|
llvm_build_AArch64 = true
|
||||||
} else if (target == "ARM") {
|
} else if (target == "ARM") {
|
||||||
llvm_build_ARM = true
|
llvm_build_ARM = true
|
||||||
|
} else if (target == "BPF") {
|
||||||
|
llvm_build_BPF = true
|
||||||
} else if (target == "PowerPC") {
|
} else if (target == "PowerPC") {
|
||||||
llvm_build_PowerPC = true
|
llvm_build_PowerPC = true
|
||||||
} else if (target == "WebAssembly") {
|
} else if (target == "WebAssembly") {
|
||||||
|
|
Loading…
Reference in New Issue