1# $FreeBSD$ 2 3.include <src.opts.mk> 4 5LLVM_SRCS= ${SRCTOP}/contrib/llvm 6LLD_SRCS= ${LLVM_SRCS}/tools/lld 7 8PACKAGE= lld 9PROG_CXX= ld.lld 10MAN= 11.if ${MK_LLD_IS_LD} != "no" 12SYMLINKS= ${PROG_CXX} ${BINDIR}/ld 13.endif 14 15CFLAGS+= -I${LLD_SRCS}/ELF 16CFLAGS+= -I${LLD_SRCS}/include 17CFLAGS+= -I${.OBJDIR} 18CFLAGS+= -I${OBJTOP}/lib/clang/libllvm 19 20SRCDIR= tools/lld 21SRCS+= ELF/Arch/AArch64.cpp 22SRCS+= ELF/Arch/AMDGPU.cpp 23SRCS+= ELF/Arch/ARM.cpp 24SRCS+= ELF/Arch/AVR.cpp 25SRCS+= ELF/Arch/Mips.cpp 26SRCS+= ELF/Arch/MipsArchTree.cpp 27SRCS+= ELF/Arch/PPC.cpp 28SRCS+= ELF/Arch/PPC64.cpp 29SRCS+= ELF/Arch/SPARCV9.cpp 30SRCS+= ELF/Arch/X86.cpp 31SRCS+= ELF/Arch/X86_64.cpp 32SRCS+= ELF/Driver.cpp 33SRCS+= ELF/DriverUtils.cpp 34SRCS+= ELF/EhFrame.cpp 35SRCS+= ELF/Error.cpp 36SRCS+= ELF/Filesystem.cpp 37SRCS+= ELF/GdbIndex.cpp 38SRCS+= ELF/ICF.cpp 39SRCS+= ELF/InputFiles.cpp 40SRCS+= ELF/InputSection.cpp 41SRCS+= ELF/LTO.cpp 42SRCS+= ELF/LinkerScript.cpp 43SRCS+= ELF/MapFile.cpp 44SRCS+= ELF/MarkLive.cpp 45SRCS+= ELF/OutputSections.cpp 46SRCS+= ELF/Relocations.cpp 47SRCS+= ELF/ScriptLexer.cpp 48SRCS+= ELF/ScriptParser.cpp 49SRCS+= ELF/Strings.cpp 50SRCS+= ELF/SymbolTable.cpp 51SRCS+= ELF/Symbols.cpp 52SRCS+= ELF/SyntheticSections.cpp 53SRCS+= ELF/Target.cpp 54SRCS+= ELF/Thunks.cpp 55SRCS+= ELF/Writer.cpp 56SRCS+= lib/Config/Version.cpp 57SRCS+= lib/Core/Error.cpp 58SRCS+= lib/Core/File.cpp 59SRCS+= lib/Core/LinkingContext.cpp 60SRCS+= lib/Core/Reader.cpp 61SRCS+= lib/Core/Reproduce.cpp 62SRCS+= lib/Core/Resolver.cpp 63SRCS+= lib/Core/SymbolTable.cpp 64SRCS+= lib/Core/TargetOptionsCommandFlags.cpp 65SRCS+= tools/lld/lld.cpp 66 67.include "${SRCTOP}/lib/clang/llvm.build.mk" 68 69LIBDEPS+= llvm 70 71.for lib in ${LIBDEPS} 72DPADD+= ${OBJTOP}/lib/clang/lib${lib}/lib${lib}.a 73LDADD+= ${OBJTOP}/lib/clang/lib${lib}/lib${lib}.a 74.endfor 75 76LLVM_TBLGEN?= llvm-tblgen 77ELF/Options.inc: ${LLD_SRCS}/ELF/Options.td 78 ${LLVM_TBLGEN} -gen-opt-parser-defs \ 79 -I ${LLVM_SRCS}/include \ 80 -d ${.TARGET:C/$/.d/} -o ${.TARGET} \ 81 ${LLVM_SRCS}/tools/lld/ELF/Options.td 82TGHDRS+= ELF/Options.inc 83 84DPSRCS+= ${TGHDRS} 85CLEANFILES+= ${TGHDRS} ${TGHDRS:C/$/.d/} 86 87LIBADD+= ncursesw 88LIBADD+= pthread 89LIBADD+= z 90 91.include <bsd.prog.mk> 92