c8735093ef
which includes Makefile.nbincludes, whose beforedepend: has some race condition I don't fully understand, and which has been causing many (but not all!) -j16 builds on the autobuild cluster to fail in tools since sometime between 201103061600 and 201103070900. With the proper voodoo, I was able to get 8 builds in a row to fail without this change, and 16 in a row to succeed with it. XXX a proper fix likely involves reworking the beforedepend: target of Makefile.nbincludes, but this should get the build cluster back up to full functionality in the meanwhile.
234 lines
5.8 KiB
Makefile
234 lines
5.8 KiB
Makefile
# $NetBSD: Makefile,v 1.144 2011/03/17 19:06:45 riz Exp $
|
|
|
|
.include <bsd.own.mk>
|
|
|
|
.if defined(HAVE_GCC)
|
|
.if ${HAVE_GCC} == "4"
|
|
TOOLCHAIN_BITS= gmake .WAIT
|
|
.endif
|
|
.if ${TOOLCHAIN_MISSING} == "no"
|
|
TOOLCHAIN_BITS+= binutils .WAIT
|
|
TOOLCHAIN_BITS+= gcc
|
|
. if ${MKCROSSGDB:Uno} != "no"
|
|
TOOLCHAIN_BITS+= gdb
|
|
. endif
|
|
TOOLCHAIN_BITS+= .WAIT dbsym mdsetimage
|
|
# XXX Eventually, we want to be able to build dbsym and mdsetimage
|
|
# XXX if EXTERNAL_TOOLCHAIN is set.
|
|
.endif
|
|
.endif
|
|
|
|
.if defined(HAVE_PCC)
|
|
TOOLCHAIN_BITS= gmake .WAIT
|
|
.if ${TOOLCHAIN_MISSING} == "no"
|
|
TOOLCHAIN_BITS+= binutils .WAIT
|
|
TOOLCHAIN_BITS+= pcc
|
|
.endif
|
|
TOOLCHAIN_BITS+= .WAIT dbsym mdsetimage
|
|
.endif
|
|
|
|
DTRACE_BITS=
|
|
.if ${MKDTRACE} != "no"
|
|
DTRACE_BITS+= .WAIT libelf
|
|
DTRACE_BITS+= .WAIT libdwarf
|
|
DTRACE_BITS+= .WAIT libctf
|
|
DTRACE_BITS+= .WAIT ctfconvert ctfmerge
|
|
.endif
|
|
|
|
LINT_BITS=
|
|
.if ${MKLINT} != "no"
|
|
LINT_BITS= lint lint2
|
|
.endif
|
|
|
|
# Dependencies in SUBDIR below ordered to maximize parallel ability.
|
|
SUBDIR= host-mkdep .WAIT compat .WAIT \
|
|
binstall .WAIT mktemp .WAIT sed .WAIT \
|
|
cap_mkdb crunchgen ctags genassym gencat hexdump join \
|
|
${LINT_BITS} \
|
|
lorder makewhatis mkdep mtree rpcgen tic tsort \
|
|
uudecode m4 \
|
|
.WAIT texinfo \
|
|
.WAIT yacc \
|
|
.WAIT awk \
|
|
.WAIT lex \
|
|
.WAIT pax \
|
|
.WAIT ${TOOLCHAIN_BITS} \
|
|
${DTRACE_BITS} \
|
|
asn1_compile cat cksum compile_et config db \
|
|
file lint1 \
|
|
makefs .WAIT menuc mkcsmapper mkesdb mklocale mknod msgc \
|
|
.WAIT disklabel \
|
|
.WAIT paxctl \
|
|
.WAIT fdisk \
|
|
.WAIT installboot \
|
|
pwd_mkdb stat strfile sunlabel zic
|
|
|
|
.if ${MKLLVM} != "no"
|
|
SUBDIR+= \
|
|
llvm .WAIT \
|
|
llvm-lib/libLLVMSupport .WAIT \
|
|
llvm-tblgen .WAIT \
|
|
llvm-include .WAIT \
|
|
llvm-lib .WAIT \
|
|
llvm-clang
|
|
.endif
|
|
|
|
.if ${MKMAN} != "no" || ${MKDOC} != "no" || ${MKHTML} != "no"
|
|
. if ${MKGROFF} != "no"
|
|
SUBDIR+= groff
|
|
. endif
|
|
SUBDIR+= mandoc
|
|
.endif
|
|
|
|
.if ${MKMAINTAINERTOOLS:Uno} != "no"
|
|
SUBDIR+= autoconf .WAIT gettext
|
|
.endif
|
|
|
|
.if ${USE_PIGZGZIP} != "no"
|
|
SUBDIR+= pigz
|
|
.endif
|
|
|
|
.if ${MACHINE} == "hp700"
|
|
SUBDIR+= hp700-mkboot
|
|
.endif
|
|
|
|
.if ${MACHINE} == "ibmnws"
|
|
SUBDIR+= ibmnws-ncdcs
|
|
.endif
|
|
|
|
.if ${MACHINE} == "macppc"
|
|
SUBDIR+= macppc-fixcoff
|
|
.endif
|
|
|
|
.if (${MACHINE} == "prep" || ${MACHINE} == "rs6000" || ${MACHINE} == "bebox")
|
|
SUBDIR+= powerpc-mkbootimage
|
|
.endif
|
|
|
|
.if (${MACHINE_ARCH} == "mipsel" || ${MACHINE_ARCH} == "mipseb")
|
|
SUBDIR+= mips-elf2ecoff
|
|
.endif
|
|
|
|
.if (${MACHINE} == "sgimips")
|
|
SUBDIR+= sgivol
|
|
.endif
|
|
|
|
.if ${MACHINE} == "acorn32"
|
|
SUBDIR+= sparkcrc
|
|
.endif
|
|
|
|
.if (${MACHINE_ARCH} == "sparc" || ${MACHINE_ARCH} == "sparc64")
|
|
SUBDIR+= fgen
|
|
.endif
|
|
|
|
.if ${MACHINE} == "amiga"
|
|
SUBDIR+= amiga-elf2bb
|
|
SUBDIR+= amiga-txlt
|
|
.endif
|
|
|
|
.if ${MACHINE} == "hp300"
|
|
SUBDIR+= hp300-mkboot
|
|
.endif
|
|
|
|
.if ${MACHINE} == "evbarm" || ${MACHINE} == "evbmips" || \
|
|
${MACHINE} == "evbppc" || ${MACHINE} == "sandpoint"
|
|
SUBDIR+= mkubootimage
|
|
.endif
|
|
|
|
check_MKTOOLS: .PHONY .NOTMAIN
|
|
.if ${MKTOOLS:Uyes} == "no"
|
|
@echo '*** WARNING: "MKTOOLS" is set to "no"; this will prevent building and'
|
|
@echo '*** updating your host toolchain. This should be used only as a'
|
|
@echo '*** temporary workaround for toolchain problems, as it will result'
|
|
@echo '*** in version skew and build errors over time!'
|
|
.endif
|
|
|
|
.if ${MKTOOLS:Uyes} == "no" || ${USETOOLS} != "yes" # {
|
|
realall realdepend install: check_MKTOOLS
|
|
|
|
.for dir in ${SUBDIR:N.WAIT}
|
|
all-${dir} depend-${dir} dependall-${dir} install-${dir}:
|
|
@true
|
|
.endfor
|
|
.endif # }
|
|
|
|
.include <bsd.subdir.mk>
|
|
.include <bsd.obj.mk>
|
|
|
|
.if !defined(PREVIOUSTOOLDIR)
|
|
. if exists(PREVIOUSTOOLDIR)
|
|
PREVIOUSTOOLDIR!= cat PREVIOUSTOOLDIR
|
|
. else
|
|
PREVIOUSTOOLDIR=
|
|
. endif
|
|
.endif
|
|
|
|
CLEANFILES+= PREVIOUSTOOLDIR
|
|
|
|
realall realdepend: .MAKE
|
|
.if !empty(PREVIOUSTOOLDIR) && "${PREVIOUSTOOLDIR}" != "${TOOLDIR}"
|
|
@echo "*** WARNING: TOOLDIR has moved?"
|
|
@echo "*** PREVIOUSTOOLDIR '${PREVIOUSTOOLDIR}'"
|
|
@echo "*** != TOOLDIR '${TOOLDIR}'"
|
|
@echo "*** Cleaning mis-matched tools"
|
|
rm -f PREVIOUSTOOLDIR
|
|
(cd ${.CURDIR} && ${MAKE} PREVIOUSTOOLDIR=${TOOLDIR} cleandir)
|
|
.endif
|
|
echo ${TOOLDIR} >PREVIOUSTOOLDIR
|
|
|
|
# For each .WAIT point, make sure the immediately preceding target is
|
|
# installed before building anything after that point.
|
|
# (dsl: which means that with: 'a b .WAIT c' the build of 'c' waits for the
|
|
# install of 'b', but not the install of 'a'.)
|
|
#
|
|
# We use the "internal" targets and dependencies generated by <bsd.subdir.mk>
|
|
# to achieve this. These targets look like:
|
|
# subdir-all: all-dir1 [.WAIT] all-dir2 etc..
|
|
# subdir-install: install-dir1 [.WAIT] install-dir2 etc..
|
|
# and so on for each element in ${TARGETS}, with .WAIT sources inserted at
|
|
# places corresponding to the .WAITs in our $SUBDIR variable.
|
|
#
|
|
# Also, since we're now mixing `install' with `all' and `depend' targets
|
|
# an order relationship between those in each individual subdirectory
|
|
# must be established.
|
|
#
|
|
_deps:=
|
|
_prev:=
|
|
|
|
.for d in ${SUBDIR} # {
|
|
_this:= ${d}
|
|
|
|
.if ${_this} == ".WAIT" # {
|
|
|
|
# setup dependency to apply to all/depend targets in the next group
|
|
_deps:= ${_deps} ${_prev:S/^/install-/}
|
|
|
|
# if we're building *only* individual targets (i.e. "dependall-yacc"),
|
|
# make sure prerequisite tools build before installing
|
|
# XXX: dsl: this is likely to generate a dependency loop since there is
|
|
# a .ORDER releation between the nodes as well.
|
|
.if !make(all) && !make(dependall) && !make(install)
|
|
install-${_prev}: dependall-${_prev}
|
|
.endif
|
|
|
|
.else # ${_this} != ".WAIT" # } {
|
|
|
|
# order depend/all/install targets for ${d} subdir.
|
|
.ORDER: depend-${d} all-${d} dependall-${d} install-${d}
|
|
|
|
# prevent cleandir in real{all,depend} from interfering with subdir makes
|
|
.ORDER: realdepend dependall-${d}
|
|
.ORDER: realdepend depend-${d}
|
|
.ORDER: realall all-${d}
|
|
|
|
# make all/depend-${d} dependent on list of install targets
|
|
depend-${d} all-${d} dependall-${d}: ${_deps}
|
|
|
|
.endif # ${_this} != ".WAIT" # }
|
|
|
|
# stash current name in case the next entry is .WAIT
|
|
_prev:= ${d}
|
|
.endfor # }
|
|
|
|
cleandir:
|
|
rm -f ${CLEANFILES}
|