Makefile revision 1.112
11.112Sgutterid# $NetBSD: Makefile,v 1.112 2024/06/08 01:07:44 gutteridge Exp $ 21.1Smrg 31.86Schristos.include <bsd.hostinit.mk> 41.1Smrg 51.16SmrgGCC_LANGUAGES=c c++ objc 61.98SmrgMODULE= ${EXTERNAL_GCC_SUBDIR} 71.45Smrg 81.66SmrgGCCDIST= ${.CURDIR}/../../external/gpl3/${EXTERNAL_GCC_SUBDIR}/dist 91.66SmrgGNUHOSTDIST= ${GCCDIST} 101.65Smrg 111.106Smrg.if ${HAVE_GCC} == 10 121.65SmrgMKNATIVE= ${.CURDIR}/mknative-gcc.old 131.60Sskrll.endif 141.60Sskrll 151.63Schristos# Defaults 161.75SmrgCC_FOR_BUILD= ${HOST_CXX:Q} 171.63SchristosMKNATIVE?= ${.CURDIR}/mknative-gcc 181.63Schristos 191.28Smrg.if ${MACHINE_ARCH} == "x86_64" || ${MACHINE_ARCH} == "sparc64" 201.28SmrgMULTILIB_ARGS= --enable-multilib 211.28Smrg.else 221.28SmrgMULTILIB_ARGS= --disable-multilib 231.28Smrg.endif 241.28Smrg 251.71Smatt.if ${MKSOFTFLOAT} != "no" && ${MACHINE_CPU} != "m68k" \ 261.81Schs && ${MACHINE_CPU} != "or1k" && ${MACHINE_CPU} != "sh3" 271.36SmattSOFTFLOAT_ARGS= -with-float=soft 281.36Smatt.endif 291.36Smatt 301.69Smrg.include "gcc-version.mk" 311.69Smrg 321.31SdrochnerCOMMON_CONFIGURE_ARGS= --target=${MACHINE_GNU_PLATFORM} \ 331.31Sdrochner --enable-long-long \ 341.31Sdrochner --enable-threads \ 351.94Smaya --with-bugurl=http://www.NetBSD.org/support/send-pr.html \ 361.69Smrg --with-pkgversion="NetBSD ${NETBSD_GCC_VERSION}" \ 371.51Sjoerg --with-system-zlib \ 381.68Smrg --enable-__cxa_atexit \ 391.80Smrg --enable-libstdcxx-time=rt \ 401.89Smrg --enable-libstdcxx-threads \ 411.89Smrg --with-diagnostics-color=auto-if-env 421.31Sdrochner.if defined(GCC_CONFIG_ARCH.${MACHINE_ARCH}) 431.31SdrochnerCOMMON_CONFIGURE_ARGS+= --with-arch=${GCC_CONFIG_ARCH.${MACHINE_ARCH}} 441.31Sdrochner.endif 451.32Sad.if defined(GCC_CONFIG_TUNE.${MACHINE_ARCH}) 461.32SadCOMMON_CONFIGURE_ARGS+= --with-tune=${GCC_CONFIG_TUNE.${MACHINE_ARCH}} 471.32Sad.endif 481.31Sdrochner 491.93Smrg# Too many CPUs have one or both of these bugs, the common code should 501.93Smrg# default to safety. 511.93Smrg.if ${MACHINE_CPU} == "aarch64" 521.93SmrgCOMMON_CONFIGURE_ARGS+= --enable-fix-cortex-a53-835769 \ 531.93Smrg --enable-fix-cortex-a53-843419 541.93Smrg.endif 551.93Smrg 561.89Smrg.if ${HAVE_GCC} >= 7 571.89SmrgCOMMON_CONFIGURE_ARGS+= --with-default-libstdcxx-abi=new 581.89Smrg.endif 591.78Smrg 601.112Sgutterid# We enabled isl support for GCC 12. Move into normal segment when 611.111Smrg# removing GCC 10. 621.111Smrg.if ${HAVE_GCC} < 12 631.111SmrgISL_CONFIGURE_ARGS+= --without-isl 641.111Smrg.else 651.111SmrgISL_CONFIGURE_ARGS+= --with-isl=${TOOLDIR} 661.111Smrg.endif 671.111Smrg 681.37SmrgCONFIGURE_ARGS= ${COMMON_CONFIGURE_ARGS} 691.37SmrgCONFIGURE_ARGS+= \ 701.63Schristos --with-sysroot=${DESTDIR} \ 711.37Smrg --with-mpc=${TOOLDIR} \ 721.37Smrg --with-mpfr=${TOOLDIR} \ 731.70Smrg --with-gmp=${TOOLDIR} \ 741.111Smrg ${ISL_CONFIGURE_ARGS} \ 751.31Sdrochner --disable-nls \ 761.28Smrg ${MULTILIB_ARGS} \ 771.36Smatt ${SOFTFLOAT_ARGS} \ 781.1Smrg --program-transform-name="s,^,${MACHINE_GNU_PLATFORM}-," \ 791.31Sdrochner --enable-languages="${GCC_LANGUAGES}" 801.1Smrg 811.64SchristosGCC_CPPFLAGS= -DNETBSD_TOOLS -DTARGET_SYSTEM_ROOT=0 \ 821.105Schristos -DTARGET_SYSTEM_ROOT_RELOCATABLE 831.105Schristos# ${HOST_CPPFLAGS} 841.35Sjoerg 851.109Srin.if ${MACHINE} == "vax" 861.109SrinGCC_CPPFLAGS+= -DNB_FIX_VAX_BACKEND 871.109Srin.endif 881.109Srin 891.1SmrgMAKE_ARGS= MACHINE= MAKEINFO=${TOOL_MAKEINFO:Q} \ 901.7Sthorpej LIBGCC= LIBGCC1= LIBGCC1_TEST= LIBGCC2= INSTALL_LIBGCC= \ 911.35Sjoerg EXTRA_PARTS= CPPFLAGS=${GCC_CPPFLAGS:Q} \ 921.17Smrg AR=${HOST_AR:Q} RANLIB=${HOST_RANLIB:Q} 931.1Smrg 941.44SmrgCONFIGURE_ENV+= gcc_cv_libc_provides_ssp=yes \ 951.44Smrg gcc_cv_as_sparc_gotdata_op=no 961.25She 971.59SskrllALL_TARGET= all-gcc 981.59SskrllINSTALL_TARGET= install-gcc 991.59Sskrll 1001.59Sskrll.include "${.CURDIR}/../Makefile.gmakehost" 1011.59SskrllBUILD_MAKE=${TOOL_GMAKE} 1021.59Sskrll 1031.59Sskrll# 1041.59Sskrll# mknative-gcc specific stuff 1051.59Sskrll# 1061.63Schristos 1071.68SmrgMKNATIVE_CONFIG_TARGET_LIBS= 1081.59Sskrll 1091.75SmrgMKNATIVE_CONFIG_TARGET_LIBS+= configure-target-libgcc 1101.75SmrgMKNATIVE_CONFIG_TARGET_LIBS+= configure-target-libgomp 1111.59Sskrll 1121.68SmrgMKNATIVE_CONFIG_TARGET_LIBS+= \ 1131.68Smrg configure-target-libstdc++-v3 \ 1141.89Smrg configure-target-libbacktrace \ 1151.68Smrg configure-target-libobjc 1161.68Smrg 1171.99Smrg.if ${HAVE_GCC} >= 9 1181.99Smrg# XXX needs to build libstdc++ fully, which fails 1191.99Smrg.if 0 1201.99SmrgMKNATIVE_CONFIG_TARGET_LIBS+= \ 1211.99Smrg configure-target-libsanitizer 1221.99Smrg.endif 1231.99Smrg.endif 1241.99Smrg 1251.107Smrg.if ${HAVE_GCC} <= 10 1261.107SmrgEXTRA_FILES= gcov-iov.h 1271.107Smrg.else 1281.107SmrgEXTRA_FILES= bversion.h gtyp-input.list 1291.107Smrg.endif 1301.107Smrg 1311.59SskrllBINENV= /usr/bin/env -i 1321.59Sskrll 1331.63Schristos 1341.16SmrgMKNATIVE_ENV= ${BINENV} ${CONFIGURE_ENV:NC*:NLD*} \ 1351.63Schristos CC_FOR_BUILD=${CC_FOR_BUILD:Q} \ 1361.63Schristos CXX_FOR_BUILD=${HOST_CXX:Q} \ 1371.63Schristos CFLAGS_FOR_BUILD="-I${TOOLDIR}/include" \ 1381.16Smrg CC=${CC:Q}' '${CCADDFLAGS:Q} \ 1391.20Smrg CXX=${CXX:Q}' '${CCADDFLAGS:Q}' '${CXXADDFLAGS:Q} \ 1401.89Smrg CPP=${CPP:Q}' '-I${DESTDIR}/usr/include' '-I${DESTDIR}/usr/include/g++/bits \ 1411.16Smrg CFLAGS= CPPFLAGS= CXXFLAGS= LDFLAGS= \ 1421.29Sapb AS=${AS:Q} AWK=${TOOL_AWK:Q} LD=${LD:Q} \ 1431.16Smrg MSGFMT=${TOOLDIR}/bin/${_TOOL_PREFIX}msgfmt \ 1441.29Sapb NM=${NM:Q} OBJDUMP=${OBJDUMP:Q} \ 1451.16Smrg XGETTEXT=${TOOLDIR}/bin/${_TOOL_PREFIX}xgettext \ 1461.16Smrg ac_cv_prog_cc_cross=yes \ 1471.16Smrg ac_cv_func_strcoll_works=yes \ 1481.39Smrg ac_cv_func_elf_getshstrndx=no \ 1491.16Smrg gcc_cv_func_printf_ptr=yes \ 1501.28Smrg gcc_cv_libc_provides_ssp=yes \ 1511.16Smrg gdb_cv_printf_has_long_double=yes \ 1521.16Smrg gdb_cv_printf_has_long_long=yes \ 1531.44Smrg gdb_cv_scanf_has_long_double=yes \ 1541.44Smrg gcc_cv_as_sparc_gotdata_op=no 1551.16Smrg 1561.38SmrgCXXADDFLAGS= --sysroot=${DESTDIR} 1571.39SmrgCCADDFLAGS= --sysroot=${DESTDIR} -L${DESTDIR}/lib -L${DESTDIR}/usr/lib -B${DESTDIR}/usr/lib/ -I${.OBJDIR}/.native/gcc/include 1581.1Smrg 1591.55Smrg# NEWCONFIGDIR can be set to a read-write location of the source tree 1601.55Smrg# in case the version being used is not. 1611.1SmrgNEWCONFIGDIR?= ${.CURDIR}/../.. 1621.1Smrg 1631.100SmrgGCC_MACHINE_ARCH= ${MACHINE_ARCH:S/earmv5/earm/} 1641.100Smrg 1651.1Smrgbootstrap-libgcc: .configure_done 1661.1Smrg @echo 'Creating files needed for libgcc by a native bootstrap build.' 1671.63Schristos (cd ${.OBJDIR}/build && ${BUILD_COMMAND} configure-target-libgcc) 1681.100Smrg @MAKE=${BUILD_MAKE:Q} ${HOST_SH} ${MKNATIVE} libgcc-bootstrap \ 1691.56Smrg ${.OBJDIR}/build ${NEWCONFIGDIR} ${NETBSDSRCDIR} \ 1701.100Smrg ${MACHINE_GNU_PLATFORM} ${GCC_MACHINE_ARCH} ${DESTDIR} ${TOOLDIR} 1711.63Schristos 1721.63Schristosbootstrap-libstdc++: .configure_done 1731.63Schristos @echo 'Creating files needed for libstdc++ by a native bootstrap build.' 1741.63Schristos (cd ${.OBJDIR}/build && ${BUILD_COMMAND} configure-target-libstdc++-v3) 1751.63Schristos @MAKE=${BUILD_MAKE:Q} ${HOST_SH} ${MKNATIVE} libstdc++-bootstrap \ 1761.63Schristos ${.OBJDIR}/build ${NEWCONFIGDIR} ${NETBSDSRCDIR} \ 1771.100Smrg ${MACHINE_GNU_PLATFORM} ${GCC_MACHINE_ARCH} ${DESTDIR} ${TOOLDIR} 1781.1Smrg 1791.1Smrgnative-gcc: .native/.configure_done 1801.1Smrg @echo 'Extracting GNU GCC configury for a native toolchain.' 1811.100Smrg @MAKE=${BUILD_MAKE:Q} ${HOST_SH} ${MKNATIVE} gcc \ 1821.56Smrg ${.OBJDIR}/.native ${NEWCONFIGDIR} ${NETBSDSRCDIR} \ 1831.100Smrg ${MACHINE_GNU_PLATFORM} ${GCC_MACHINE_ARCH} ${DESTDIR} ${TOOLDIR} 1841.1Smrg 1851.37SmrgNATIVE_CONFIGURE_ARGS= ${COMMON_CONFIGURE_ARGS} 1861.108Schristos.include "lgpl3.mk" 1871.48Sjoerg 1881.70Smrg.if ${MACHINE_ARCH} != "vax" 1891.48SjoergNATIVE_CONFIGURE_ARGS+= --enable-tls 1901.70Smrg.endif 1911.70Smrg.if !empty(MACHINE_ARCH:Mearm*) 1921.63SchristosNATIVE_CONFIGURE_ARGS+= --enable-initfini-array 1931.37Smrg.endif 1941.70Smrg 1951.73Smrg.if ${MACHINE_ARCH} == "m68000" 1961.73SmrgNATIVE_CONFIGURE_ARGS+= --disable-shared 1971.73Smrg.endif 1981.73Smrg 1991.78Smrg.if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "x86_64" 2001.78SmrgEXTRA_GCC_TARGETS= i386-builtin-types.inc 2011.78Smrg.endif 2021.96Schristos.if !empty(MACHINE_ARCH:M*arm*) 2031.96SchristosEXTRA_GCC_TARGETS= arm-cpu-data.h arm-cpu-cdata.h 2041.96Schristos.endif 2051.78Smrg 2061.37SmrgNATIVE_CONFIGURE_ARGS+= \ 2071.31Sdrochner --disable-multilib \ 2081.41Smrg --disable-libstdcxx-pch \ 2091.66Smrg --build=`${GCCDIST}/config.guess` \ 2101.63Schristos --host=${MACHINE_GNU_PLATFORM} \ 2111.63Schristos --with-sysroot=${DESTDIR} 2121.63SchristosMKENV_BUILD_MAKE=cd .native && ${MKNATIVE_ENV} ${BUILD_MAKE} 2131.31Sdrochner 2141.1Smrg.native/.configure_done: ${_GNU_CFGSRC} ${.CURDIR}/Makefile 2151.89Smrg mkdir .native .native/gcc .native/gcc/include 2>/dev/null || true 2161.89Smrg # If this fails, gthreads won't be configured initially, but reconfig will. 2171.90Smrg cp ${DESTDIR}/usr/include/g++/bits/gthr-default.h .native/gcc/include || true 2181.9Smrg PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 2191.16Smrg (cd .native && ${MKNATIVE_ENV} \ 2201.8Slukem ${HOST_SH} ${GNUHOSTDIST}/configure \ 2211.31Sdrochner ${NATIVE_CONFIGURE_ARGS}) && \ 2221.63Schristos (${MKENV_BUILD_MAKE} all-build-libiberty) && \ 2231.75Smrg ((${MKENV_BUILD_MAKE} all-libcpp) && \ 2241.63Schristos (${MKENV_BUILD_MAKE} all-libbacktrace) && \ 2251.63Schristos (${MKENV_BUILD_MAKE} all-libdecnumber) || true) 2261.63Schristos PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 2271.63Schristos (${MKENV_BUILD_MAKE} configure-gcc configure-libcpp) && \ 2281.63Schristos (${MKENV_BUILD_MAKE} configure-libiberty) && \ 2291.63Schristos (${MKENV_BUILD_MAKE} configure-libdecnumber) 2301.16Smrg # edit Makefile so that maybe-all-gcc does not depend on all-gcc any more. 2311.16Smrg (cd .native && mv Makefile Makefile.config && \ 2321.30Sapb ${TOOL_SED} -e 's/\(maybe-all-gcc:\) all-gcc/\1/' \ 2331.42Smrg -e 's/\(maybe-all-target-libgcc:\) all-target-libgcc/\1/' \ 2341.41Smrg < Makefile.config > Makefile) 2351.41Smrg PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 2361.107Smrg (cd .native/gcc && ${MKNATIVE_ENV} ${BUILD_MAKE} -e tree-check.h config.h multilib.h ${EXTRA_FILES}) 2371.16Smrg PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 2381.84Smrg (cd .native/gcc && ${MKNATIVE_ENV} ${BUILD_MAKE} -e libgcc.mvars tconfig.h); \ 2391.42Smrg (cd .native && touch gcc/cc1obj gcc/cc1plus gcc/f771 gcc/libgcc.a gcc/libgcc_s.so) 2401.101Smrg PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 2411.102Smrg (cd .native/gcc && ${MKNATIVE_ENV} ${BUILD_MAKE} -e s-omp-device-properties-h) 2421.79Smrg.if defined(EXTRA_GCC_TARGETS) 2431.79Smrg PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 2441.78Smrg (cd .native/gcc && ${MKNATIVE_ENV} ${BUILD_MAKE} -e ${EXTRA_GCC_TARGETS}) 2451.78Smrg.endif 2461.42Smrg.for _lib in ${MKNATIVE_CONFIG_TARGET_LIBS} 2471.39Smrg PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 2481.42Smrg (cd .native && ${MKNATIVE_ENV} ${BUILD_MAKE} \ 2491.42Smrg ${_lib} \ 2501.1Smrg ALL_GCC_C= ALL_GCC_CXX= \ 2511.1Smrg CC_FOR_TARGET=${CC:Q}' '${CCADDFLAGS:Q} \ 2521.20Smrg CXX_FOR_TARGET=${CXX:Q}' '${CCADDFLAGS:Q}' '${CXXADDFLAGS:Q} \ 2531.22Smrg RAW_CXX_FOR_TARGET=${CXX:Q}' '${CCADDFLAGS:Q}' '${CXXADDFLAGS:Q} \ 2541.20Smrg CPP=${CPP:Q}' '-I${DESTDIR}/usr/include \ 2551.20Smrg ac_cv_prog_cc_cross=yes) && \ 2561.16Smrg true 2571.42Smrg.endfor 2581.16Smrg PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 2591.1Smrg (cd .native/${MACHINE_GNU_PLATFORM}/libstdc++-v3/include && \ 2601.20Smrg ${MKNATIVE_ENV} ${BUILD_MAKE} \ 2611.20Smrg CC_FOR_TARGET=${CC:Q}' '${CCADDFLAGS:Q} \ 2621.20Smrg CXX_FOR_TARGET=${CXX:Q}' '${CCADDFLAGS:Q}' '${CXXADDFLAGS:Q} \ 2631.20Smrg CPP=${CPP:Q}' '-I${DESTDIR}/usr/include \ 2641.20Smrg all-local) && \ 2651.16Smrg true 2661.1Smrg @touch $@ 2671.1Smrg 2681.97Smrg.if !defined(PREV_GCC) 2691.97Smrg. if exists(PREV_GCC) 2701.97SmrgPREV_GCC!= cat PREV_GCC 2711.97Smrg. else 2721.97SmrgPREV_GCC= 2731.97Smrg. endif 2741.97Smrg.endif 2751.97Smrg 2761.97SmrgCLEANFILES+= PREV_GCC 2771.97Smrg 2781.110Smrg# Include the local NetBSD GCC version so that bumps to it trigger rebuilds. 2791.110SmrgNETBSD_GCC_VERSION_NOSPACE= ${NETBSD_GCC_VERSION:S/ /-/gW} 2801.110Smrg 2811.97Smrgrealall realdepend: .MAKE 2821.110Smrg.if !empty(PREV_GCC) && "${PREV_GCC}" != "${EXTERNAL_GCC_SUBDIR}-${HAVE_GCC}-${NETBSD_GCC_VERSION_NOSPACE}" 2831.97Smrg @echo "*** WARNING: GCC has changed version?" 2841.97Smrg @echo "*** PREV_GCC '${PREV_GCC}'" 2851.110Smrg @echo "*** NETBSD_GCC_VERSION_NOSPACE '${NETBSD_GCC_VERSION_NOSPACE}'" 2861.110Smrg @echo "*** != EXTERNAL_GCC_SUBDIR-HAVE_GCC-NETBSD_GCC_VERSION_NOSPACE:" 2871.110Smrg @echo "*** != '${EXTERNAL_GCC_SUBDIR}-${HAVE_GCC}-${NETBSD_GCC_VERSION_NOSPACE}'" 2881.97Smrg @echo "*** Cleaning mis-matched tools/gcc" 2891.97Smrg rm -f PREV_GCC 2901.97Smrg (cd ${.CURDIR} && ${MAKE} cleandir) 2911.97Smrg.endif 2921.110Smrg echo ${EXTERNAL_GCC_SUBDIR}-${HAVE_GCC}-${NETBSD_GCC_VERSION_NOSPACE} >PREV_GCC 2931.97Smrg 2941.1Smrgclean: clean.native 2951.1Smrgclean.native: 2961.1Smrg -rm -r -f .native 297