import("//llvm/utils/TableGen/tablegen.gni") tablegen("NVPTXGenDAGISel") { visibility = [ ":LLVMNVPTXCodeGen" ] args = [ "-gen-dag-isel" ] td_file = "NVPTX.td" } static_library("LLVMNVPTXCodeGen") { deps = [ ":NVPTXGenDAGISel", "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/Support", "//llvm/lib/Target", "//llvm/lib/Transforms/IPO", "//llvm/lib/Transforms/Scalar", "//llvm/lib/Transforms/Utils", "//llvm/lib/Transforms/Vectorize", ] include_dirs = [ "." ] sources = [ "NVPTXAllocaHoisting.cpp", "NVPTXAsmPrinter.cpp", "NVPTXAssignValidGlobalNames.cpp", "NVPTXAtomicLower.cpp", "NVPTXFrameLowering.cpp", "NVPTXGenericToNVVM.cpp", "NVPTXISelDAGToDAG.cpp", "NVPTXISelLowering.cpp", "NVPTXImageOptimizer.cpp", "NVPTXInstrInfo.cpp", "NVPTXLowerAggrCopies.cpp", "NVPTXLowerAlloca.cpp", "NVPTXLowerArgs.cpp", "NVPTXMCExpr.cpp", "NVPTXPeephole.cpp", "NVPTXPrologEpilogPass.cpp", "NVPTXProxyRegErasure.cpp", "NVPTXRegisterInfo.cpp", "NVPTXReplaceImageHandles.cpp", "NVPTXSubtarget.cpp", "NVPTXTargetMachine.cpp", "NVPTXTargetTransformInfo.cpp", "NVPTXUtilities.cpp", "NVVMIntrRange.cpp", "NVVMReflect.cpp", ] } # This is a bit different from most build files: Due to this group # having the directory's name, "//llvm/lib/Target/NVPTX" 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("NVPTX") { deps = [ ":LLVMNVPTXCodeGen", "MCTargetDesc", "TargetInfo", ] }