Module Name:    src
Committed By:   christos
Date:           Mon Feb 17 21:39:43 UTC 2014

Modified Files:
        src/tools/gcc: Makefile mknative.common
Added Files:
        src/tools/gcc: mknative-gcc48

Log Message:
Merge gcc-4.8 mknative bits.


To generate a diff of this commit:
cvs rdiff -u -r1.62 -r1.63 src/tools/gcc/Makefile
cvs rdiff -u -r0 -r1.1 src/tools/gcc/mknative-gcc48
cvs rdiff -u -r1.10 -r1.11 src/tools/gcc/mknative.common

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/tools/gcc/Makefile
diff -u src/tools/gcc/Makefile:1.62 src/tools/gcc/Makefile:1.63
--- src/tools/gcc/Makefile:1.62	Sun Feb 16 06:26:31 2014
+++ src/tools/gcc/Makefile	Mon Feb 17 16:39:43 2014
@@ -1,14 +1,25 @@
-#	$NetBSD: Makefile,v 1.62 2014/02/16 11:26:31 skrll Exp $
+#	$NetBSD: Makefile,v 1.63 2014/02/17 21:39:43 christos Exp $
 
 .include <bsd.own.mk>
 
 GCC_LANGUAGES=c c++ objc
 MODULE=			gcc4
 
-.if ${HAVE_GCC} == 45
+.if ${HAVE_GCC} == 48
+CC_FOR_BUILD=		${HOST_CXX:Q}
+LIB_INTL=
+MKNATIVE=		${.CURDIR}/mknative-gcc48
+GNUHOSTDIST=		${.CURDIR}/../../external/gpl3/yagcc/dist
+.elif ${HAVE_GCC} == 45
 GNUHOSTDIST=		${.CURDIR}/../../external/gpl3/gcc/dist
+UNWIND_H=unwind.h
 .endif
 
+# Defaults
+CC_FOR_BUILD?=		${HOST_CC:Q}
+LIB_INTL?=		"LIBS=-lintl"
+MKNATIVE?=		${.CURDIR}/mknative-gcc
+
 .if ${MACHINE_ARCH} == "x86_64" || ${MACHINE_ARCH} == "sparc64"
 MULTILIB_ARGS= --enable-multilib
 .else
