# $NetBSD: bootstrap.mk,v 1.11 2014/09/26 07:00:50 obache Exp $ # ----------------------------------------------------------------------------- # Select a bindist of bootstrapping compiler based on a per-platform # basis. # # BOOT_ARCHIVE # This variable is set to the name of compressed archive file of a # bootstrapping compiler for the current platform. # # BOOT_TARBALL # Similar to BOOT_ARCHIVE, but "*.tar" not "*.tar.xz". # .include "../../mk/bsd.prefs.mk" .if ${MACHINE_ARCH} == "i386" && ${OPSYS} == "FreeBSD" BOOT_ARCHIVE:= ${PKGNAME}-boot-i386-unknown-freebsd.tar.xz .elif ${MACHINE_ARCH} == "i386" && ${OPSYS} == "NetBSD" BOOT_ARCHIVE:= ${PKGNAME}-boot-i386-unknown-netbsd.tar.xz .elif ${MACHINE_ARCH} == "powerpc" && ${OPSYS} == "Darwin" BOOT_ARCHIVE:= ${PKGNAME_NOREV}-boot-powerpc-apple-darwin.tar.xz # Existence of libelf makes LeadingUnderscore being "NO", which is # incorrect for this platform. See ${WRKSRC}/aclocal.m4 # (FP_LEADING_UNDERSCORE) CONFLICTS+= libelf-[0-9]* .elif ${MACHINE_ARCH} == "x86_64" && ${OPSYS} == "Linux" BOOT_ARCHIVE:= ${PKGNAME}-boot-x86_64-unknown-linux.tar.xz .elif ${MACHINE_ARCH} == "x86_64" && ${OPSYS} == "NetBSD" BOOT_ARCHIVE:= ${PKGNAME}-boot-x86_64-unknown-netbsd.tar.xz .elif !empty(MACHINE_PLATFORM:MSunOS-5.11-i386) BOOT_ARCHIVE:= ${PKGNAME}-boot-i386-unknown-solaris2.tar.xz .elif !empty(MACHINE_PLATFORM:MSunOS-5.11-x86_64) BOOT_ARCHIVE:= ${PKGNAME}-boot-x86_64-unknown-solaris2.tar.xz .else PKG_FAIL_REASON+= "internal error: unsupported platform" .endif # current bootstrap binary kit for SmartOS is built with ncurses5 .if !empty(MACHINE_PLATFORM:MSunOS-5.11-*) && !empty(OS_VARIANT:U:MSmartOS) BUILD_DEPENDS+= ncurses>=5.0:../../devel/ncurses .endif BOOT_TARBALL= ${BOOT_ARCHIVE:C/\.xz$//} # ----------------------------------------------------------------------------- # The "pre-configure" hook # # Install a bootstrapping compiler directly into TOOLS_DIR so that # ./configure can find it. # USE_TOOLS+= gmake xzcat xz pre-configure: @${TEST} -f ${DISTDIR:Q}/${DIST_SUBDIR:Q}/${BOOT_ARCHIVE} || \ ${FAIL_MSG} "Put your trusted bootstrap archive as ${DISTDIR}/${DIST_SUBDIR}/${BOOT_ARCHIVE}" @${PHASE_MSG} "Extracting bootstrapping compiler for ${PKGNAME}" ${RUN} ${MKDIR} ${WRKDIR:Q}/build-extract ${RUN} cd ${WRKDIR:Q}/build-extract && \ ${EXTRACT_CMD_DEFAULT} ${DISTDIR:Q}/${DIST_SUBDIR:Q}/${BOOT_ARCHIVE} @${PHASE_MSG} "Preparing bootstrapping compiler for ${PKGNAME}" ${RUN} cd ${WRKDIR:Q}/build-extract/${PKGNAME_NOREV}-boot && \ ${SH} ./configure \ --prefix=${TOOLS_DIR:Q} && \ ${MAKE_PROGRAM} install # ----------------------------------------------------------------------------- # An unusual target "bootstrap" # # Build a bootstrapping compiler using an already installed GHC. This # can certainly impossible if you don't have one. It's absolutely # important to build it with the fewest possible run-time # dependencies, otherwise the resulting binary can easily get # unusable. # .PHONY: bootstrap #BUILDLINK_PASSTHRU_DIRS= ${PREFIX}/lib/${PKGNAME_NOREV} bootstrap: pre-bootstrap .WAIT ${WRKDIR}/${BOOT_ARCHIVE} @${PHASE_MSG} "Done creating" ${WRKDIR}/${BOOT_ARCHIVE} .PHONY: pre-bootstrap pre-bootstrap: @${TEST} \! -f ${_COOKIE.configure} || \ (${ERROR_MSG} "You have already configured the package in a way\ that building bootstrapping compiler is impossible."; \ ${FAIL_MSG} "Please run \"${MAKE} clean patch\" first."); @${TEST} -f ${_COOKIE.patch} || \ ${FAIL_MSG} "Please run \"${MAKE} patch\" first." @${DO_NADA} ${WRKDIR}/lndir: @${PHASE_MSG} "Building lndir(1) to duplicate the source tree." cd ${WRKSRC:Q}/utils/lndir && \ ${PKG_CC:Q} lndir.c -o ${.TARGET} ${WRKDIR}/stamp-lndir-boot: ${WRKDIR}/lndir @${PHASE_MSG} "Duplicating the source tree for bootstrapping ${PKGNAME_NOREV}" ${MKDIR} ${WRKDIR:Q}/build-boot cd ${WRKDIR:Q}/build-boot && \ ${WRKDIR}/lndir -silent ../${PKGNAME_NOREV:Q} ${TOUCH} ${.TARGET} ${WRKDIR}/stamp-configure-boot: ${WRKDIR}/stamp-lndir-boot @${PHASE_MSG} "Configuring bootstrapping compiler ${PKGNAME_NOREV}" ${MKDIR} ${WRKDIR:Q}/build-boot cd ${WRKDIR:Q}/build-boot && \ ${PKGSRC_SETENV} PATH=${PATH} \ CONF_CC_OPTS_STAGE0=${CFLAGS:Q} \ CONF_GCC_LINKER_OPTS_STAGE0="-L${PREFIX}/lib ${COMPILER_RPATH_FLAG}${PREFIX}/lib" \ CONF_LD_LINKER_OPTS_STAGE0="-L${PREFIX}/lib ${LINKER_RPATH_FLAG}${PREFIX}/lib" \ CONF_CC_OPTS_STAGE1=${CFLAGS:Q} \ CONF_GCC_LINKER_OPTS_STAGE1="-L${PREFIX}/lib ${COMPILER_RPATH_FLAG}${PREFIX}/lib" \ CONF_LD_LINKER_OPTS_STAGE1="-L${PREFIX}/lib ${LINKER_RPATH_FLAG}${PREFIX}/lib" \ CONF_CC_OPTS_STAGE2=${CFLAGS:Q} \ CONF_GCC_LINKER_OPTS_STAGE2="-L${PREFIX}/lib ${COMPILER_RPATH_FLAG}${PREFIX}/lib" \ CONF_LD_LINKER_OPTS_STAGE2="-L${PREFIX}/lib ${LINKER_RPATH_FLAG}${PREFIX}/lib" \ ${SH} ./configure && \ ${SED} -e "s,@CURSES_INCDIR@,${BUILDLINK_PREFIX.curses:Q}/${BUILDLINK_INCDIRS.ncurses:Uinclude},g" \ -e "s,@CURSES_LIBDIR@,${BUILDLINK_PREFIX.curses:Q}/lib,g" \ ${FILESDIR:Q}/bootstrap.build.mk > mk/build.mk ${TOUCH} ${.TARGET} ${WRKDIR}/stamp-build-boot: ${WRKDIR}/stamp-configure-boot @${PHASE_MSG} "Building bootstrapping compiler ${PKGNAME_NOREV}" ${RUN} cd ${WRKDIR:Q}/build-boot && ${BUILD_MAKE_CMD} ${TOUCH} ${.TARGET} ${WRKDIR}/${BOOT_TARBALL}: ${WRKDIR}/stamp-build-boot @${PHASE_MSG} "Creating binary distribution of bootstrapping ${PKGNAME_NOREV}" ${RUN} cd ${WRKDIR:Q}/build-boot && ${BUILD_MAKE_CMD} binary-dist ${MV} -f ${WRKDIR:Q}/build-boot/${BOOT_TARBALL} ${.TARGET} # This can take up half an hour. Memory usage is also very high, about 680 MiB. ${WRKDIR}/${BOOT_ARCHIVE}: ${WRKDIR}/${BOOT_TARBALL} @${PHASE_MSG} "Compressing binary distribution of bootstrapping ${PKGNAME_NOREV}" ${XZ} --verbose -9 --extreme ${WRKDIR:Q}/${BOOT_TARBALL}