]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - usr.bin/clang/lld/Makefile
THIS BRANCH IS OBSOLETE, PLEASE READ:
[FreeBSD/FreeBSD.git] / usr.bin / clang / lld / Makefile
1 # $FreeBSD$
2
3 .include <src.opts.mk>
4
5 LLVM_BASE=      ${SRCTOP}/contrib/llvm-project
6 LLVM_SRCS=      ${LLVM_BASE}/llvm
7 LLD_SRCS=       ${LLVM_BASE}/lld
8
9 PACKAGE=        lld
10 PROG_CXX=       ld.lld
11 # Man page directory
12 .PATH:          ${LLD_SRCS}/docs
13 .if (!defined(TOOLS_PREFIX) && ${MK_LLD_IS_LD} != "no") || \
14     (defined(TOOLS_PREFIX) && ${MK_LLD_BOOTSTRAP} != "no")
15 SYMLINKS=       ${PROG_CXX} ${BINDIR}/ld
16 MLINKS=         ld.lld.1 ld.1
17 .endif
18
19 .if ${MK_SHARED_TOOLCHAIN} == "no"
20 NO_SHARED?= yes
21 .endif
22
23 CFLAGS+=        -I${LLD_SRCS}/ELF
24 CFLAGS+=        -I${LLD_SRCS}/include
25 CFLAGS+=        -I${.OBJDIR}
26 CFLAGS+=        -I${OBJTOP}/lib/clang/libllvm
27
28 SRCDIR=         lld
29 SRCS+=          Common/Args.cpp
30 SRCS+=          Common/DWARF.cpp
31 SRCS+=          Common/ErrorHandler.cpp
32 SRCS+=          Common/Filesystem.cpp
33 SRCS+=          Common/Memory.cpp
34 SRCS+=          Common/Reproduce.cpp
35 SRCS+=          Common/Strings.cpp
36 SRCS+=          Common/TargetOptionsCommandFlags.cpp
37 SRCS+=          Common/Version.cpp
38 SRCS+=          ELF/AArch64ErrataFix.cpp
39 SRCS+=          ELF/ARMErrataFix.cpp
40 SRCS+=          ELF/Arch/AArch64.cpp
41 SRCS+=          ELF/Arch/AMDGPU.cpp
42 SRCS+=          ELF/Arch/ARM.cpp
43 SRCS+=          ELF/Arch/AVR.cpp
44 SRCS+=          ELF/Arch/Hexagon.cpp
45 SRCS+=          ELF/Arch/MSP430.cpp
46 SRCS+=          ELF/Arch/Mips.cpp
47 SRCS+=          ELF/Arch/MipsArchTree.cpp
48 SRCS+=          ELF/Arch/PPC.cpp
49 SRCS+=          ELF/Arch/PPC64.cpp
50 SRCS+=          ELF/Arch/RISCV.cpp
51 SRCS+=          ELF/Arch/SPARCV9.cpp
52 SRCS+=          ELF/Arch/X86.cpp
53 SRCS+=          ELF/Arch/X86_64.cpp
54 SRCS+=          ELF/CallGraphSort.cpp
55 SRCS+=          ELF/DWARF.cpp
56 SRCS+=          ELF/Driver.cpp
57 SRCS+=          ELF/DriverUtils.cpp
58 SRCS+=          ELF/EhFrame.cpp
59 SRCS+=          ELF/ICF.cpp
60 SRCS+=          ELF/InputFiles.cpp
61 SRCS+=          ELF/InputSection.cpp
62 SRCS+=          ELF/LTO.cpp
63 SRCS+=          ELF/LinkerScript.cpp
64 SRCS+=          ELF/MapFile.cpp
65 SRCS+=          ELF/MarkLive.cpp
66 SRCS+=          ELF/OutputSections.cpp
67 SRCS+=          ELF/Relocations.cpp
68 SRCS+=          ELF/ScriptLexer.cpp
69 SRCS+=          ELF/ScriptParser.cpp
70 SRCS+=          ELF/SymbolTable.cpp
71 SRCS+=          ELF/Symbols.cpp
72 SRCS+=          ELF/SyntheticSections.cpp
73 SRCS+=          ELF/Target.cpp
74 SRCS+=          ELF/Thunks.cpp
75 SRCS+=          ELF/Writer.cpp
76 SRCS+=          lib/Core/Error.cpp
77 SRCS+=          lib/Core/File.cpp
78 SRCS+=          lib/Core/LinkingContext.cpp
79 SRCS+=          lib/Core/Reader.cpp
80 SRCS+=          lib/Core/Resolver.cpp
81 SRCS+=          lib/Core/SymbolTable.cpp
82 SRCS+=          tools/lld/lld.cpp
83
84 .include "${SRCTOP}/lib/clang/llvm.build.mk"
85
86 LIBDEPS+=       llvm
87
88 .for lib in ${LIBDEPS}
89 DPADD+=         ${OBJTOP}/lib/clang/lib${lib}/lib${lib}.a
90 LDADD+=         ${OBJTOP}/lib/clang/lib${lib}/lib${lib}.a
91 .endfor
92
93 LLVM_TBLGEN?=   llvm-tblgen
94 INCFILE=        Options.inc
95 TDFILE=         ${LLD_SRCS}/ELF/Options.td
96 GENOPT=         -gen-opt-parser-defs
97 ${INCFILE}: ${TDFILE}
98         ${LLVM_TBLGEN} ${GENOPT} -I ${LLVM_SRCS}/include -d ${.TARGET:C/$/.d/} \
99             -o ${.TARGET} ${TDFILE}
100 TGHDRS+=        ${INCFILE}
101
102 DPSRCS+=        ${TGHDRS}
103 CLEANFILES+=    ${TGHDRS} ${TGHDRS:C/$/.d/}
104
105 LIBADD+=        execinfo
106 LIBADD+=        ncursesw
107 LIBADD+=        pthread
108 LIBADD+=        z
109
110 .include <bsd.prog.mk>