xref: /freebsd/usr.bin/clang/lld/Makefile (revision 770cf0a5f02dc8983a89c6568d741fbc25baa999)
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