76d6892f91
dirdeps.mk and meta.autodep.mk will now look for Makefile.depend.options to handle optional dependencies, the work is all done by dirdeps-options.mk Also update to latest meta.stage.mk and gendirdeps.mk Reviewed by: bdrewery Differential Revision: https://reviews.freebsd.org/D15701
230 lines
6.3 KiB
Makefile
230 lines
6.3 KiB
Makefile
# $FreeBSD$
|
|
.if !target(_DIRDEP_USE)
|
|
# we are the 1st makefile
|
|
|
|
.if !defined(MK_CLANG)
|
|
.include "${SRCTOP}/share/mk/src.opts.mk"
|
|
.endif
|
|
|
|
# making universe is special
|
|
.if defined(UNIVERSE_GUARD)
|
|
# these should be done by now
|
|
DIRDEPS_FILTER+= N*.host
|
|
.endif
|
|
|
|
# pseudo machines get no qualification
|
|
.for m in host common
|
|
M_dep_qual_fixes += C;($m),[^/.,]*$$;\1;
|
|
.endfor
|
|
#.info M_dep_qual_fixes=${M_dep_qual_fixes}
|
|
|
|
# Cheat for including src.libnames.mk
|
|
__<bsd.init.mk>__:
|
|
# Pull in _INTERNALLIBS
|
|
.include <src.libnames.mk>
|
|
|
|
# Host libraries should mostly be excluded from the build so the
|
|
# host version in /usr/lib is used. Internal libraries need to be
|
|
# allowed to be built though since they are never installed.
|
|
_need_host_libs=
|
|
.for lib in ${_INTERNALLIBS}
|
|
_need_host_libs+= ${LIB${lib:tu}DIR:S,^${OBJTOP}/,,}
|
|
.endfor
|
|
|
|
N_host_libs:= ${cd ${SRCTOP} && echo lib/lib*:L:sh:${_need_host_libs:${M_ListToSkip}}:${M_ListToSkip}}
|
|
DIRDEPS_FILTER.host = \
|
|
${N_host_libs} \
|
|
Ninclude* \
|
|
Nlib/csu* \
|
|
Nlib/libc \
|
|
Nlib/[mn]* \
|
|
Ngnu/lib/csu* \
|
|
Ngnu/lib/lib[a-r]* \
|
|
Nsecure/lib* \
|
|
Nusr.bin/xinstall* \
|
|
|
|
|
|
DIRDEPS_FILTER+= \
|
|
Nbin/cat.host \
|
|
${DIRDEPS_FILTER.xtras:U}
|
|
|
|
# Cleanup a buildworld's WORLDTMP so that any files generated from it
|
|
# or using it will rebuild with the DIRDEPS SYSROOT. Otherwise existing
|
|
# object .meta files may still reference those directories and not be
|
|
# rebuilt and lead to incorrect Makefile.depend files due to lack of
|
|
# .dirdep files.
|
|
.if !defined(NO_CLEANUP_WORLDTMP) && exists(${OBJTOP}/tmp/_worldtmp)
|
|
cleanup_worldtmp: .PHONY .NOMETA
|
|
@echo "Cleaning leftover WORLDTMP from buildworld."
|
|
-rm -rf ${OBJTOP}/tmp/*
|
|
-chflags -R 0 ${OBJTOP}/tmp/*
|
|
rm -rf ${OBJTOP}/tmp
|
|
beforedirdeps: cleanup_worldtmp
|
|
.endif
|
|
.endif
|
|
|
|
# reset this each time
|
|
DIRDEPS_FILTER.xtras=
|
|
.if ${DEP_MACHINE:Npkgs*} != ""
|
|
DIRDEPS_FILTER.xtras+= Nusr.bin/clang/clang.host
|
|
.endif
|
|
|
|
.if ${DEP_MACHINE} != "host"
|
|
|
|
# this is how we can handle optional dependencies
|
|
.if ${DEP_RELDIR} == "lib/libc"
|
|
DIRDEPS += lib/libc_nonshared
|
|
.if ${MK_SSP:Uno} != "no"
|
|
DIRDEPS += gnu/lib/libssp/libssp_nonshared
|
|
.endif
|
|
.else
|
|
DIRDEPS_FILTER.xtras+= Nlib/libc_nonshared
|
|
.endif
|
|
|
|
# some optional things
|
|
.if ${MK_CTF} == "yes" && ${DEP_RELDIR:Mcddl/usr.bin/ctf*} == ""
|
|
DIRDEPS += \
|
|
cddl/usr.bin/ctfconvert.host \
|
|
cddl/usr.bin/ctfmerge.host
|
|
.endif
|
|
|
|
# Add in proper libgcc (gnu or LLVM) if not building libcc and libc is needed.
|
|
# Add both gcc_s and gcc_eh as dependencies as the decision to build
|
|
# -static or not is not known here.
|
|
.if ${DEP_RELDIR:M*libgcc*} == "" && ${DIRDEPS:U:Mlib/libc} != ""
|
|
.if ${MK_LLVM_LIBUNWIND} == "yes"
|
|
DIRDEPS+= \
|
|
lib/libgcc_eh \
|
|
lib/libgcc_s
|
|
.else
|
|
DIRDEPS+= gnu/lib/libgcc
|
|
.endif
|
|
.endif
|
|
|
|
# Bootstrap support. Give hints to DIRDEPS if there is no Makefile.depend*
|
|
# generated yet. This can be based on things such as SRC files and LIBADD.
|
|
# These hints will not factor into the final Makefile.depend as only what is
|
|
# used will be added in and handled via [local.]gendirdeps.mk. This is not
|
|
# done for MACHINE=host builds.
|
|
# XXX: Include this in local.autodep.mk as well for gendirdeps without filemon.
|
|
# Only do this for main build target
|
|
.if ${RELDIR} == ${DEP_RELDIR} && !defined(_RECURSING_PROGS)
|
|
.for _depfile in ${.MAKE.DEPENDFILE_PREFERENCE:T}
|
|
.if !defined(_have_depfile) && exists(${.CURDIR}/${_depfile})
|
|
_have_depfile=
|
|
.endif
|
|
.endfor
|
|
.if !defined(_have_depfile)
|
|
# KMOD does not use any stdlibs.
|
|
.if !defined(KMOD)
|
|
# Gather PROGS dependencies first
|
|
.if !empty(PROGS)
|
|
_PROGS_LIBADD=
|
|
_PROGS_DPADD=
|
|
_PROGS_SRCS=
|
|
.for _prog in ${PROGS}
|
|
.for s in . _
|
|
.if !empty(LIBADD${s}${_prog})
|
|
_PROGS_LIBADD+= ${LIBADD${s}${_prog}}
|
|
.endif
|
|
.if !empty(DPADD${s}${_prog})
|
|
_PROGS_DPADD+= ${DPADD${s}${_prog}}
|
|
.endif
|
|
.if !empty(SRCS${s}${_prog})
|
|
_PROGS_SRCS+= ${SRCS${s}${_prog}}
|
|
.endif
|
|
.endfor # .for s in . _
|
|
# Add in assumed source (bsd.prog.mk)
|
|
.if !target(${_prog})
|
|
.if defined(PROG_CXX)
|
|
_PROGS_SRCS+= ${_prog}.cc
|
|
.else
|
|
_PROGS_SRCS+= ${_prog}.c
|
|
.endif
|
|
.endif # !target(${_prog})
|
|
.endfor # .for _prog in ${PROGS}
|
|
.endif # !empty(PROGS)
|
|
_SRCS= ${SRCS} ${_PROGS_SRCS}
|
|
|
|
# Has C files. The C_DIRDEPS are shared with C++ files as well.
|
|
C_DIRDEPS= \
|
|
gnu/lib/csu \
|
|
include \
|
|
include/arpa \
|
|
include/protocols \
|
|
include/rpc \
|
|
include/rpcsvc \
|
|
include/xlocale \
|
|
lib/${CSU_DIR} \
|
|
lib/libc \
|
|
lib/libcompiler_rt \
|
|
|
|
# libgcc is needed as well but is added later.
|
|
|
|
.if ${MK_GSSAPI} != "no"
|
|
C_DIRDEPS+= include/gssapi
|
|
.endif
|
|
|
|
.if !empty(_SRCS:M*.c)
|
|
DIRDEPS+= ${C_DIRDEPS}
|
|
.endif
|
|
# Has C++ files
|
|
.if !empty(_SRCS:M*.cc) || !empty(_SRCS:M*.C) || !empty(_SRCS:M*.cpp) || \
|
|
!empty(_SRCS:M*.cxx)
|
|
DIRDEPS+= ${C_DIRDEPS}
|
|
.if ${MK_CLANG} == "yes"
|
|
DIRDEPS+= lib/libc++ lib/libcxxrt
|
|
.else
|
|
DIRDEPS+= gnu/lib/libstdc++ gnu/lib/libsupc++
|
|
.endif
|
|
# XXX: Clang and GCC always adds -lm currently, even when not needed.
|
|
DIRDEPS+= lib/msun
|
|
.endif # CXX
|
|
.endif # !defined(KMOD)
|
|
# Has yacc files.
|
|
.if !empty(_SRCS:M*.y)
|
|
DIRDEPS+= usr.bin/yacc.host
|
|
.endif
|
|
_DPADD= ${DPADD} ${_PROGS_DPADD}
|
|
.if !empty(_DPADD)
|
|
# Taken from meta.autodep.mk (where it only does something with
|
|
# BUILD_AT_LEVEL0, which we don't use).
|
|
# This only works for DPADD with full OBJ/SRC paths, which is mostly just
|
|
# _INTERNALLIBS.
|
|
_DP_DIRDEPS= \
|
|
${_DPADD:O:u:M${OBJTOP}*:H:N.:tA:C,${OBJTOP}[^/]*/,,:N.:O:u} \
|
|
${_DPADD:O:u:M${OBJROOT}*:N${OBJTOP}*:N${STAGE_ROOT}/*:H:S,${OBJROOT},,:C,^([^/]+)/(.*),\2.\1,:S,${HOST_TARGET}$,host,:N.*:O:u}
|
|
# Resolve the paths to RELDIRs
|
|
.if !empty(_DP_DIRDEPS)
|
|
DIRDEPS+= ${_DP_DIRDEPS:C,^,${SRCTOP}/,:tA:C,^${SRCTOP}/,,}
|
|
.endif
|
|
.endif # !empty(DPADD)
|
|
_ALL_LIBADD= ${LIBADD} ${_PROGS_LIBADD}
|
|
.if !empty(_ALL_LIBADD)
|
|
# Also handle LIBADD for non-internal libraries.
|
|
.for _lib in ${_ALL_LIBADD:O:u}
|
|
_lib${_lib}reldir= ${LIB${_lib:tu}DIR:C,${OBJTOP}/,,}
|
|
.if defined(LIB${_lib:tu}DIR) && ${DIRDEPS:M${_lib${_lib}reldir}} == "" && \
|
|
exists(${SRCTOP}/${_lib${_lib}reldir})
|
|
DIRDEPS+= ${_lib${_lib}reldir}
|
|
.endif
|
|
.endfor
|
|
.endif # !empty(LIBADD)
|
|
.endif # no Makefile.depend*
|
|
.endif # ${RELDIR} == ${DEP_RELDIR}
|
|
|
|
.endif # ${DEP_MACHINE} != "host"
|
|
|
|
.if ${MK_STAGING} == "yes"
|
|
# we need targets/pseudo/stage to prep the stage tree
|
|
.if ${DEP_RELDIR} != "targets/pseudo/stage"
|
|
DIRDEPS += targets/pseudo/stage
|
|
.endif
|
|
.endif
|
|
|
|
DEP_MACHINE_ARCH = ${MACHINE_ARCH.${DEP_MACHINE}}
|
|
CSU_DIR.${DEP_MACHINE_ARCH} ?= csu/${DEP_MACHINE_ARCH}
|
|
CSU_DIR := ${CSU_DIR.${DEP_MACHINE_ARCH}}
|
|
BOOT_MACHINE_DIR:= ${BOOT_MACHINE_DIR.${DEP_MACHINE}}
|
|
KERNEL_NAME:= ${KERNEL_NAME.${DEP_MACHINE}}
|