reference, declarationdefinition
definition → references, declarations, derived classes, virtual overrides
reference to multiple definitions → definitions
unreferenced
    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
import("//llvm/utils/TableGen/tablegen.gni")

tablegen("SystemZGenCallingConv") {
  visibility = [ ":LLVMSystemZCodeGen" ]
  args = [ "-gen-callingconv" ]
  td_file = "SystemZ.td"
}

tablegen("SystemZGenDAGISel") {
  visibility = [ ":LLVMSystemZCodeGen" ]
  args = [ "-gen-dag-isel" ]
  td_file = "SystemZ.td"
}

static_library("LLVMSystemZCodeGen") {
  deps = [
    ":SystemZGenCallingConv",
    ":SystemZGenDAGISel",
    "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/Scalar",
  ]
  include_dirs = [ "." ]
  sources = [
    "SystemZAsmPrinter.cpp",
    "SystemZCallingConv.cpp",
    "SystemZConstantPoolValue.cpp",
    "SystemZElimCompare.cpp",
    "SystemZFrameLowering.cpp",
    "SystemZHazardRecognizer.cpp",
    "SystemZISelDAGToDAG.cpp",
    "SystemZISelLowering.cpp",
    "SystemZInstrInfo.cpp",
    "SystemZLDCleanup.cpp",
    "SystemZLongBranch.cpp",
    "SystemZMCInstLower.cpp",
    "SystemZMachineFunctionInfo.cpp",
    "SystemZMachineScheduler.cpp",
    "SystemZPostRewrite.cpp",
    "SystemZRegisterInfo.cpp",
    "SystemZSelectionDAGInfo.cpp",
    "SystemZShortenInst.cpp",
    "SystemZSubtarget.cpp",
    "SystemZTDC.cpp",
    "SystemZTargetMachine.cpp",
    "SystemZTargetTransformInfo.cpp",
  ]
}

# This is a bit different from most build files: Due to this group
# having the directory's name, "//llvm/lib/Target/SystemZ" 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("SystemZ") {
  deps = [
    ":LLVMSystemZCodeGen",
    "AsmParser",
    "Disassembler",
    "MCTargetDesc",
    "TargetInfo",
  ]
}