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