@@ -36,6 +47,7 @@ COMMON_CONFIGURE_ARGS+=	--with-tune=${GC
 CONFIGURE_ARGS=	${COMMON_CONFIGURE_ARGS}
 .if ${HAVE_GCC} >= 45
 CONFIGURE_ARGS+= \
+		--with-sysroot=${DESTDIR} \
 		--with-mpc=${TOOLDIR} \
 		--with-mpfr=${TOOLDIR} \
 		--with-gmp=${TOOLDIR}
@@ -47,8 +59,7 @@ CONFIGURE_ARGS+= \
 		--program-transform-name="s,^,${MACHINE_GNU_PLATFORM}-," \
 		--enable-languages="${GCC_LANGUAGES}"
 
-GCC_CPPFLAGS=	-DNETBSD_TOOLS -DTARGET_SYSTEM_ROOT=0 \
-		-DTARGET_SYSTEM_ROOT_RELOCATABLE
+GCC_CPPFLAGS=	-DNETBSD_TOOLS
 
 MAKE_ARGS=	MACHINE= MAKEINFO=${TOOL_MAKEINFO:Q} \
 		LIBGCC= LIBGCC1= LIBGCC1_TEST= LIBGCC2= INSTALL_LIBGCC= \
@@ -67,11 +78,17 @@ BUILD_MAKE=${TOOL_GMAKE}
 #
 # mknative-gcc specific stuff
 #
+
 MKNATIVE_CONFIG_TARGET_LIBS= \
 	configure-target-libstdc++-v3 \
 	configure-target-libobjc
 
-.if ${HAVE_GCC} == 45
+.if ${HAVE_GCC} == 48
+MKNATIVE_CONFIG_TARGET_LIBS += configure-target-libgcc
+MKNATIVE_TARGET=	gcc48
+MKNATIVE_CONFIG_TARGET_LIBS+= \
+	configure-target-libgomp
+.elif ${HAVE_GCC} == 45
 MKNATIVE_TARGET=	gcc45
 MKNATIVE_CONFIG_TARGET_LIBS+= \
 	configure-target-libgomp
@@ -81,8 +98,11 @@ MKNATIVE_TARGET=	gcc4
 
 BINENV=		/usr/bin/env -i
 
+
 MKNATIVE_ENV=	${BINENV} ${CONFIGURE_ENV:NC*:NLD*} \
-			CC_FOR_BUILD=${HOST_CC:Q} \
+			CC_FOR_BUILD=${CC_FOR_BUILD:Q} \
+			CXX_FOR_BUILD=${HOST_CXX:Q} \
+			CFLAGS_FOR_BUILD="-I${TOOLDIR}/include" \
 			CC=${CC:Q}' '${CCADDFLAGS:Q} \
 			CXX=${CXX:Q}' '${CCADDFLAGS:Q}' '${CXXADDFLAGS:Q} \
 			CPP=${CPP:Q}' '-I${DESTDIR}/usr/include \
@@ -91,7 +111,7 @@ MKNATIVE_ENV=	${BINENV} ${CONFIGURE_ENV:
 			MSGFMT=${TOOLDIR}/bin/${_TOOL_PREFIX}msgfmt \
 			NM=${NM:Q} OBJDUMP=${OBJDUMP:Q} \
 			XGETTEXT=${TOOLDIR}/bin/${_TOOL_PREFIX}xgettext \
-			LIBS=-lintl \
+			${LIB_INTL} \
 			ac_cv_prog_cc_cross=yes \
 			ac_cv_func_strcoll_works=yes \
 			ac_cv_func_elf_getshstrndx=no \
@@ -114,19 +134,28 @@ CCADDFLAGS=	--sysroot=${DESTDIR} -L${DES
 # NEWCONFIGDIR can be set to a read-write location of the source tree
 # in case the version being used is not.
 NEWCONFIGDIR?=	${.CURDIR}/../..
-MKNATIVE?=	${.CURDIR}/mknative-gcc
 
 bootstrap-libgcc: .configure_done
 	@echo 'Creating files needed for libgcc by a native bootstrap build.'
-	@MAKE=${BUILD_MAKE:Q} ${HOST_SH} ${MKNATIVE} lib${MKNATIVE_TARGET} \
+	(cd ${.OBJDIR}/build && ${BUILD_COMMAND} configure-target-libgcc)
+	@MAKE=${BUILD_MAKE:Q} ${HOST_SH} ${MKNATIVE} lib${MKNATIVE_TARGET}-bootstrap \
 		${.OBJDIR}/build ${NEWCONFIGDIR} ${NETBSDSRCDIR} \
-		${MACHINE_GNU_PLATFORM} ${DESTDIR}
+		${MACHINE_GNU_PLATFORM} ${DESTDIR} ${TOOLDIR}
+
+.if ${HAVE_GCC} == "48"
+bootstrap-libstdc++: .configure_done
+	@echo 'Creating files needed for libstdc++ by a native bootstrap build.'
+	(cd ${.OBJDIR}/build && ${BUILD_COMMAND} configure-target-libstdc++-v3)
+	@MAKE=${BUILD_MAKE:Q} ${HOST_SH} ${MKNATIVE} libstdc++-bootstrap \
+		${.OBJDIR}/build ${NEWCONFIGDIR} ${NETBSDSRCDIR} \
+		${MACHINE_GNU_PLATFORM} ${DESTDIR} ${TOOLDIR}
+.endif
 
 native-gcc: .native/.configure_done
 	@echo 'Extracting GNU GCC configury for a native toolchain.'
 	@MAKE=${BUILD_MAKE:Q} ${HOST_SH} ${MKNATIVE} ${MKNATIVE_TARGET} \
 		${.OBJDIR}/.native ${NEWCONFIGDIR} ${NETBSDSRCDIR} \
-		${MACHINE_GNU_PLATFORM} ${DESTDIR}
+		${MACHINE_GNU_PLATFORM} ${DESTDIR} ${TOOLDIR}
 
 NATIVE_CONFIGURE_ARGS=	${COMMON_CONFIGURE_ARGS}
 .if ${HAVE_GCC} >= 45
@@ -137,24 +166,31 @@ MPCOBJ!=	cd ${MPC}/lib/libmpc && ${PRINT
 MPFROBJ!=	cd ${MPFR}/lib/libmpfr && ${PRINTOBJDIR}
 GMPOBJ!=	cd ${GMP}/lib/libgmp && ${PRINTOBJDIR}
 
+GMP_MACHINE_ARCH?=	${MACHINE_ARCH:S/earmv4/arm/:C/armv[5-7]/arm/}
+
 NATIVE_CONFIGURE_ARGS+=	\
 			--with-mpc-lib=${MPCOBJ} \
 			--with-mpfr-lib=${MPFROBJ} \
 			--with-gmp-lib=${GMPOBJ} \
 			--with-mpc-include=${MPC}/dist/src \
 			--with-mpfr-include=${MPFR}/dist/src \
-			--with-gmp-include=${GMP}/lib/libgmp/arch/${MACHINE_ARCH}
+			--with-gmp-include=${GMP}/lib/libgmp/arch/${GMP_MACHINE_ARCH}
 
 .  if ${MACHINE_ARCH} != "vax"
 NATIVE_CONFIGURE_ARGS+= --enable-tls
 .  endif
+.  if !empty(MACHINE_ARCH:Mearm*)
+NATIVE_CONFIGURE_ARGS+=	--enable-initfini-array
+.  endif
 .endif
 NATIVE_CONFIGURE_ARGS+=	\
 			--disable-multilib \
 			--disable-symvers \
 			--disable-libstdcxx-pch \
 			--build=`${GCCSRCDIR}/config.guess` \
-			--host=${MACHINE_GNU_PLATFORM}
+			--host=${MACHINE_GNU_PLATFORM} \
+			--with-sysroot=${DESTDIR}
+MKENV_BUILD_MAKE=cd .native && ${MKNATIVE_ENV} ${BUILD_MAKE}
 
 .native/.configure_done: ${_GNU_CFGSRC} ${.CURDIR}/Makefile
 	mkdir .native 2>/dev/null || true
@@ -162,11 +198,15 @@ NATIVE_CONFIGURE_ARGS+=	\
 		(cd .native && ${MKNATIVE_ENV} \
 			${HOST_SH} ${GNUHOSTDIST}/configure \
 			${NATIVE_CONFIGURE_ARGS}) && \
-		(cd .native && ${MKNATIVE_ENV} ${BUILD_MAKE} all-build-libiberty)
-	PATH=${TOOLDIR}/bin:$$PATH; export PATH; \
-		(cd .native && ${MKNATIVE_ENV} ${BUILD_MAKE} configure-gcc configure-libcpp) && \
-		(cd .native && ${MKNATIVE_ENV} ${BUILD_MAKE} configure-libiberty) && \
-		(cd .native && ${MKNATIVE_ENV} ${BUILD_MAKE} configure-libdecnumber)
+		(${MKENV_BUILD_MAKE} all-build-libiberty) && \
+		([ "${HAVE_GCC}" = "48" ] && \
+		 (${MKENV_BUILD_MAKE} all-libcpp) && \
+		 (${MKENV_BUILD_MAKE} all-libbacktrace) && \
+		 (${MKENV_BUILD_MAKE} all-libdecnumber) || true)
+	PATH=${TOOLDIR}/bin:$$PATH; export PATH; \
+		(${MKENV_BUILD_MAKE} configure-gcc configure-libcpp) && \
+		(${MKENV_BUILD_MAKE} configure-libiberty) && \
+		(${MKENV_BUILD_MAKE} configure-libdecnumber)
 	# edit Makefile so that maybe-all-gcc does not depend on all-gcc any more.
 		(cd .native && mv Makefile Makefile.config && \
 			${TOOL_SED} -e 's/\(maybe-all-gcc:\) all-gcc/\1/' \
@@ -175,7 +215,7 @@ NATIVE_CONFIGURE_ARGS+=	\
 	PATH=${TOOLDIR}/bin:$$PATH; export PATH; \
 		(cd .native/gcc && ${MKNATIVE_ENV} ${BUILD_MAKE} -e tree-check.h config.h multilib.h gcov-iov.h)
 	PATH=${TOOLDIR}/bin:$$PATH; export PATH; \
-		(cd .native/gcc && ${MKNATIVE_ENV} ${BUILD_MAKE} -e libgcc.mvars tconfig.h unwind.h)
+		(cd .native/gcc && ${MKNATIVE_ENV} ${BUILD_MAKE} -e libgcc.mvars tconfig.h ${UNWIND_H})
 		(cd .native && touch gcc/cc1obj gcc/cc1plus gcc/f771 gcc/libgcc.a gcc/libgcc_s.so)
 .for _lib in ${MKNATIVE_CONFIG_TARGET_LIBS}
 	PATH=${TOOLDIR}/bin:$$PATH; export PATH; \

Index: src/tools/gcc/mknative.common
diff -u src/tools/gcc/mknative.common:1.10 src/tools/gcc/mknative.common:1.11
--- src/tools/gcc/mknative.common:1.10	Sun Oct 20 12:00:20 2013
+++ src/tools/gcc/mknative.common	Mon Feb 17 16:39:43 2014
@@ -1,4 +1,4 @@
-#	$NetBSD: mknative.common,v 1.10 2013/10/20 16:00:20 skrll Exp $
+#	$NetBSD: mknative.common,v 1.11 2014/02/17 21:39:43 christos Exp $
 #
 # from: NetBSD: mknative,v 1.12 2003/03/05 06:17:17 mrg Exp
 #
@@ -45,14 +45,24 @@ EOF
 	esac
 }
 
+# usage: getlinks <config.status> <subdir>
+#
+getlinks()
+{
+	_cs="$1"; shift
+	_dir="$1"; shift
+	echo -n G_CONFIGLINKS=
+	grep "^config_links=" $_cs | sed -e 's@config_links="\([^"]*\)"@\1@g' -e "s@\([^:]*\):\([^ ]*\)@\${GNUHOSTDIST}/${_dir}/\2 \1 @g"
+}
+
 # usage: write_c FILENAME
 #
 write_c()
 {
 	echo '/* This file is automatically generated.  DO NOT EDIT! */' >$_TOP/$1.tmp || \
 		bomb "cannot create $1"
-	grep '$''NetBSD' $0 | sed 's,[#$],,g;s,.*,/* Generated from: & */,' >>$_TOP/$1.tmp
-	echo '$NetBSD: mknative.common,v 1.10 2013/10/20 16:00:20 skrll Exp $' | sed 's,[#$],,g;s,.*,/* Generated from: & */,' >>$_TOP/$1.tmp
+	grep '$''NetBSD' $0 | sed 's,[	#$],,g;s,.*,/* Generated from: & */,' >>$_TOP/$1.tmp
+	echo '$NetBSD: mknative.common,v 1.11 2014/02/17 21:39:43 christos Exp $' | sed 's,[#$],,g;s,.*,/* Generated from: & */,' >>$_TOP/$1.tmp
 	echo '' >>$_TOP/$1.tmp
 	writefile $1
 }
@@ -63,8 +73,8 @@ write_mk()
 {
 	echo '# This file is automatically generated.  DO NOT EDIT!' >$_TOP/$1.tmp || \
 		bomb "cannot create $1"
-	grep '$''NetBSD' $0 | sed 's,[#$],,g;s,.*,# Generated from: &,' >>$_TOP/$1.tmp
-	echo '$NetBSD: mknative.common,v 1.10 2013/10/20 16:00:20 skrll Exp $' | sed 's,[#$],,g;s,.*,# Generated from: &,' >>$_TOP/$1.tmp
+	grep '$''NetBSD' $0 | sed 's,[	#$],,g;s,.*,# Generated from: &,' >>$_TOP/$1.tmp
+	echo '$NetBSD: mknative.common,v 1.11 2014/02/17 21:39:43 christos Exp $' | sed 's,[#$],,g;s,.*,# Generated from: &,' >>$_TOP/$1.tmp
 	echo '#' >>$_TOP/$1.tmp
 	writefile $1
 }

Added files:

Index: src/tools/gcc/mknative-gcc48
diff -u /dev/null src/tools/gcc/mknative-gcc48:1.1
--- /dev/null	Mon Feb 17 16:39:43 2014
+++ src/tools/gcc/mknative-gcc48	Mon Feb 17 16:39:43 2014
@@ -0,0 +1,421 @@
+#!/bin/sh
+#	$NetBSD: mknative-gcc48,v 1.1 2014/02/17 21:39:43 christos Exp $
+#
+# Shell script for generating all the constants needed for a native
+# platform build of gcc.
+#
+
+# initialise
+
+_TMPDIR=$2
+_TOP=$3
+_SRC=$4
+_PLATFORM=$5
+_DESTDIR=$6
+_TOOLDIR=$7
+_VPATH=`grep VPATH ${_TMPDIR}/Makefile | sed 's,^.*=[ 	]*,,'`
+_GNU_DIST=`cd ${_VPATH}; pwd`
+
+if [ -z "$_DESTDIR" ]; then
+	echo "\$_DESTDIR is empty" 2>&1
+	exit 1
+fi
+
+. $_TOP/tools/gcc/mknative.common
+
+# default to GCC 4.1 for now
+_OUTDIR="$_TOP/gnu"
+_OUTDIRBASE="gnu"
+
+sanitise_includes () {
+	sed \
+		-e "s,-I$_DESTDIR/usr/include,,g" \
+		-e "s,-I$_SRC/external/lgpl3/mpfr/dist/src,,g" \
+		-e "s,-I$_SRC/external/lgpl3/mpc/dist/src,,g" \
+		-e "s,-I$_SRC/external/lgpl3/gmp/lib/libgmp/arch/[a-z_0-9-]*,,g" \
+		-e "s,-I$_TOOLDIR/include,,g" \
+		-e "s,-I/usr/include/[^ 	]*,,"
+}
+
+##### lib/crtstuff #####
+
+get_crtstuff () {
+	_subdir="$1"
+	mkdir -p $_OUTDIR/lib/$_subdir/arch
+
+	getvars gcc/Makefile \
+		INCLUDES CRTSTUFF_CFLAGS CRTSTUFF_T_CFLAGS CRTSTUFF_T_CFLAGS_S \
+		tm_defines xm_file xm_defines \
+		| sanitise_includes \
+		| write_mk $_OUTDIRBASE/lib/$_subdir/arch/$MACHINE_ARCH.mk
+}
+
+##### lib/libg2c #####
+
+get_libg2c () {
+	mkdir -p $_OUTDIR/lib/libg2c3/arch/$MACHINE_ARCH
+
+	write_c $_OUTDIRBASE/lib/libg2c3/arch/$MACHINE_ARCH/config.h <$_TMPDIR/$_PLATFORM/libf2c/libU77/config.h
+	write_c $_OUTDIRBASE/lib/libg2c3/arch/$MACHINE_ARCH/g2c.h <$_TMPDIR/$_PLATFORM/libf2c/g2c.h
+
+	{
+		getvars $_PLATFORM/libf2c/Makefile \
+			F2CEXT
+		getvars $_PLATFORM/libf2c/libF77/Makefile \
+			ALL_CFLAGS OBJS
+		getvars $_PLATFORM/libf2c/libI77/Makefile \
+			ALL_CFLAGS OBJS | sed 's,=,+=,'
+		getvars $_PLATFORM/libf2c/libU77/Makefile \
+			ALL_CFLAGS OBJS | sed 's,=,+=,'
+	} | write_mk $_OUTDIRBASE/lib/libg2c3/arch/$MACHINE_ARCH/defs.mk
+}
+
+##### lib/libgcc #####
+
+get_libgcc () {
+	_subdir="$1"
+	mkdir -p $_OUTDIR/lib/lib$_subdir/arch
+
+	# DPBIT, FPBIT only used on mn10[23]00, we don't need them.
+	# XXX we should probably grab everything Just In Case for
+	# the future.
+
+	mkdir -p $_OUTDIR/lib/lib$_subdir/arch/$MACHINE_ARCH
+	cd $_TMPDIR/$_PLATFORM/libgcc
+	{
+		getvars $_PLATFORM/libgcc/Makefile \
+			INCLUDES LIB2ADD LIB2ADDEH LIB2ADD_ST \
+			LIB1ASMFUNCS LIB1ASMSRC \
+			LIB2_DIVMOD_FUNCS LIB2FUNCS_ST \
+			LIB2FUNCS_EXTRA \
+			LIBGCC2_CFLAGS \
+			SHLIB_MKMAP SHLIB_MKMAP_OPTS \
+			SHLIB_MAPFILES SHLIB_NM_FLAGS
+		getvars gcc/Makefile \
+			NOEXCEPTION_FLAGS EXTRA_HEADERS
+		getlinks config.status libgcc
+	}	| sanitise_includes \
+		| write_mk $_OUTDIRBASE/lib/lib$_subdir/arch/$MACHINE_ARCH/defs.mk
+
+	for f in auto-target.h; do
+		write_c $_OUTDIRBASE/lib/lib$_subdir/arch/$MACHINE_ARCH/$f \
+		    <$_TMPDIR/$_PLATFORM/libgcc/$f
+	done
+}
+
+##### lib/libgcov #####
+
+get_libgcov () {
+	_subdir="$1"
+	_mf="$2"
+
+	mkdir -p $_OUTDIR/lib/lib$_subdir/libgcov/arch/$MACHINE_ARCH
+
+	{
+		getvars $_mf \
+			LIBGCOV
+	} | write_mk $_OUTDIRBASE/lib/lib$_subdir/libgcov/arch/$MACHINE_ARCH/defs.mk
+
+	write_c $_OUTDIRBASE/lib/lib$_subdir/libgcov/arch/$MACHINE_ARCH/gcov-iov.h \
+	   <$_TMPDIR/gcc/gcov-iov.h
+
+}
+
+##### lib/libiberty #####
+
+get_gcc_libiberty () {
+	_subdir="$1"
+	_libibertydir="lib/libiberty"
+	mkdir -p $_OUTDIR/$_libibertydir/arch/$MACHINE_ARCH
+
+	getvars libiberty/Makefile \
+		ALLOCA EXTRA_OFILES LIBOBJS REQUIRED_OFILES \
+		| write_mk $_OUTDIRBASE/$_libibertydir/defs.mk
+
+	write_c $_OUTDIRBASE/$_libibertydir/arch/$MACHINE_ARCH/config.h \
+		<$_TMPDIR/libiberty/config.h
+}
+
+##### lib/libdecnumber #####
+
+get_libdecnumber () {
+	_subdir="$1"
+
+	mkdir -p $_OUTDIR/usr.bin/$_subdir/arch/$MACHINE_ARCH
+	write_c $_OUTDIRBASE/usr.bin/$_subdir/arch/$MACHINE_ARCH/config.h \
+		<$_TMPDIR/libdecnumber/config.h
+}
+
+##### lib/libgomp #####
+
+get_libgomp () {
+	_subdir="$1"
+
+	mkdir -p $_OUTDIR/lib/$_subdir/arch/$MACHINE_ARCH
+	write_c $_OUTDIRBASE/lib/$_subdir/arch/$MACHINE_ARCH/config.h \
+		<$_TMPDIR/$_PLATFORM/libgomp/config.h
+	write_c $_OUTDIRBASE/lib/$_subdir/arch/$MACHINE_ARCH/libgomp_f.h \
+		<$_TMPDIR/$_PLATFORM/libgomp/libgomp_f.h
+	write_mk $_OUTDIRBASE/lib/$_subdir/arch/$MACHINE_ARCH/libgomp.spec \
+		<$_TMPDIR/$_PLATFORM/libgomp/libgomp.spec
+	write_c $_OUTDIRBASE/lib/$_subdir/arch/$MACHINE_ARCH/omp.h \
+		<$_TMPDIR/$_PLATFORM/libgomp/omp.h
+}
+
+##### lib/libbacktrace #####
+
+get_libbacktrace () {
+	_subdir="$1"
+
+	mkdir -p $_OUTDIR/lib/$_subdir/arch/$MACHINE_ARCH
+	write_c $_OUTDIRBASE/lib/$_subdir/arch/$MACHINE_ARCH/config.h \
+		<$_TMPDIR/$_subdir/config.h
+	write_c $_OUTDIRBASE/lib/$_subdir/arch/$MACHINE_ARCH/backtrace-supported.h \
+		<$_TMPDIR/$_subdir/backtrace-supported.h
+}
+
+##### lib/libobjc #####
+
+get_libobjc () {
+	_subdir="$1/arch/$MACHINE_ARCH"
+	_options="ALL_OPT_FILES"
+
+	mkdir -p $_OUTDIR/lib/$_subdir
+
+	{
+		if [ -n "$_options" ]; then
+			getvars gcc/Makefile $_options
+		fi
+		getvars $_PLATFORM/libobjc/Makefile \
+			ALL_CFLAGS INCLUDES OBJC_SOURCE_FILES C_SOURCE_FILES OBJC_H \
+			| sed "s,$_GNU_DIST,\${GNUHOSTDIST},g"
+		getlinks $_TMPDIR/$_PLATFORM/libgcc/config.status libgcc
+	} | sanitise_includes \
+	  | write_mk $_OUTDIRBASE/lib/$_subdir/defs.mk
+
+	write_c $_OUTDIRBASE/lib/$_subdir/config.h \
+		<$_TMPDIR/$_PLATFORM/libobjc/config.h
+}
+
+##### lib/libstdc++-v3 #####
+
+get_libstdcxx_v3 () {
+	_subdir="$1"
+	_ver="$2"
+
+	mkdir -p $_OUTDIR/lib/$_subdir/arch/$MACHINE_ARCH
+
+	_build_headers="c++allocator.h c++config.h cxxabi_tweaks.h gthr-default.h gthr-posix.h gthr-single.h gthr.h"
+	_headers1="c_base_headers_extra_install"
+	_headers1="$_headers1 tr1_headers tr2_headers decimal_headers c_compatibility_headers_install"
+	_headers1="$_headers1 debug_headers parallel_headers"
+	_headers2="host_headers thread_host_headers"
+	_pf_headers="profile_headers profile_impl_headers"
+	_pb_headers="pb_headers1 pb_headers2 pb_headers3 pb_headers4 pb_headers5 pb_headers6 pb_headers7"
+
+	# build files
+	for h in $_build_headers; do
+		write_c $_OUTDIRBASE/lib/$_subdir/arch/$MACHINE_ARCH/$h \
+			<$_TMPDIR/$_PLATFORM/libstdc++-v3/include/$_PLATFORM/bits/$h
+	done
+
+	write_c $_OUTDIRBASE/lib/$_subdir/arch/$MACHINE_ARCH/config.h \
+		<$_TMPDIR/$_PLATFORM/libstdc++-v3/config.h
+	write_c $_OUTDIRBASE/lib/$_subdir/arch/$MACHINE_ARCH/gstdint.h \
+		<$_TMPDIR/$_PLATFORM/libstdc++-v3/include/gstdint.h
+
+	{
+		# libsupc++
+		getvars $_PLATFORM/libstdc++-v3/libsupc++/Makefile \
+			sources | sed 's/^G_sources=/G_LIBSUPCXX_SOURCES=/'
+		getvars $_PLATFORM/libstdc++-v3/libsupc++/Makefile \
+			c_sources | sed 's/^G_c_sources=/G_LIBSUPCXX_C_SOURCES=/'
+
+		# includes
+		getvars $_PLATFORM/libstdc++-v3/include/Makefile \
+			c_base_headers std_headers | sed -e 's#/[^ 	][^ 	]*/##g' -e 's/\${GNUHOSTDIST}//g'
+
+		# src
+		getvars $_PLATFORM/libstdc++-v3/src/Makefile \
+			libstdc___la_SOURCES | sed 's/^G_libstdc___la_SOURCES=/G_SRC_SOURCES=/'
+		getvars $_PLATFORM/libstdc++-v3/src/c++11/Makefile \
+			libc__11convenience_la_SOURCES | sed 's/^G_libc__11convenience_la_SOURCES=/G_CPP11_SOURCES=/'
+		getvars $_PLATFORM/libstdc++-v3/src/c++98/Makefile \
+			libc__98convenience_la_SOURCES | sed 's/^G_libc__98convenience_la_SOURCES=/G_CPP98_SOURCES=/'
+		getvars $_PLATFORM/libstdc++-v3/Makefile ATOMICITY_SRCDIR \
+			BASIC_FILE_CC CLOCALE_CC CCODECVT_CC CCOLLATE_CC \
+			CCTYPE_CC  CMESSAGES_CC CMONEY_CC CNUMERIC_CC CTIME_CC \
+			CPU_OPT_BITS_RANDOM
+
+		# includes
+		getvars $_PLATFORM/libstdc++-v3/include/Makefile \
+			backward_headers c_base_headers_extra $_headers1 $_pb_headers | \
+				sed -e 's#\${GNUHOSTDIST}/libstdc++-v3/include/##g'
+		getvars $_PLATFORM/libstdc++-v3/include/Makefile \
+			bits_headers ext_headers $_headers2 | \
+				sed -e 's#\${GNUHOSTDIST}/libstdc++-v3/include/##g' -e 's#\${GNUHOSTDIST}/libstdc++-v3/config/##g'
+		getvars $_PLATFORM/libstdc++-v3/include/Makefile \
+			$_pf_headers | sed -e 's#\${GNUHOSTDIST}/libstdc++-v3/include/profile/##g'
+		getvars $_PLATFORM/libstdc++-v3/include/Makefile \
+			BASIC_FILE_H ALLOCATOR_H CSTDIO_H CLOCALE_H CMESSAGES_H CTIME_H
+		getlinks $_TMPDIR/$_PLATFORM/libgcc/config.status libgcc
+	} | sanitise_includes \
+	  | write_mk $_OUTDIRBASE/lib/$_subdir/arch/$MACHINE_ARCH/defs.mk
+}
+
+##### usr.bin/gcc* #####
+
+get_gcc_bootstrap () {
+	_subdir="$1"
+	mkdir -p $_OUTDIR/usr.bin/$_subdir/arch/$MACHINE_ARCH
+	for f in auto-host tm config; do
+		write_c $_OUTDIRBASE/usr.bin/$_subdir/arch/$MACHINE_ARCH/$f.h <$_TMPDIR/gcc/$f.h
+	done
+}
+
+get_gcc () {
+	_subdir="$1"
+	mkdir -p $_OUTDIR/usr.bin/$_subdir/arch/$MACHINE_ARCH
+	mkdir -p $_OUTDIR/usr.bin/libcpp/arch/$MACHINE_ARCH
+	mkdir -p $_OUTDIR/usr.bin/include/arch
+	_buildname="BUILD_"
+	_libcppsubdir=""
+	_extravars="TM_H ALL_OPT_FILES"
+	_hconfig_h=""
+	_extravars2="tm_file_list build_xm_include_list"
+	_extravars3="tm_p_include_list"
+
+	{
+		getvars gcc/Makefile \
+			${_buildname}EARLY_SUPPORT ${_buildname}ERRORS ${_buildname}PRINT \
+			${_buildname}RTL ${_buildname}SUPPORT ${_buildname}VARRAY \
+			${_buildname}MD | \
+		    sed -e 's#build/errors.o#build-errors.o#g' \
+			-e 's#build/print-rtl.o#build-print-rtl.o#g' \
+			-e 's#build/rtl.o#build-rtl.o#g' \
+			-e 's#build/varray.o#build-varray.o#g' \
+			-e 's#build/ggc-none.o#build-ggc-none.o#g' \
+			-e 's#build/##g'
+		getvars gcc/Makefile \
+			ALL_CFLAGS ALL_CPPFLAGS C_AND_OBJC_OBJS C_OBJS CCCP_OBJS \
+			GCC_OBJS GCOV_OBJS GXX_OBJS GTM_H PROTO_OBJS ${_extravars1} \
+			INCLUDES md_file OBJC_OBJS OBJS out_file version \
+			BUILD_PREFIX RTL_H RTL_BASE_H TREE_H ${_hconfig_h} BASIC_BLOCK_H GCC_H \
+			GTFILES_SRCDIR GTFILES_FILES_FILES GTFILES_FILES_LANGS \
+			GTFILES GTFILES_LANG_DIR_NAMES NOEXCEPTION_FLAGS \
+			NATIVE_SYSTEM_HEADER_DIR \
+			tm_defines host_xm_file host_xm_defines tm_p_file \
+			target_cpu_default ${_extravars} ${_extravars2} \
+			lang_specs_files ${_extravars3} \
+			common_out_file \
+				| sanitise_includes
+		getvars gcc/Makefile \
+			LIB2ADDEHDEP | sed 's/unwind.inc//'
+		getvars gcc/Makefile \
+			CXX_OBJS CXX_C_OBJS | sed 's/cp\///g'
+		getvars gcc/Makefile \
+			F77_OBJS | sed 's/f\///g'
+		getvars libcpp/Makefile \
+			libcpp_a_OBJS
+		getvars gcc/Makefile \
+			ENABLE_SHARED
+		echo G_SHLIB_LINK="$CC -shared"
+		echo G_SHLIB_MULTILIB=.
+	} | write_mk $_OUTDIRBASE/usr.bin/$_subdir/arch/$MACHINE_ARCH/defs.mk
+
+	getvars gcc/Makefile \
+		EXTRA_HEADERS \
+			| write_mk $_OUTDIRBASE/usr.bin/include/arch/$MACHINE_ARCH.mk
+
+	write_c $_OUTDIRBASE/usr.bin/libcpp/arch/$MACHINE_ARCH/config.h <$_TMPDIR/libcpp/config.h
+	hfiles='auto-host configargs config bconfig bversion plugin-version multilib tm'
+	for f in $hfiles; do
+		write_c $_OUTDIRBASE/usr.bin/$_subdir/arch/$MACHINE_ARCH/$f.h <$_TMPDIR/gcc/$f.h
+		if [ "${MACHINE_ARCH}" = "powerpc" -a "${f}" = "configargs" ]
+		then
+			ex <<__EOF__ $_OUTDIRBASE/usr.bin/$_subdir/arch/$MACHINE_ARCH/$f.h
+/configuration_arguments/ s/$//
+ya
+i
+#ifdef _SOFT_FLOAT
+.
+pu
+s/";$/ -with-float=soft";/
+a
+#else
+#endif
+.
+. m +1
+/configure_default_options/ s/{ NULL.*$//
+a
+#ifdef _SOFT_FLOAT
+  { "float", "soft" },
+#endif
+  { NULL, NULL }
+};
+.
+wq
+__EOF__
+		fi
+	done
+
+	# keep identical
+	for f in all-tree.def; do
+		cp $_TMPDIR/gcc/$f $_OUTDIR/usr.bin/$_subdir/arch/$MACHINE_ARCH/$f
+	done
+
+	# special transforms
+	for f in gtyp-input.list; do
+		sed -e 's/^.*external\/gpl3\/gcc\/dist/SRCDIR/' < $_TMPDIR/gcc/$f > $_OUTDIR/usr.bin/$_subdir/arch/$MACHINE_ARCH/$f
+	done
+
+	# special platforms
+	if [ "${MACHINE_ARCH}" = "sh3el" -o "${MACHINE_ARCH}" = "sh3eb" ]; then
+		write_c $_OUTDIRBASE/usr.bin/$_subdir/arch/$MACHINE_ARCH/sysroot-suffix.h <$_TMPDIR/gcc/sysroot-suffix.h
+	fi
+}
+
+##### main #####
+
+case "$1" in
+# .mk and .h files for libgcc bootstrap (from host build)
+
+libgcc*-bootstrap)
+	_OUTDIR="$_TOP/external/gpl3/gcc"
+	_OUTDIRBASE="external/gpl3/gcc"
+	get_libgcc gcc
+	get_libgcov gcc $_PLATFORM/libgcc/Makefile
+	get_crtstuff crtstuff
+	get_gcc_bootstrap gcc
+	exit 0
+	;;
+
+libstdc++-bootstrap)
+	_OUTDIR="$_TOP/external/gpl3/gcc"
+	_OUTDIRBASE="external/gpl3/gcc"
+	get_libstdcxx_v3 libstdc++-v3 gcc
+	exit 0
+	;;
+
+gcc*)
+	_OUTDIR="$_TOP/external/gpl3/gcc"
+	_OUTDIRBASE="external/gpl3/gcc"
+	get_gcc gcc
+	get_libgcc gcc
+	get_libgcov gcc $_PLATFORM/libgcc/Makefile
+	get_crtstuff crtstuff
+	get_gcc_libiberty gcc
+	get_libobjc libobjc
+	get_libstdcxx_v3 libstdc++-v3 gcc
+	get_libdecnumber libdecnumber
+	get_libgomp libgomp
+	get_libbacktrace libbacktrace
+	exit 0
+	;;
+
+
+*)
+	echo invalid arguments;
+	exit 1
+	;;
+esac

Reply via email to