1 # from: @(#)bsd.prog.mk 5.26 (Berkeley) 6/25/91
5 .include <bsd.compiler.mk>
6 .include <bsd.linker.mk>
8 .SUFFIXES: .out .o .bc .c .cc .cpp .cxx .C .m .y .l .ll .ln .s .S .asm
10 # XXX The use of COPTS in modern makefiles is discouraged.
12 .warning ${.CURDIR}: COPTS should be CFLAGS.
16 .if ${MK_ASSERT_DEBUG} == "no"
21 .if defined(DEBUG_FLAGS)
22 CFLAGS+=${DEBUG_FLAGS}
23 CXXFLAGS+=${DEBUG_FLAGS}
25 .if ${MK_CTF} != "no" && ${DEBUG_FLAGS:M-g} != ""
34 .if !empty(LDFLAGS:M-Wl,*--oformat,*) || !empty(LDFLAGS:M-static)
39 .if ${MK_BIND_NOW} != "no"
42 .if ${MK_PIE} != "no" && (!defined(NO_SHARED) || ${NO_SHARED:tl} == "no")
47 .if ${MK_RETPOLINE} != "no"
48 .if ${COMPILER_FEATURES:Mretpoline} && ${LINKER_FEATURES:Mretpoline}
50 CXXFLAGS+= -mretpoline
51 # retpolineplt is broken with static linking (PR 233336)
52 .if !defined(NO_SHARED) || ${NO_SHARED:tl} == "no"
53 LDFLAGS+= -Wl,-zretpolineplt
56 .warning Retpoline requested but not supported by compiler or linker
60 .if ${MACHINE_CPUARCH} == "riscv" && ${LINKER_FEATURES:Mriscv-relaxations} == ""
64 .if defined(CRUNCH_CFLAGS)
65 CFLAGS+=${CRUNCH_CFLAGS}
67 .if ${MK_DEBUG_FILES} != "no" && empty(DEBUG_FLAGS:M-g) && \
68 empty(DEBUG_FLAGS:M-gdwarf-*)
69 CFLAGS+= ${DEBUG_FILES_CFLAGS}
74 .if !defined(DEBUG_FLAGS)
79 .if !defined(TAGS) || ! ${TAGS:Mpackage=*}
80 TAGS+= package=${PACKAGE:Uutilities}
82 TAG_ARGS= -T ${TAGS:[*]:S/ /,/g}
85 .if defined(NO_SHARED) && ${NO_SHARED:tl} != "no"
89 # clang currently defaults to dynamic TLS for mips64 binaries
90 .if ${MACHINE_ARCH:Mmips64*} && ${COMPILER_TYPE} == "clang"
91 CFLAGS+= -ftls-model=initial-exec
94 .if ${MK_DEBUG_FILES} != "no"
95 PROG_FULL=${PROG}.full
96 # Use ${DEBUGDIR} for base system debug files, else .debug subdirectory
97 .if defined(BINDIR) && (\
98 ${BINDIR} == "/bin" ||\
99 ${BINDIR:C%/libexec(/.*)?%/libexec%} == "/libexec" ||\
100 ${BINDIR} == "/sbin" ||\
101 ${BINDIR:C%/usr/(bin|bsdinstall|libexec|lpr|sendmail|sm.bin|sbin|tests)(/.*)?%/usr/bin%} == "/usr/bin" ||\
102 ${BINDIR} == "/usr/lib" \
104 DEBUGFILEDIR= ${DEBUGDIR}${BINDIR}
106 DEBUGFILEDIR?= ${BINDIR}/.debug
108 .if !exists(${DESTDIR}${DEBUGFILEDIR})
120 OBJS+= ${SRCS:N*.h:${OBJS_SRCS_FILTER:ts:}:S/$/.o/g}
122 # LLVM bitcode / textual IR representations of the program
123 BCOBJS+=${SRCS:N*.[hsS]:N*.asm:${OBJS_SRCS_FILTER:ts:}:S/$/.bco/g}
124 LLOBJS+=${SRCS:N*.[hsS]:N*.asm:${OBJS_SRCS_FILTER:ts:}:S/$/.llo/g}
126 .if target(beforelinking)
127 beforelinking: ${OBJS}
128 ${PROG_FULL}: beforelinking
130 ${PROG_FULL}: ${OBJS}
131 .if defined(PROG_CXX)
132 ${CXX:N${CCACHE_BIN}} ${CXXFLAGS:N-M*} ${LDFLAGS} -o ${.TARGET} \
135 ${CC:N${CCACHE_BIN}} ${CFLAGS:N-M*} ${LDFLAGS} -o ${.TARGET} ${OBJS} \
138 .if ${MK_CTF} != "no"
139 ${CTFMERGE} ${CTFFLAGS} -o ${.TARGET} ${OBJS}
142 .else # !defined(SRCS)
145 .if defined(PROG_CXX)
151 # Always make an intermediate object file because:
152 # - it saves time rebuilding when only the library has changed
153 # - the name of the object gets put into the executable symbol table instead of
154 # the name of a variable temporary object.
155 # - it's useful to keep objects around for crunching.
159 CLEANFILES+= ${PROG}.o ${PROG}.bc ${PROG}.ll
161 .if target(beforelinking)
162 beforelinking: ${OBJS}
163 ${PROG_FULL}: beforelinking
165 ${PROG_FULL}: ${OBJS}
166 .if defined(PROG_CXX)
167 ${CXX:N${CCACHE_BIN}} ${CXXFLAGS:N-M*} ${LDFLAGS} -o ${.TARGET} \
170 ${CC:N${CCACHE_BIN}} ${CFLAGS:N-M*} ${LDFLAGS} -o ${.TARGET} ${OBJS} \
173 .if ${MK_CTF} != "no"
174 ${CTFMERGE} ${CTFFLAGS} -o ${.TARGET} ${OBJS}
176 .endif # !target(${PROG})
178 .endif # !defined(SRCS)
180 .if ${MK_DEBUG_FILES} != "no"
181 ${PROG}: ${PROG_FULL} ${PROGNAME}.debug
182 ${OBJCOPY} --strip-debug --add-gnu-debuglink=${PROGNAME}.debug \
183 ${PROG_FULL} ${.TARGET}
185 ${PROGNAME}.debug: ${PROG_FULL}
186 ${OBJCOPY} --only-keep-debug ${PROG_FULL} ${.TARGET}
189 .if defined(LLVM_LINK)
190 ${PROG_FULL}.bc: ${BCOBJS}
191 ${LLVM_LINK} -o ${.TARGET} ${BCOBJS}
193 ${PROG_FULL}.ll: ${LLOBJS}
194 ${LLVM_LINK} -S -o ${.TARGET} ${LLOBJS}
196 CLEANFILES+= ${PROG_FULL}.bc ${PROG_FULL}.ll
197 .endif # defined(LLVM_LINK)
199 .if ${MK_MAN} != "no" && !defined(MAN) && \
200 !defined(MAN1) && !defined(MAN2) && !defined(MAN3) && \
201 !defined(MAN4) && !defined(MAN5) && !defined(MAN6) && \
202 !defined(MAN7) && !defined(MAN8) && !defined(MAN9)
206 .endif # defined(PROG)
208 .if defined(_SKIP_BUILD)
211 all: ${PROG} ${SCRIPTS}
212 .if ${MK_MAN} != "no"
218 CLEANFILES+= ${PROG} ${PROG}.bc ${PROG}.ll
219 .if ${MK_DEBUG_FILES} != "no"
220 CLEANFILES+= ${PROG_FULL} ${PROGNAME}.debug
225 CLEANFILES+= ${OBJS} ${BCOBJS} ${LLOBJS}
228 .include <bsd.libnames.mk>
231 .if !defined(NO_EXTRADEPEND)
233 .if defined(LDFLAGS) && !empty(LDFLAGS:M-nostdlib)
234 .if defined(DPADD) && !empty(DPADD)
235 echo ${PROG_FULL}: ${DPADD} >> ${DEPENDFILE}
238 echo ${PROG_FULL}: ${LIBC} ${DPADD} >> ${DEPENDFILE}
239 .if defined(PROG_CXX)
240 .if ${COMPILER_TYPE} == "clang" && empty(CXXFLAGS:M-stdlib=libstdc++)
241 echo ${PROG_FULL}: ${LIBCPLUSPLUS} >> ${DEPENDFILE}
243 echo ${PROG_FULL}: ${LIBSTDCPLUSPLUS} >> ${DEPENDFILE}
247 .endif # !defined(NO_EXTRADEPEND)
252 .if defined(PRECIOUSPROG)
253 .if !defined(NO_FSCHG)
254 INSTALLFLAGS+= -fschg
259 _INSTALLFLAGS:= ${INSTALLFLAGS}
260 .for ie in ${INSTALLFLAGS_EDIT}
261 _INSTALLFLAGS:= ${_INSTALLFLAGS${ie}}
264 .if !target(realinstall) && !defined(INTERNALPROG)
265 realinstall: _proginstall
266 .ORDER: beforeinstall _proginstall
269 ${INSTALL} ${TAG_ARGS} ${STRIP} -o ${BINOWN} -g ${BINGRP} -m ${BINMODE} \
270 ${_INSTALLFLAGS} ${PROG} ${DESTDIR}${BINDIR}/${PROGNAME}
271 .if ${MK_DEBUG_FILES} != "no"
272 .if defined(DEBUGMKDIR)
273 ${INSTALL} ${TAG_ARGS:D${TAG_ARGS},debug} -d ${DESTDIR}${DEBUGFILEDIR}/
275 ${INSTALL} ${TAG_ARGS:D${TAG_ARGS},debug} -o ${BINOWN} -g ${BINGRP} -m ${DEBUGMODE} \
276 ${PROGNAME}.debug ${DESTDIR}${DEBUGFILEDIR}/${PROGNAME}.debug
279 .endif # !target(realinstall)
281 .if defined(SCRIPTS) && !empty(SCRIPTS)
282 realinstall: _scriptsinstall
283 .ORDER: beforeinstall _scriptsinstall
285 SCRIPTSDIR?= ${BINDIR}
286 SCRIPTSOWN?= ${BINOWN}
287 SCRIPTSGRP?= ${BINGRP}
288 SCRIPTSMODE?= ${BINMODE}
290 STAGE_AS_SETS+= scripts
291 stage_as.scripts: ${SCRIPTS}
292 FLAGS.stage_as.scripts= -m ${SCRIPTSMODE}
293 STAGE_FILES_DIR.scripts= ${STAGE_OBJTOP}
294 .for script in ${SCRIPTS}
295 .if defined(SCRIPTSNAME)
296 SCRIPTSNAME_${script:T}?= ${SCRIPTSNAME}
298 SCRIPTSNAME_${script:T}?= ${script:T:R}
300 SCRIPTSDIR_${script:T}?= ${SCRIPTSDIR}
301 SCRIPTSOWN_${script:T}?= ${SCRIPTSOWN}
302 SCRIPTSGRP_${script:T}?= ${SCRIPTSGRP}
303 SCRIPTSMODE_${script:T}?= ${SCRIPTSMODE}
304 STAGE_AS_${script:T}= ${SCRIPTSDIR_${script:T}}/${SCRIPTSNAME_${script:T}}
305 _scriptsinstall: _SCRIPTSINS_${script:T}
306 _SCRIPTSINS_${script:T}: ${script}
307 ${INSTALL} ${TAG_ARGS} -o ${SCRIPTSOWN_${.ALLSRC:T}} \
308 -g ${SCRIPTSGRP_${.ALLSRC:T}} -m ${SCRIPTSMODE_${.ALLSRC:T}} \
310 ${DESTDIR}${SCRIPTSDIR_${.ALLSRC:T}}/${SCRIPTSNAME_${.ALLSRC:T}}
315 .include <bsd.nls.mk>
317 .include <bsd.confs.mk>
318 .include <bsd.files.mk>
319 .include <bsd.incs.mk>
323 LINKMODE?= ${BINMODE}
324 .include <bsd.links.mk>
326 .if ${MK_MAN} != "no"
327 realinstall: maninstall
328 .ORDER: beforeinstall maninstall
331 .endif # !target(install)
333 .if ${MK_MAN} != "no"
334 .include <bsd.man.mk>
337 .if defined(HAS_TESTS)
338 MAKE+= MK_MAKE_CHECK_USE_SANDBOX=yes
339 SUBDIR_TARGETS+= check
340 TESTS_LD_LIBRARY_PATH+= ${.OBJDIR}
341 TESTS_PATH+= ${.OBJDIR}
345 OBJS_DEPEND_GUESS+= ${SRCS:M*.h}
348 .include <bsd.dep.mk>
349 .include <bsd.clang-analyze.mk>
350 .include <bsd.obj.mk>
351 .include <bsd.sys.mk>