5 LLVM_BASE= ${SRCTOP}/contrib/llvm-project
6 LLVM_SRCS= ${LLVM_BASE}/llvm
7 LLD_SRCS= ${LLVM_BASE}/lld
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
19 .if ${MK_SHARED_TOOLCHAIN} == "no"
23 CFLAGS+= -I${LLD_SRCS}/ELF
24 CFLAGS+= -I${LLD_SRCS}/include
26 CFLAGS+= -I${OBJTOP}/lib/clang/libllvm
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
57 SRCS+= ELF/DriverUtils.cpp
58 SRCS+= ELF/EhFrame.cpp
60 SRCS+= ELF/InputFiles.cpp
61 SRCS+= ELF/InputSection.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
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
84 .include "${SRCTOP}/lib/clang/llvm.build.mk"
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
93 LLVM_TBLGEN?= llvm-tblgen
95 TDFILE= ${LLD_SRCS}/ELF/Options.td
96 GENOPT= -gen-opt-parser-defs
98 ${LLVM_TBLGEN} ${GENOPT} -I ${LLVM_SRCS}/include -d ${.TARGET:C/$/.d/} \
99 -o ${.TARGET} ${TDFILE}
103 CLEANFILES+= ${TGHDRS} ${TGHDRS:C/$/.d/}
110 .include <bsd.prog.mk>