1 1.106 mrg # $NetBSD: Makefile,v 1.106 2023/07/28 08:05:29 mrg Exp $ 2 1.1 mrg 3 1.86 christos .include <bsd.hostinit.mk> 4 1.1 mrg 5 1.16 mrg GCC_LANGUAGES=c c++ objc 6 1.98 mrg MODULE= ${EXTERNAL_GCC_SUBDIR} 7 1.45 mrg 8 1.66 mrg GCCDIST= ${.CURDIR}/../../external/gpl3/${EXTERNAL_GCC_SUBDIR}/dist 9 1.66 mrg GNUHOSTDIST= ${GCCDIST} 10 1.65 mrg 11 1.106 mrg .if ${HAVE_GCC} == 10 12 1.65 mrg MKNATIVE= ${.CURDIR}/mknative-gcc.old 13 1.60 skrll .endif 14 1.60 skrll 15 1.63 christos # Defaults 16 1.75 mrg CC_FOR_BUILD= ${HOST_CXX:Q} 17 1.63 christos MKNATIVE?= ${.CURDIR}/mknative-gcc 18 1.63 christos 19 1.28 mrg .if ${MACHINE_ARCH} == "x86_64" || ${MACHINE_ARCH} == "sparc64" 20 1.28 mrg MULTILIB_ARGS= --enable-multilib 21 1.28 mrg .else 22 1.28 mrg MULTILIB_ARGS= --disable-multilib 23 1.28 mrg .endif 24 1.28 mrg 25 1.71 matt .if ${MKSOFTFLOAT} != "no" && ${MACHINE_CPU} != "m68k" \ 26 1.81 chs && ${MACHINE_CPU} != "or1k" && ${MACHINE_CPU} != "sh3" 27 1.36 matt SOFTFLOAT_ARGS= -with-float=soft 28 1.36 matt .endif 29 1.36 matt 30 1.69 mrg .include "gcc-version.mk" 31 1.69 mrg 32 1.31 drochner COMMON_CONFIGURE_ARGS= --target=${MACHINE_GNU_PLATFORM} \ 33 1.31 drochner --enable-long-long \ 34 1.31 drochner --enable-threads \ 35 1.94 maya --with-bugurl=http://www.NetBSD.org/support/send-pr.html \ 36 1.69 mrg --with-pkgversion="NetBSD ${NETBSD_GCC_VERSION}" \ 37 1.51 joerg --with-system-zlib \ 38 1.87 maya --without-isl \ 39 1.68 mrg --enable-__cxa_atexit \ 40 1.80 mrg --enable-libstdcxx-time=rt \ 41 1.89 mrg --enable-libstdcxx-threads \ 42 1.89 mrg --with-diagnostics-color=auto-if-env 43 1.31 drochner .if defined(GCC_CONFIG_ARCH.${MACHINE_ARCH}) 44 1.31 drochner COMMON_CONFIGURE_ARGS+= --with-arch=${GCC_CONFIG_ARCH.${MACHINE_ARCH}} 45 1.31 drochner .endif 46 1.32 ad .if defined(GCC_CONFIG_TUNE.${MACHINE_ARCH}) 47 1.32 ad COMMON_CONFIGURE_ARGS+= --with-tune=${GCC_CONFIG_TUNE.${MACHINE_ARCH}} 48 1.32 ad .endif 49 1.31 drochner 50 1.93 mrg # Too many CPUs have one or both of these bugs, the common code should 51 1.93 mrg # default to safety. 52 1.93 mrg .if ${MACHINE_CPU} == "aarch64" 53 1.93 mrg COMMON_CONFIGURE_ARGS+= --enable-fix-cortex-a53-835769 \ 54 1.93 mrg --enable-fix-cortex-a53-843419 55 1.93 mrg .endif 56 1.93 mrg 57 1.89 mrg .if ${HAVE_GCC} >= 7 58 1.89 mrg COMMON_CONFIGURE_ARGS+= --with-default-libstdcxx-abi=new 59 1.89 mrg .endif 60 1.78 mrg 61 1.37 mrg CONFIGURE_ARGS= ${COMMON_CONFIGURE_ARGS} 62 1.37 mrg CONFIGURE_ARGS+= \ 63 1.63 christos --with-sysroot=${DESTDIR} \ 64 1.37 mrg --with-mpc=${TOOLDIR} \ 65 1.37 mrg --with-mpfr=${TOOLDIR} \ 66 1.70 mrg --with-gmp=${TOOLDIR} \ 67 1.31 drochner --disable-nls \ 68 1.28 mrg ${MULTILIB_ARGS} \ 69 1.36 matt ${SOFTFLOAT_ARGS} \ 70 1.1 mrg --program-transform-name="s,^,${MACHINE_GNU_PLATFORM}-," \ 71 1.31 drochner --enable-languages="${GCC_LANGUAGES}" 72 1.1 mrg 73 1.64 christos GCC_CPPFLAGS= -DNETBSD_TOOLS -DTARGET_SYSTEM_ROOT=0 \ 74 1.105 christos -DTARGET_SYSTEM_ROOT_RELOCATABLE 75 1.105 christos # ${HOST_CPPFLAGS} 76 1.35 joerg 77 1.1 mrg MAKE_ARGS= MACHINE= MAKEINFO=${TOOL_MAKEINFO:Q} \ 78 1.7 thorpej LIBGCC= LIBGCC1= LIBGCC1_TEST= LIBGCC2= INSTALL_LIBGCC= \ 79 1.35 joerg EXTRA_PARTS= CPPFLAGS=${GCC_CPPFLAGS:Q} \ 80 1.17 mrg AR=${HOST_AR:Q} RANLIB=${HOST_RANLIB:Q} 81 1.1 mrg 82 1.44 mrg CONFIGURE_ENV+= gcc_cv_libc_provides_ssp=yes \ 83 1.44 mrg gcc_cv_as_sparc_gotdata_op=no 84 1.25 he 85 1.59 skrll ALL_TARGET= all-gcc 86 1.59 skrll INSTALL_TARGET= install-gcc 87 1.59 skrll 88 1.59 skrll .include "${.CURDIR}/../Makefile.gmakehost" 89 1.59 skrll BUILD_MAKE=${TOOL_GMAKE} 90 1.59 skrll 91 1.59 skrll # 92 1.59 skrll # mknative-gcc specific stuff 93 1.59 skrll # 94 1.63 christos 95 1.68 mrg MKNATIVE_CONFIG_TARGET_LIBS= 96 1.59 skrll 97 1.75 mrg MKNATIVE_CONFIG_TARGET_LIBS+= configure-target-libgcc 98 1.75 mrg MKNATIVE_CONFIG_TARGET_LIBS+= configure-target-libgomp 99 1.59 skrll 100 1.68 mrg MKNATIVE_CONFIG_TARGET_LIBS+= \ 101 1.68 mrg configure-target-libstdc++-v3 \ 102 1.89 mrg configure-target-libbacktrace \ 103 1.68 mrg configure-target-libobjc 104 1.68 mrg 105 1.99 mrg .if ${HAVE_GCC} >= 9 106 1.99 mrg # XXX needs to build libstdc++ fully, which fails 107 1.99 mrg .if 0 108 1.99 mrg MKNATIVE_CONFIG_TARGET_LIBS+= \ 109 1.99 mrg configure-target-libsanitizer 110 1.99 mrg .endif 111 1.99 mrg .endif 112 1.99 mrg 113 1.59 skrll BINENV= /usr/bin/env -i 114 1.59 skrll 115 1.63 christos 116 1.16 mrg MKNATIVE_ENV= ${BINENV} ${CONFIGURE_ENV:NC*:NLD*} \ 117 1.63 christos CC_FOR_BUILD=${CC_FOR_BUILD:Q} \ 118 1.63 christos CXX_FOR_BUILD=${HOST_CXX:Q} \ 119 1.63 christos CFLAGS_FOR_BUILD="-I${TOOLDIR}/include" \ 120 1.16 mrg CC=${CC:Q}' '${CCADDFLAGS:Q} \ 121 1.20 mrg CXX=${CXX:Q}' '${CCADDFLAGS:Q}' '${CXXADDFLAGS:Q} \ 122 1.89 mrg CPP=${CPP:Q}' '-I${DESTDIR}/usr/include' '-I${DESTDIR}/usr/include/g++/bits \ 123 1.16 mrg CFLAGS= CPPFLAGS= CXXFLAGS= LDFLAGS= \ 124 1.29 apb AS=${AS:Q} AWK=${TOOL_AWK:Q} LD=${LD:Q} \ 125 1.16 mrg MSGFMT=${TOOLDIR}/bin/${_TOOL_PREFIX}msgfmt \ 126 1.29 apb NM=${NM:Q} OBJDUMP=${OBJDUMP:Q} \ 127 1.16 mrg XGETTEXT=${TOOLDIR}/bin/${_TOOL_PREFIX}xgettext \ 128 1.16 mrg ac_cv_prog_cc_cross=yes \ 129 1.16 mrg ac_cv_func_strcoll_works=yes \ 130 1.39 mrg ac_cv_func_elf_getshstrndx=no \ 131 1.16 mrg gcc_cv_func_printf_ptr=yes \ 132 1.28 mrg gcc_cv_libc_provides_ssp=yes \ 133 1.16 mrg gdb_cv_printf_has_long_double=yes \ 134 1.16 mrg gdb_cv_printf_has_long_long=yes \ 135 1.44 mrg gdb_cv_scanf_has_long_double=yes \ 136 1.44 mrg gcc_cv_as_sparc_gotdata_op=no 137 1.16 mrg 138 1.38 mrg CXXADDFLAGS= --sysroot=${DESTDIR} 139 1.39 mrg CCADDFLAGS= --sysroot=${DESTDIR} -L${DESTDIR}/lib -L${DESTDIR}/usr/lib -B${DESTDIR}/usr/lib/ -I${.OBJDIR}/.native/gcc/include 140 1.1 mrg 141 1.55 mrg # NEWCONFIGDIR can be set to a read-write location of the source tree 142 1.55 mrg # in case the version being used is not. 143 1.1 mrg NEWCONFIGDIR?= ${.CURDIR}/../.. 144 1.1 mrg 145 1.100 mrg GCC_MACHINE_ARCH= ${MACHINE_ARCH:S/earmv5/earm/} 146 1.100 mrg 147 1.1 mrg bootstrap-libgcc: .configure_done 148 1.1 mrg @echo 'Creating files needed for libgcc by a native bootstrap build.' 149 1.63 christos (cd ${.OBJDIR}/build && ${BUILD_COMMAND} configure-target-libgcc) 150 1.100 mrg @MAKE=${BUILD_MAKE:Q} ${HOST_SH} ${MKNATIVE} libgcc-bootstrap \ 151 1.56 mrg ${.OBJDIR}/build ${NEWCONFIGDIR} ${NETBSDSRCDIR} \ 152 1.100 mrg ${MACHINE_GNU_PLATFORM} ${GCC_MACHINE_ARCH} ${DESTDIR} ${TOOLDIR} 153 1.63 christos 154 1.63 christos bootstrap-libstdc++: .configure_done 155 1.63 christos @echo 'Creating files needed for libstdc++ by a native bootstrap build.' 156 1.63 christos (cd ${.OBJDIR}/build && ${BUILD_COMMAND} configure-target-libstdc++-v3) 157 1.63 christos @MAKE=${BUILD_MAKE:Q} ${HOST_SH} ${MKNATIVE} libstdc++-bootstrap \ 158 1.63 christos ${.OBJDIR}/build ${NEWCONFIGDIR} ${NETBSDSRCDIR} \ 159 1.100 mrg ${MACHINE_GNU_PLATFORM} ${GCC_MACHINE_ARCH} ${DESTDIR} ${TOOLDIR} 160 1.1 mrg 161 1.1 mrg native-gcc: .native/.configure_done 162 1.1 mrg @echo 'Extracting GNU GCC configury for a native toolchain.' 163 1.100 mrg @MAKE=${BUILD_MAKE:Q} ${HOST_SH} ${MKNATIVE} gcc \ 164 1.56 mrg ${.OBJDIR}/.native ${NEWCONFIGDIR} ${NETBSDSRCDIR} \ 165 1.100 mrg ${MACHINE_GNU_PLATFORM} ${GCC_MACHINE_ARCH} ${DESTDIR} ${TOOLDIR} 166 1.1 mrg 167 1.37 mrg NATIVE_CONFIGURE_ARGS= ${COMMON_CONFIGURE_ARGS} 168 1.61 mrg MPC= ${NETBSDSRCDIR}/external/lgpl3/mpc 169 1.55 mrg MPFR= ${NETBSDSRCDIR}/external/lgpl3/mpfr 170 1.55 mrg GMP= ${NETBSDSRCDIR}/external/lgpl3/gmp 171 1.53 skrll MPCOBJ!= cd ${MPC}/lib/libmpc && ${PRINTOBJDIR} 172 1.53 skrll MPFROBJ!= cd ${MPFR}/lib/libmpfr && ${PRINTOBJDIR} 173 1.53 skrll GMPOBJ!= cd ${GMP}/lib/libgmp && ${PRINTOBJDIR} 174 1.53 skrll 175 1.82 mrg .include "../../external/lgpl3/gmp/Makefile.arch" 176 1.63 christos 177 1.37 mrg NATIVE_CONFIGURE_ARGS+= \ 178 1.53 skrll --with-mpc-lib=${MPCOBJ} \ 179 1.53 skrll --with-mpfr-lib=${MPFROBJ} \ 180 1.53 skrll --with-gmp-lib=${GMPOBJ} \ 181 1.53 skrll --with-mpc-include=${MPC}/dist/src \ 182 1.62 skrll --with-mpfr-include=${MPFR}/dist/src \ 183 1.63 christos --with-gmp-include=${GMP}/lib/libgmp/arch/${GMP_MACHINE_ARCH} 184 1.48 joerg 185 1.70 mrg .if ${MACHINE_ARCH} != "vax" 186 1.48 joerg NATIVE_CONFIGURE_ARGS+= --enable-tls 187 1.70 mrg .endif 188 1.70 mrg .if !empty(MACHINE_ARCH:Mearm*) 189 1.63 christos NATIVE_CONFIGURE_ARGS+= --enable-initfini-array 190 1.37 mrg .endif 191 1.70 mrg 192 1.73 mrg .if ${MACHINE_ARCH} == "m68000" 193 1.73 mrg NATIVE_CONFIGURE_ARGS+= --disable-shared 194 1.73 mrg .endif 195 1.73 mrg 196 1.78 mrg .if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "x86_64" 197 1.78 mrg EXTRA_GCC_TARGETS= i386-builtin-types.inc 198 1.78 mrg .endif 199 1.96 christos .if !empty(MACHINE_ARCH:M*arm*) 200 1.96 christos EXTRA_GCC_TARGETS= arm-cpu-data.h arm-cpu-cdata.h 201 1.96 christos .endif 202 1.78 mrg 203 1.37 mrg NATIVE_CONFIGURE_ARGS+= \ 204 1.31 drochner --disable-multilib \ 205 1.41 mrg --disable-libstdcxx-pch \ 206 1.66 mrg --build=`${GCCDIST}/config.guess` \ 207 1.63 christos --host=${MACHINE_GNU_PLATFORM} \ 208 1.63 christos --with-sysroot=${DESTDIR} 209 1.63 christos MKENV_BUILD_MAKE=cd .native && ${MKNATIVE_ENV} ${BUILD_MAKE} 210 1.31 drochner 211 1.1 mrg .native/.configure_done: ${_GNU_CFGSRC} ${.CURDIR}/Makefile 212 1.89 mrg mkdir .native .native/gcc .native/gcc/include 2>/dev/null || true 213 1.89 mrg # If this fails, gthreads won't be configured initially, but reconfig will. 214 1.90 mrg cp ${DESTDIR}/usr/include/g++/bits/gthr-default.h .native/gcc/include || true 215 1.9 mrg PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 216 1.16 mrg (cd .native && ${MKNATIVE_ENV} \ 217 1.8 lukem ${HOST_SH} ${GNUHOSTDIST}/configure \ 218 1.31 drochner ${NATIVE_CONFIGURE_ARGS}) && \ 219 1.63 christos (${MKENV_BUILD_MAKE} all-build-libiberty) && \ 220 1.75 mrg ((${MKENV_BUILD_MAKE} all-libcpp) && \ 221 1.63 christos (${MKENV_BUILD_MAKE} all-libbacktrace) && \ 222 1.63 christos (${MKENV_BUILD_MAKE} all-libdecnumber) || true) 223 1.63 christos PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 224 1.63 christos (${MKENV_BUILD_MAKE} configure-gcc configure-libcpp) && \ 225 1.63 christos (${MKENV_BUILD_MAKE} configure-libiberty) && \ 226 1.63 christos (${MKENV_BUILD_MAKE} configure-libdecnumber) 227 1.16 mrg # edit Makefile so that maybe-all-gcc does not depend on all-gcc any more. 228 1.16 mrg (cd .native && mv Makefile Makefile.config && \ 229 1.30 apb ${TOOL_SED} -e 's/\(maybe-all-gcc:\) all-gcc/\1/' \ 230 1.42 mrg -e 's/\(maybe-all-target-libgcc:\) all-target-libgcc/\1/' \ 231 1.41 mrg < Makefile.config > Makefile) 232 1.41 mrg PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 233 1.28 mrg (cd .native/gcc && ${MKNATIVE_ENV} ${BUILD_MAKE} -e tree-check.h config.h multilib.h gcov-iov.h) 234 1.16 mrg PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 235 1.84 mrg (cd .native/gcc && ${MKNATIVE_ENV} ${BUILD_MAKE} -e libgcc.mvars tconfig.h); \ 236 1.42 mrg (cd .native && touch gcc/cc1obj gcc/cc1plus gcc/f771 gcc/libgcc.a gcc/libgcc_s.so) 237 1.101 mrg PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 238 1.102 mrg (cd .native/gcc && ${MKNATIVE_ENV} ${BUILD_MAKE} -e s-omp-device-properties-h) 239 1.79 mrg .if defined(EXTRA_GCC_TARGETS) 240 1.79 mrg PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 241 1.78 mrg (cd .native/gcc && ${MKNATIVE_ENV} ${BUILD_MAKE} -e ${EXTRA_GCC_TARGETS}) 242 1.78 mrg .endif 243 1.42 mrg .for _lib in ${MKNATIVE_CONFIG_TARGET_LIBS} 244 1.39 mrg PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 245 1.42 mrg (cd .native && ${MKNATIVE_ENV} ${BUILD_MAKE} \ 246 1.42 mrg ${_lib} \ 247 1.1 mrg ALL_GCC_C= ALL_GCC_CXX= \ 248 1.1 mrg CC_FOR_TARGET=${CC:Q}' '${CCADDFLAGS:Q} \ 249 1.20 mrg CXX_FOR_TARGET=${CXX:Q}' '${CCADDFLAGS:Q}' '${CXXADDFLAGS:Q} \ 250 1.22 mrg RAW_CXX_FOR_TARGET=${CXX:Q}' '${CCADDFLAGS:Q}' '${CXXADDFLAGS:Q} \ 251 1.20 mrg CPP=${CPP:Q}' '-I${DESTDIR}/usr/include \ 252 1.20 mrg ac_cv_prog_cc_cross=yes) && \ 253 1.16 mrg true 254 1.42 mrg .endfor 255 1.16 mrg PATH=${TOOLDIR}/bin:$$PATH; export PATH; \ 256 1.1 mrg (cd .native/${MACHINE_GNU_PLATFORM}/libstdc++-v3/include && \ 257 1.20 mrg ${MKNATIVE_ENV} ${BUILD_MAKE} \ 258 1.20 mrg CC_FOR_TARGET=${CC:Q}' '${CCADDFLAGS:Q} \ 259 1.20 mrg CXX_FOR_TARGET=${CXX:Q}' '${CCADDFLAGS:Q}' '${CXXADDFLAGS:Q} \ 260 1.20 mrg CPP=${CPP:Q}' '-I${DESTDIR}/usr/include \ 261 1.20 mrg all-local) && \ 262 1.16 mrg true 263 1.1 mrg @touch $@ 264 1.1 mrg 265 1.97 mrg .if !defined(PREV_GCC) 266 1.97 mrg . if exists(PREV_GCC) 267 1.97 mrg PREV_GCC!= cat PREV_GCC 268 1.97 mrg . else 269 1.97 mrg PREV_GCC= 270 1.97 mrg . endif 271 1.97 mrg .endif 272 1.97 mrg 273 1.97 mrg CLEANFILES+= PREV_GCC 274 1.97 mrg 275 1.97 mrg realall realdepend: .MAKE 276 1.97 mrg .if !empty(PREV_GCC) && "${PREV_GCC}" != "${EXTERNAL_GCC_SUBDIR}-${HAVE_GCC}" 277 1.97 mrg @echo "*** WARNING: GCC has changed version?" 278 1.97 mrg @echo "*** PREV_GCC '${PREV_GCC}'" 279 1.97 mrg @echo "*** != EXTERNAL_GCC_SUBDIR-HAVE_GCC '${EXTERNAL_GCC_SUBDIR}-${HAVE_GCC}'" 280 1.97 mrg @echo "*** Cleaning mis-matched tools/gcc" 281 1.97 mrg rm -f PREV_GCC 282 1.97 mrg (cd ${.CURDIR} && ${MAKE} cleandir) 283 1.97 mrg .endif 284 1.97 mrg echo ${EXTERNAL_GCC_SUBDIR}-${HAVE_GCC} >PREV_GCC 285 1.97 mrg 286 1.1 mrg clean: clean.native 287 1.1 mrg clean.native: 288 1.1 mrg -rm -r -f .native 289