summaryrefslogtreecommitdiff
path: root/Toolchain/Patches/gcc.patch
diff options
context:
space:
mode:
authorItamar <itamar8910@gmail.com>2020-12-12 11:21:53 +0200
committerAndreas Kling <kling@serenityos.org>2020-12-14 23:05:53 +0100
commit2ba5a325d5c11d0c1da7b2f7b014cd0c477c73c7 (patch)
treeb77e71bee15ad521c32024680be887d9f99d8f50 /Toolchain/Patches/gcc.patch
parentd2a984f2c730aca86a3b68991bb08eaf3ab96c42 (diff)
downloadserenity-2ba5a325d5c11d0c1da7b2f7b014cd0c477c73c7.zip
Toolchain+Ports: Fix gcc patch file
Previously, some hunks of the t-slibgcc patch failed to apply
Diffstat (limited to 'Toolchain/Patches/gcc.patch')
-rw-r--r--Toolchain/Patches/gcc.patch1687
1 files changed, 1626 insertions, 61 deletions
diff --git a/Toolchain/Patches/gcc.patch b/Toolchain/Patches/gcc.patch
index f06a160904..7cf7a59586 100644
--- a/Toolchain/Patches/gcc.patch
+++ b/Toolchain/Patches/gcc.patch
@@ -1,7 +1,6 @@
-diff --git a/config.sub b/config.sub
-index a318a4686..c5c551eb2 100755
---- a/config.sub
-+++ b/config.sub
+diff -ruN a/config.sub b/config.sub
+--- a/config.sub 2020-07-23 09:35:16.912379792 +0300
++++ b/config.sub 2020-12-12 10:43:35.280270540 +0200
@@ -2,7 +2,7 @@
# Configuration validation subroutine script.
# Copyright 1992-2019 Free Software Foundation, Inc.
@@ -11,7 +10,7 @@ index a318a4686..c5c551eb2 100755
# This file is free software; you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by
-@@ -1366,7 +1366,7 @@ case $os in
+@@ -1366,7 +1366,7 @@
| skyos* | haiku* | rdos* | toppers* | drops* | es* \
| onefs* | tirtos* | phoenix* | fuchsia* | redox* | bme* \
| midnightbsd* | amdhsa* | unleashed* | emscripten* | wasi* \
@@ -20,11 +19,10 @@ index a318a4686..c5c551eb2 100755
# Remember, each alternative MUST END IN *, to match a version number.
;;
qnx*)
-diff --git a/fixincludes/mkfixinc.sh b/fixincludes/mkfixinc.sh
-index df90720b7..a45cdd0de 100755
---- a/fixincludes/mkfixinc.sh
-+++ b/fixincludes/mkfixinc.sh
-@@ -11,6 +11,7 @@ target=fixinc.sh
+diff -ruN a/fixincludes/mkfixinc.sh b/fixincludes/mkfixinc.sh
+--- a/fixincludes/mkfixinc.sh 2020-07-23 09:35:16.932380013 +0300
++++ b/fixincludes/mkfixinc.sh 2020-12-12 10:43:35.280270540 +0200
+@@ -11,6 +11,7 @@
# Check for special fix rules for particular targets
case $machine in
@@ -32,11 +30,9 @@ index df90720b7..a45cdd0de 100755
i?86-*-cygwin* | \
i?86-*-mingw32* | \
x86_64-*-mingw32* | \
-diff --git a/b/gcc/config/arm/serenity-elf.h b/gcc/config/arm/serenity-elf.h
-new file mode 100644
-index 000000000..24b29c3da
---- /dev/null
-+++ b/gcc/config/arm/serenity-elf.h
+diff -ruN a/gcc/config/arm/serenity-elf.h b/gcc/config/arm/serenity-elf.h
+--- a/gcc/config/arm/serenity-elf.h 1970-01-01 02:00:00.000000000 +0200
++++ b/gcc/config/arm/serenity-elf.h 2020-12-12 10:43:35.280270540 +0200
@@ -0,0 +1,65 @@
+/* Definitions of target machine for GNU compiler, NetBSD/arm ELF version.
+ Copyright (C) 2002-2018 Free Software Foundation, Inc.
@@ -103,11 +99,9 @@ index 000000000..24b29c3da
+
+#undef PTRDIFF_TYPE
+#define PTRDIFF_TYPE "long int"
-diff --git a/b/gcc/config/serenity.h b/gcc/config/serenity.h
-new file mode 100644
-index 000000000..2692b8e57
---- /dev/null
-+++ b/gcc/config/serenity.h
+diff -ruN a/gcc/config/serenity.h b/gcc/config/serenity.h
+--- a/gcc/config/serenity.h 1970-01-01 02:00:00.000000000 +0200
++++ b/gcc/config/serenity.h 2020-12-12 10:43:35.280270540 +0200
@@ -0,0 +1,31 @@
+/* Useful if you wish to make target-specific GCC changes. */
+#undef TARGET_SERENITY
@@ -140,11 +134,10 @@ index 000000000..2692b8e57
+ builtin_assert ("system=unix"); \
+ builtin_assert ("system=posix"); \
+ } while(0);
-diff --git a/gcc/config.gcc b/gcc/config.gcc
-index cf1a87e2e..d2f20aaf3 100644
---- a/gcc/config.gcc
-+++ b/gcc/config.gcc
-@@ -675,6 +675,11 @@ x86_cpus="generic intel"
+diff -ruN a/gcc/config.gcc b/gcc/config.gcc
+--- a/gcc/config.gcc 2020-07-23 09:35:17.316384243 +0300
++++ b/gcc/config.gcc 2020-12-12 10:43:35.280270540 +0200
+@@ -675,6 +675,11 @@
# Common parts for widely ported systems.
case ${target} in
@@ -156,7 +149,7 @@ index cf1a87e2e..d2f20aaf3 100644
*-*-darwin*)
tmake_file="t-darwin "
tm_file="${tm_file} darwin.h"
-@@ -1033,6 +1038,15 @@ case ${target} in
+@@ -1033,6 +1038,15 @@
esac
case ${target} in
@@ -172,11 +165,30 @@ index cf1a87e2e..d2f20aaf3 100644
aarch64*-*-elf | aarch64*-*-fuchsia* | aarch64*-*-rtems*)
tm_file="${tm_file} dbxelf.h elfos.h newlib-stdint.h"
tm_file="${tm_file} aarch64/aarch64-elf.h aarch64/aarch64-errata.h aarch64/aarch64-elf-raw.h"
-diff --git a/libgcc/config.host b/libgcc/config.host
-index 1ff415923..38aa1c972 100644
---- a/libgcc/config.host
-+++ b/libgcc/config.host
-@@ -1485,6 +1485,22 @@ nvptx-*)
+diff -ruN a/libgcc/config/t-slibgcc b/libgcc/config/t-slibgcc
+--- a/libgcc/config/t-slibgcc 2020-07-23 09:35:18.796400548 +0300
++++ b/libgcc/config/t-slibgcc 2020-12-12 10:56:01.439116155 +0200
+@@ -26,7 +26,6 @@
+ SHLIB_OBJS = @shlib_objs@
+ SHLIB_DIR = @multilib_dir@
+ SHLIB_SLIBDIR_QUAL = @shlib_slibdir_qual@
+-SHLIB_LC = -lc
+ SHLIB_MAKE_SOLINK = $(LN_S) $(SHLIB_SONAME) $(SHLIB_DIR)/$(SHLIB_SOLINK)
+ SHLIB_INSTALL_SOLINK = $(LN_S) $(SHLIB_SONAME) \
+ $(DESTDIR)$(slibdir)$(SHLIB_SLIBDIR_QUAL)/$(SHLIB_SOLINK)
+@@ -34,7 +33,7 @@
+ SHLIB_LINK = $(CC) $(LIBGCC2_CFLAGS) -shared -nodefaultlibs \
+ $(SHLIB_LDFLAGS) \
+ -o $(SHLIB_DIR)/$(SHLIB_SONAME).tmp @multilib_flags@ \
+- $(SHLIB_OBJS) $(SHLIB_LC) && \
++ $(SHLIB_OBJS) && \
+ rm -f $(SHLIB_DIR)/$(SHLIB_SOLINK) && \
+ if [ -f $(SHLIB_DIR)/$(SHLIB_SONAME) ]; then \
+ mv -f $(SHLIB_DIR)/$(SHLIB_SONAME) \
+diff -ruN a/libgcc/config.host b/libgcc/config.host
+--- a/libgcc/config.host 2020-07-23 09:35:18.752400064 +0300
++++ b/libgcc/config.host 2020-12-12 10:43:35.280270540 +0200
+@@ -1491,6 +1491,22 @@
tmake_file="$tmake_file nvptx/t-nvptx"
extra_parts="crt0.o"
;;
@@ -199,11 +211,1585 @@ index 1ff415923..38aa1c972 100644
*)
echo "*** Configuration ${host} not supported" 1>&2
exit 1
-diff --git a/libstdc++-v3/configure b/libstdc++-v3/configure
-index 9f9c5a241..9055fe09e 100755
---- a/libstdc++-v3/configure
-+++ b/libstdc++-v3/configure
-@@ -29846,6 +29846,5986 @@ else
+diff -ruN a/libgcc/config.host.orig b/libgcc/config.host.orig
+--- a/libgcc/config.host.orig 1970-01-01 02:00:00.000000000 +0200
++++ b/libgcc/config.host.orig 2020-07-23 09:35:18.752400064 +0300
+@@ -0,0 +1,1571 @@
++# libgcc host-specific configuration file.
++# Copyright (C) 1997-2020 Free Software Foundation, Inc.
++
++#This file is part of GCC.
++
++#GCC is free software; you can redistribute it and/or modify it under
++#the terms of the GNU General Public License as published by the Free
++#Software Foundation; either version 3, or (at your option) any later
++#version.
++
++#GCC is distributed in the hope that it will be useful, but WITHOUT
++#ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
++#FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
++#for more details.
++
++#You should have received a copy of the GNU General Public License
++#along with GCC; see the file COPYING3. If not see
++#<http://www.gnu.org/licenses/>.
++
++# This is the libgcc host-specific configuration file
++# where a configuration type is mapped to different system-specific
++# definitions and files. This is invoked by the autoconf-generated
++# configure script. Putting it in a separate shell file lets us skip
++# running autoconf when modifying host-specific information.
++
++# This file bears an obvious resemblance to gcc/config.gcc. The cases
++# should be kept similar, to ease moving library-specific settings
++# from config.gcc to this file. That is also why tmake_file is
++# left as tmake_file, rather than hmake_file, even though this library
++# switches on ${host}.
++
++# This file switches on the shell variable ${host}, and also uses the
++# following shell variables:
++#
++# with_* Various variables as set by configure.
++
++# This file sets the following shell variables for use by the
++# autoconf-generated configure script:
++#
++# asm_hidden_op The assembler pseudo-op to use for hide
++# lists for object files implemented in
++# assembly (with -fvisibility=hidden for C).
++# The default is ".hidden".
++# cpu_type The name of the cpu, if different from the first
++# chunk of the canonical host name.
++# enable_execute_stack The name of a source file implementing
++# __enable_execute_stack.
++# extra_parts List of extra object files that should be compiled
++# for this target machine. This may be overridden
++# by setting EXTRA_PARTS in a tmake_file fragment.
++# If either is set, EXTRA_PARTS and
++# EXTRA_MULTILIB_PARTS inherited from the GCC
++# subdirectory will be ignored.
++# md_unwind_header The name of a header file defining
++# MD_FALLBACK_FRAME_STATE_FOR.
++# sfp_machine_header The name of a sfp-machine.h header file for soft-fp.
++# Defaults to "$cpu_type/sfp-machine.h" if it exists,
++# no-sfp-machine.h otherwise.
++# tmake_file A list of machine-description-specific
++# makefile fragments.
++# tm_defines List of target macros to define for all compilations.
++# tm_file A list of target macro files used only for code
++# built for the target, not the host. These files
++# are relative to $srcdir/config and must not have
++# the same names as files in $srcdir/../gcc/config.
++# unwind_header The name of the header file declaring the unwind
++# runtime interface routines.
++
++asm_hidden_op=.hidden
++enable_execute_stack=
++extra_parts=
++tmake_file=
++tm_file=
++tm_define=
++md_unwind_header=no-unwind.h
++unwind_header=unwind-generic.h
++
++# Set default cpu_type so it can be updated in each machine entry.
++cpu_type=`echo ${host} | sed 's/-.*$//'`
++case ${host} in
++m32c*-*-*)
++ cpu_type=m32c
++ tmake_file=t-fdpbit
++ ;;
++aarch64*-*-*)
++ cpu_type=aarch64
++ ;;
++alpha*-*-*)
++ cpu_type=alpha
++ ;;
++am33_2.0-*-linux*)
++ cpu_type=mn10300
++ ;;
++amdgcn*-*-*)
++ cpu_type=gcn
++ tmake_file="${tmake_file} t-softfp-sfdf t-softfp"
++ ;;
++arc*-*-*)
++ cpu_type=arc
++ ;;
++arm*-*-*)
++ cpu_type=arm
++ ;;
++avr-*-*)
++ cpu_type=avr
++ ;;
++bfin*-*)
++ cpu_type=bfin
++ ;;
++bpf-*-*)
++ cpu_type=bpf
++ ;;
++cr16-*-*)
++ ;;
++crisv32-*-*)
++ cpu_type=cris
++ ;;
++csky*-*-*)
++ cpu_type=csky
++ ;;
++fido-*-*)
++ cpu_type=m68k
++ ;;
++frv*) cpu_type=frv
++ ;;
++ft32*) cpu_type=ft32
++ ;;
++moxie*) cpu_type=moxie
++ ;;
++i[34567]86-*-*)
++ cpu_type=i386
++ ;;
++x86_64-*-*)
++ cpu_type=i386
++ ;;
++ia64-*-*)
++ ;;
++hppa*-*-*)
++ cpu_type=pa
++ ;;
++lm32*-*-*)
++ cpu_type=lm32
++ ;;
++m32r*-*-*)
++ cpu_type=m32r
++ ;;
++m68k-*-*)
++ ;;
++microblaze*-*-*)
++ cpu_type=microblaze
++ ;;
++mips*-*-*)
++ # All MIPS targets provide a full set of FP routines.
++ cpu_type=mips
++ tmake_file="mips/t-mips"
++ if test "${libgcc_cv_mips_hard_float}" = yes; then
++ tmake_file="${tmake_file} t-hardfp-sfdf t-hardfp"
++ else
++ tmake_file="${tmake_file} t-softfp-sfdf"
++ fi
++ if test "${ac_cv_sizeof_long_double}" = 16; then
++ tmake_file="${tmake_file} mips/t-softfp-tf"
++ fi
++ if test "${host_address}" = 64; then
++ tmake_file="${tmake_file} mips/t-mips64"
++ fi
++ tmake_file="${tmake_file} t-softfp"
++ ;;
++nds32*-*)
++ cpu_type=nds32
++ ;;
++nios2*-*-*)
++ cpu_type=nios2
++ ;;
++or1k*-*-*)
++ cpu_type=or1k
++ ;;
++powerpc*-*-*)
++ cpu_type=rs6000
++ ;;
++pru-*-*)
++ cpu_type=pru
++ ;;
++rs6000*-*-*)
++ ;;
++riscv*-*-*)
++ cpu_type=riscv
++ ;;
++sparc64*-*-*)
++ cpu_type=sparc
++ ;;
++sparc*-*-*)
++ cpu_type=sparc
++ ;;
++s390*-*-*)
++ cpu_type=s390
++ ;;
++# Note the 'l'; we need to be able to match e.g. "shle" or "shl".
++sh[123456789lbe]*-*-*)
++ cpu_type=sh
++ ;;
++tilegx*-*-*)
++ cpu_type=tilegx
++ ;;
++tilepro*-*-*)
++ cpu_type=tilepro
++ ;;
++v850*-*-*)
++ cpu_type=v850
++ ;;
++tic6x-*-*)
++ cpu_type=c6x
++ ;;
++esac
++
++# Common parts for widely ported systems.
++case ${host} in
++*-*-darwin*)
++ asm_hidden_op=.private_extern
++ tmake_file="$tmake_file t-darwin ${cpu_type}/t-darwin t-libgcc-pic t-slibgcc-darwin"
++ extra_parts="crt3.o d10-uwfef.o crttms.o crttme.o"
++ ;;
++*-*-dragonfly*)
++ tmake_file="$tmake_file t-crtstuff-pic t-libgcc-pic t-eh-dw2-dip"
++ tmake_file="$tmake_file t-slibgcc t-slibgcc-gld t-slibgcc-elf-ver"
++ extra_parts="crtbegin.o crtend.o crtbeginS.o crtendS.o"
++ ;;
++*-*-freebsd*)
++ # This is the generic ELF configuration of FreeBSD. Later
++ # machine-specific sections may refine and add to this
++ # configuration.
++ tmake_file="$tmake_file t-freebsd t-crtstuff-pic t-libgcc-pic t-eh-dw2-dip t-slibgcc t-slibgcc-gld t-slibgcc-elf-ver"
++ extra_parts="crtbegin.o crtend.o crtbeginS.o crtendS.o"
++ case ${target_thread_file} in
++ posix)
++ tmake_file="${tmake_file} t-freebsd-thread"
++ # Before 5.0, FreeBSD can't bind shared libraries to -lc
++ # when "optionally" threaded via weak pthread_* checks.
++ case ${host} in
++ *-*-freebsd[34] | *-*-freebsd[34].*)
++ tmake_file="${tmake_file} t-slibgcc-nolc-override"
++ ;;
++ esac
++ ;;
++ esac
++ ;;
++*-*-fuchsia*)
++ tmake_file="$tmake_file t-crtstuff-pic t-libgcc-pic t-eh-dw2-dip t-slibgcc t-slibgcc-fuchsia"
++ extra_parts="crtbegin.o crtend.o"
++ ;;
++*-*-linux* | frv-*-*linux* | *-*-kfreebsd*-gnu | *-*-gnu* | *-*-kopensolaris*-gnu | *-*-uclinuxfdpiceabi)
++ tmake_file="$tmake_file t-crtstuff-pic t-libgcc-pic t-eh-dw2-dip t-slibgcc t-slibgcc-gld t-slibgcc-elf-ver t-linux"
++ extra_parts="crtbegin.o crtbeginS.o crtbeginT.o crtend.o crtendS.o"
++ if test x$enable_vtable_verify = xyes; then
++ extra_parts="$extra_parts vtv_start.o vtv_end.o vtv_start_preinit.o vtv_end_preinit.o"
++ fi
++ ;;
++*-*-lynxos*)
++ tmake_file="$tmake_file t-lynx $cpu_type/t-crtstuff t-crtstuff-pic t-libgcc-pic"
++ extra_parts="crtbegin.o crtbeginS.o crtend.o crtendS.o"
++ ;;
++*-*-netbsd*)
++ tmake_file="$tmake_file t-crtstuff-pic t-libgcc-pic t-eh-dw2-dip"
++ tmake_file="$tmake_file t-slibgcc t-slibgcc-gld t-slibgcc-elf-ver"
++ tmake_file="$tmake_file t-slibgcc-libgcc"
++ extra_parts="crtbegin.o crtend.o crtbeginS.o crtendS.o crtbeginT.o"
++ ;;
++*-*-openbsd*)
++ tmake_file="$tmake_file t-crtstuff-pic t-libgcc-pic t-eh-dw2-dip"
++ case ${target_thread_file} in
++ posix)
++ tmake_file="$tmake_file t-openbsd-thread"
++ ;;
++ esac
++ ;;
++*-*-rtems*)
++ tmake_file="$tmake_file t-rtems"
++ extra_parts="crtbegin.o crtend.o"
++ ;;
++*-*-solaris2*)
++ # Unless linker support and dl_iterate_phdr are present,
++ # unwind-dw2-fde-dip.c automatically falls back to unwind-dw2-fde.c.
++ tmake_file="$tmake_file sol2/t-sol2 t-eh-dw2-dip t-crtstuff-pic t-libgcc-pic t-slibgcc t-slibgcc-elf-ver"
++ if test $with_gnu_ld = yes; then
++ tmake_file="$tmake_file t-slibgcc-gld"
++ else
++ tmake_file="$tmake_file t-slibgcc-sld"
++ fi
++ # Add cpu-specific t-sol2 after t-slibgcc-* so it can augment SHLIB_MAPFILES.
++ tmake_file="$tmake_file $cpu_type/t-sol2"
++ extra_parts="gmon.o crtbegin.o crtend.o"
++ if test "${libgcc_cv_solaris_crts}" = yes; then
++ # Solaris 11.4 provides crt1.o, crti.o, and crtn.o as part of the
++ # base system. crtp.o and crtpg.o implement the compiler-dependent parts.
++ extra_parts="$extra_parts crtp.o crtpg.o"
++ # If the Solaris CRTs are present, both ld and gld will have PIE support.
++ extra_parts="$extra_parts crtbeginS.o crtendS.o"
++ else
++ case ${host} in
++ i?86-*-solaris2* | x86_64-*-solaris2*)
++ # Solaris 10+/x86 provides crt1.o, crti.o, crtn.o, and gcrt1.o as
++ # part of the base system.
++ ;;
++ sparc*-*-solaris2*)
++ # Solaris 10+/SPARC lacks crt1.o and gcrt1.o.
++ extra_parts="$extra_parts crt1.o gcrt1.o"
++ ;;
++ esac
++ fi
++ if test x$enable_vtable_verify = xyes; then
++ extra_parts="$extra_parts vtv_start.o vtv_end.o vtv_start_preinit.o vtv_end_preinit.o"
++ fi
++ ;;
++*-*-uclinux*)
++ extra_parts="crtbegin.o crtend.o"
++ ;;
++*-*-*vms*)
++ tmake_file="vms/t-vms"
++ extra_parts="crt0.o crtbegin.o crtbeginS.o crtend.o crtendS.o"
++ ;;
++*-*-vxworks7*)
++ tmake_file=t-vxworks7
++ ;;
++*-*-vxworksae*)
++ tmake_file=t-vxworksae
++ ;;
++*-*-vxworks*)
++ tmake_file=t-vxworks
++ ;;
++*-*-elf)
++ extra_parts="crtbegin.o crtend.o"
++ ;;
++esac
++
++# Except on ARM where we do not use DWARF, table based EH on VxWorks
++# relies on specially crafted crtstuff files
++case ${host} in
++arm-*-vxworks*)
++ ;;
++*-*-vxworks*)
++ tmake_file="${tmake_file} t-vxcrtstuff"
++ ;;
++esac
++
++case ${host} in
++*-*-darwin* | *-*-dragonfly* | *-*-freebsd* | *-*-netbsd* | *-*-openbsd* | \
++ *-*-solaris2*)
++ enable_execute_stack=enable-execute-stack-mprotect.c
++ ;;
++i[34567]86-*-mingw* | x86_64-*-mingw*)
++ enable_execute_stack=config/i386/enable-execute-stack-mingw32.c
++ ;;
++i[34567]86-*-cygwin* | x86_64-*-cygwin*)
++ enable_execute_stack=config/i386/enable-execute-stack-mingw32.c
++ ;;
++*)
++ enable_execute_stack=enable-execute-stack-empty.c;
++ ;;
++esac
++
++case ${host} in
++aarch64*-*-elf | aarch64*-*-rtems*)
++ extra_parts="$extra_parts crtbegin.o crtend.o crti.o crtn.o"
++ extra_parts="$extra_parts crtfastmath.o"
++ tmake_file="${tmake_file} ${cpu_type}/t-aarch64"
++ tmake_file="${tmake_file} ${cpu_type}/t-lse t-slibgcc-libgcc"
++ tmake_file="${tmake_file} ${cpu_type}/t-softfp t-softfp t-crtfm"
++ md_unwind_header=aarch64/aarch64-unwind.h
++ ;;
++aarch64*-*-freebsd*)
++ extra_parts="$extra_parts crtfastmath.o"
++ tmake_file="${tmake_file} ${cpu_type}/t-aarch64"
++ tmake_file="${tmake_file} ${cpu_type}/t-lse t-slibgcc-libgcc"
++ tmake_file="${tmake_file} ${cpu_type}/t-softfp t-softfp t-crtfm"
++ md_unwind_header=aarch64/freebsd-unwind.h
++ ;;
++aarch64*-*-netbsd*)
++ extra_parts="$extra_parts crtfastmath.o"
++ tmake_file="${tmake_file} ${cpu_type}/t-aarch64"
++ tmake_file="${tmake_file} ${cpu_type}/t-softfp t-softfp t-crtfm"
++ md_unwind_header=aarch64/aarch64-unwind.h
++ ;;
++aarch64*-*-fuchsia*)
++ tmake_file="${tmake_file} ${cpu_type}/t-aarch64"
++ tmake_file="${tmake_file} ${cpu_type}/t-lse t-slibgcc-libgcc"
++ tmake_file="${tmake_file} ${cpu_type}/t-softfp t-softfp"
++ ;;
++aarch64*-*-linux*)
++ extra_parts="$extra_parts crtfastmath.o"
++ md_unwind_header=aarch64/linux-unwind.h
++ tmake_file="${tmake_file} ${cpu_type}/t-aarch64"
++ tmake_file="${tmake_file} ${cpu_type}/t-lse t-slibgcc-libgcc"
++ tmake_file="${tmake_file} ${cpu_type}/t-softfp t-softfp t-crtfm"
++ ;;
++aarch64*-*-vxworks7*)
++ extra_parts="$extra_parts crtfastmath.o"
++ md_unwind_header=aarch64/aarch64-unwind.h
++ tmake_file="${tmake_file} ${cpu_type}/t-aarch64"
++ tmake_file="${tmake_file} ${cpu_type}/t-softfp t-softfp t-crtfm"
++ ;;
++alpha*-*-linux*)
++ tmake_file="${tmake_file} alpha/t-alpha alpha/t-ieee t-crtfm alpha/t-linux"
++ extra_parts="$extra_parts crtfastmath.o"
++ md_unwind_header=alpha/linux-unwind.h
++ ;;
++alpha*-*-freebsd*)
++ tmake_file="${tmake_file} alpha/t-alpha alpha/t-ieee t-crtfm"
++ extra_parts="$extra_parts crtbeginT.o crtfastmath.o"
++ ;;
++alpha*-*-netbsd*)
++ tmake_file="${tmake_file} alpha/t-alpha alpha/t-ieee"
++ ;;
++alpha*-*-openbsd*)
++ tmake_file="${tmake_file} alpha/t-alpha alpha/t-ieee"
++ ;;
++alpha64-dec-*vms*)
++ tmake_file="$tmake_file alpha/t-alpha alpha/t-ieee alpha/t-vms t-slibgcc-vms"
++ extra_parts="$extra_parts vms-dwarf2.o vms-dwarf2eh.o"
++ md_unwind_header=alpha/vms-unwind.h
++ ;;
++alpha*-dec-*vms*)
++ tmake_file="$tmake_file alpha/t-alpha alpha/t-ieee alpha/t-vms t-slibgcc-vms"
++ extra_parts="$extra_parts vms-dwarf2.o vms-dwarf2eh.o"
++ md_unwind_header=alpha/vms-unwind.h
++ ;;
++amdgcn*-*-amdhsa)
++ tmake_file="$tmake_file gcn/t-amdgcn"
++ extra_parts="crt0.o"
++ ;;
++arc*-*-elf*)
++ tmake_file="arc/t-arc"
++ extra_parts="crti.o crtn.o crtend.o crtbegin.o crtendS.o crtbeginS.o"
++ extra_parts="$extra_parts crttls.o"
++ ;;
++arc*-*-linux*)
++ tmake_file="${tmake_file} t-slibgcc-libgcc t-slibgcc-nolc-override arc/t-arc-uClibc arc/t-arc"
++ extra_parts="$extra_parts crti.o crtn.o"
++ extra_parts="$extra_parts crttls.o"
++ md_unwind_header=arc/linux-unwind.h
++ ;;
++arm-wrs-vxworks7*)
++ tmake_file="$tmake_file arm/t-arm arm/t-elf arm/t-bpabi arm/t-vxworks7"
++ tmake_file="$tmake_file t-softfp-sfdf t-softfp-excl arm/t-softfp t-softfp"
++ tm_file="$tm_file arm/bpabi-lib.h"
++ unwind_header=config/arm/unwind-arm.h
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++arm*-*-freebsd*) # ARM FreeBSD EABI
++ tmake_file="${tmake_file} arm/t-arm t-fixedpoint-gnu-prefix arm/t-elf"
++ tmake_file="${tmake_file} arm/t-bpabi arm/t-freebsd"
++ tm_file="${tm_file} arm/bpabi-lib.h"
++ unwind_header=config/arm/unwind-arm.h
++ tmake_file="${tmake_file} t-softfp-sfdf t-softfp-excl arm/t-softfp t-softfp"
++ ;;
++arm*-*-fuchsia*)
++ tmake_file="${tmake_file} arm/t-arm arm/t-elf arm/t-bpabi"
++ tmake_file="${tmake_file} arm/tsoftfp t-softfp"
++ tm_file="${tm_file} arm/bpabi-lib.h"
++ unwind_header=config/arm/unwind-arm.h
++ ;;
++arm*-*-netbsdelf*)
++ tmake_file="$tmake_file arm/t-arm"
++ case ${host} in
++ arm*-*-netbsdelf-*eabi*)
++ tmake_file="${tmake_file} arm/t-netbsd-eabi"
++ unwind_header=config/arm/unwind-arm.h
++ ;;
++ *)
++ tmake_file="${tmake_file} arm/t-netbsd t-slibgcc-gld-nover"
++ ;;
++ esac
++ ;;
++arm*-*-linux* | arm*-*-uclinuxfdpiceabi)
++ tmake_file="${tmake_file} arm/t-arm t-fixedpoint-gnu-prefix t-crtfm"
++ tmake_file="${tmake_file} arm/t-elf arm/t-bpabi arm/t-linux-eabi t-slibgcc-libgcc"
++ tm_file="$tm_file arm/bpabi-lib.h"
++ unwind_header=config/arm/unwind-arm.h
++ tmake_file="$tmake_file t-softfp-sfdf t-softfp-excl arm/t-softfp t-softfp"
++ extra_parts="$extra_parts crtfastmath.o"
++ ;;
++arm*-*-uclinux*) # ARM ucLinux
++ tmake_file="${tmake_file} t-fixedpoint-gnu-prefix t-crtfm"
++ tmake_file="$tmake_file arm/t-arm arm/t-elf t-softfp-sfdf t-softfp-excl arm/t-softfp t-softfp"
++ tmake_file="${tmake_file} arm/t-bpabi"
++ tm_file="$tm_file arm/bpabi-lib.h"
++ unwind_header=config/arm/unwind-arm.h
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++arm*-*-phoenix*)
++ tmake_file="t-hardfp t-softfp arm/t-arm arm/t-elf arm/t-softfp arm/t-phoenix"
++ tmake_file="${tmake_file} arm/t-bpabi"
++ tm_file="$tm_file arm/bpabi-lib.h"
++ extra_parts="crtbegin.o crtend.o crti.o crtn.o"
++ unwind_header=config/arm/unwind-arm.h
++ ;;
++arm*-*-eabi* | arm*-*-symbianelf* | arm*-*-rtems*)
++ tmake_file="${tmake_file} arm/t-arm arm/t-elf t-fixedpoint-gnu-prefix"
++ tm_file="$tm_file arm/bpabi-lib.h"
++ case ${host} in
++ arm*-*-eabi* | arm*-*-rtems*)
++ tmake_file="${tmake_file} arm/t-bpabi t-crtfm"
++ extra_parts="crtbegin.o crtend.o crti.o crtn.o"
++ ;;
++ arm*-*-symbianelf*)
++ tmake_file="${tmake_file} arm/t-symbian t-slibgcc-nolc-override"
++ tm_file="$tm_file arm/symbian-lib.h"
++ # Symbian OS provides its own startup code.
++ ;;
++ esac
++ tmake_file="$tmake_file t-softfp-sfdf t-softfp-excl arm/t-softfp t-softfp"
++ extra_parts="$extra_parts crtfastmath.o"
++ unwind_header=config/arm/unwind-arm.h
++ ;;
++avr-*-*)
++ # Make HImode functions for AVR
++ tmake_file="${cpu_type}/t-avr t-fpbit"
++ # Make some DFmode functions from libf7, part of avr-libgcc.
++ # This must be prior to adding t-avrlibc.
++ case "y${with_libf7}" in
++ yno)
++ # No libf7 support.
++ ;;
++ ylibgcc)
++ tmake_file="$tmake_file ${cpu_type}/libf7/t-libf7"
++ ;;
++ ymath)
++ tmake_file="$tmake_file ${cpu_type}/libf7/t-libf7-math"
++ tmake_file="$tmake_file ${cpu_type}/libf7/t-libf7"
++ ;;
++ ymath-symbols | yyes | y)
++ tmake_file="$tmake_file ${cpu_type}/libf7/t-libf7-math-symbols"
++ tmake_file="$tmake_file ${cpu_type}/libf7/t-libf7-math"
++ tmake_file="$tmake_file ${cpu_type}/libf7/t-libf7"
++ ;;
++ *)
++ echo "Error: --with-libf7=${with_libf7} but can only be used with: 'libgcc', 'math', 'math-symbols', 'yes', 'no'" 1>&2
++ exit 1
++ ;;
++ esac
++ if test x${with_avrlibc} != xno; then
++ tmake_file="$tmake_file ${cpu_type}/t-avrlibc"
++ fi
++ tm_file="$tm_file avr/avr-lib.h"
++ if test x${with_fixed_point} = xno; then
++ fixed_point=no
++ fi
++ ;;
++bfin*-elf*)
++ tmake_file="bfin/t-bfin bfin/t-crtlibid bfin/t-crtstuff t-libgcc-pic t-fdpbit"
++ extra_parts="$extra_parts crtbeginS.o crtendS.o crti.o crtn.o crtlibid.o"
++ ;;
++bfin*-uclinux*)
++ tmake_file="bfin/t-bfin bfin/t-crtlibid bfin/t-crtstuff t-libgcc-pic t-fdpbit"
++ extra_parts="$extra_parts crtbeginS.o crtendS.o crtlibid.o"
++ md_unwind_header=bfin/linux-unwind.h
++ ;;
++bfin*-linux-uclibc*)
++ tmake_file="$tmake_file bfin/t-bfin bfin/t-crtstuff t-libgcc-pic t-fdpbit bfin/t-linux"
++ # No need to build crtbeginT.o on uClibc systems. Should probably
++ # be moved to the OS specific section above.
++ extra_parts="crtbegin.o crtbeginS.o crtend.o crtendS.o"
++ md_unwind_header=bfin/linux-unwind.h
++ ;;
++bfin*-rtems*)
++ tmake_file="$tmake_file bfin/t-bfin t-fdpbit"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++bfin*-*)
++ tmake_file="$tmake_file bfin/t-bfin t-fdpbit"
++ extra_parts="crtbegin.o crtend.o crti.o crtn.o"
++ ;;
++bpf-*-*)
++ tmake_file="$tmake_file ${cpu_type}/t-${cpu_type}"
++ extra_parts="crti.o crtn.o"
++ ;;
++cr16-*-elf)
++ tmake_file="${tmake_file} cr16/t-cr16 cr16/t-crtlibid t-fdpbit"
++ extra_parts="$extra_parts crti.o crtn.o crtlibid.o"
++ ;;
++crisv32-*-elf)
++ tmake_file="$tmake_file cris/t-cris t-softfp-sfdf t-softfp"
++ ;;
++cris-*-elf)
++ tmake_file="$tmake_file cris/t-cris t-softfp-sfdf t-softfp cris/t-elfmulti"
++ ;;
++cris-*-linux* | crisv32-*-linux*)
++ tmake_file="$tmake_file cris/t-cris t-softfp-sfdf t-softfp cris/t-linux"
++ ;;
++csky-*-elf*)
++ tmake_file="csky/t-csky t-fdpbit"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++csky-*-linux*)
++ tmake_file="$tmake_file csky/t-csky t-slibgcc-libgcc t-fdpbit csky/t-linux-csky"
++ extra_parts="$extra_parts crti.o crtn.o"
++ md_unwind_header=csky/linux-unwind.h
++ ;;
++epiphany-*-elf* | epiphany-*-rtems*)
++ tmake_file="$tmake_file epiphany/t-epiphany t-fdpbit epiphany/t-custom-eqsf"
++ extra_parts="$extra_parts crti.o crtint.o crtrunc.o crtm1reg-r43.o crtm1reg-r63.o crtn.o"
++ ;;
++fr30-*-elf)
++ tmake_file="$tmake_file fr30/t-fr30 t-fdpbit"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++frv-*-elf)
++ tmake_file="$tmake_file frv/t-frv t-fdpbit"
++ tm_file="$tm_file frv/elf-lib.h frv/frv-abi.h"
++ # Don't use crtbegin.o, crtend.o.
++ extra_parts="frvbegin.o frvend.o"
++ ;;
++frv-*-*linux*)
++ tmake_file="$tmake_file frv/t-frv frv/t-linux t-fdpbit"
++ tm_file="$tm_file frv/elf-lib.h frv/frv-abi.h"
++ ;;
++ft32-*-elf)
++ tmake_file="ft32/t-ft32 t-softfp-sfdf t-softfp-excl t-softfp"
++ extra_parts="$extra_parts crti.o crti-hw.o crtn.o"
++ ;;
++h8300-*-elf*)
++ tmake_file="$tmake_file h8300/t-h8300 t-fpbit"
++ tm_file="$tm_file h8300/h8300-lib.h"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++h8300-*-linux*)
++ tmake_file="t-linux h8300/t-linux t-softfp-sfdf t-softfp"
++ tm_file="$tm_file h8300/h8300-lib.h"
++ ;;
++hppa*64*-*-linux*)
++ tmake_file="$tmake_file pa/t-linux pa/t-linux64"
++ extra_parts="crtbegin.o crtbeginS.o crtbeginT.o crtend.o crtendS.o"
++ ;;
++hppa*-*-linux*)
++ tmake_file="$tmake_file pa/t-linux t-slibgcc-libgcc"
++ # Set the libgcc version number
++ if test x$ac_cv_sjlj_exceptions = xyes; then
++ tmake_file="$tmake_file pa/t-slibgcc-sjlj-ver"
++ else
++ tmake_file="$tmake_file pa/t-slibgcc-dwarf-ver"
++ fi
++ extra_parts="crtbegin.o crtbeginS.o crtbeginT.o crtend.o crtendS.o"
++ md_unwind_header=pa/linux-unwind.h
++ ;;
++hppa[12]*-*-hpux10*)
++ tmake_file="$tmake_file pa/t-hpux pa/t-hpux10 t-libgcc-pic t-slibgcc"
++ # Set the libgcc version number
++ if test x$ac_cv_sjlj_exceptions = xyes; then
++ tmake_file="$tmake_file pa/t-slibgcc-sjlj-ver"
++ else
++ tmake_file="$tmake_file pa/t-slibgcc-dwarf-ver"
++ fi
++ tmake_file="$tmake_file pa/t-slibgcc-hpux t-slibgcc-hpux"
++ md_unwind_header=pa/hpux-unwind.h
++ ;;
++hppa*64*-*-hpux11*)
++ tmake_file="$tmake_file pa/t-hpux pa/t-pa64 pa/t-stublib t-libgcc-pic t-slibgcc"
++ # Set the libgcc version number
++ if test x$ac_cv_sjlj_exceptions = xyes; then
++ tmake_file="$tmake_file pa/t-slibgcc-sjlj-ver"
++ else
++ tmake_file="$tmake_file pa/t-slibgcc-dwarf-ver"
++ fi
++ tmake_file="$tmake_file pa/t-slibgcc-hpux t-slibgcc-hpux"
++ tm_file="$tm_file pa/pa64-hpux-lib.h"
++ extra_parts="crtbegin.o crtend.o crtbeginS.o crtendS.o crtbeginT.o \
++ libgcc_stub.a"
++ md_unwind_header=pa/hpux-unwind.h
++ ;;
++hppa[12]*-*-hpux11*)
++ tmake_file="$tmake_file pa/t-hpux pa/t-stublib t-libgcc-pic t-slibgcc"
++ # Set the libgcc version number
++ if test x$ac_cv_sjlj_exceptions = xyes; then
++ tmake_file="$tmake_file pa/t-slibgcc-sjlj-ver"
++ else
++ tmake_file="$tmake_file pa/t-slibgcc-dwarf-ver"
++ fi
++ tmake_file="$tmake_file pa/t-slibgcc-hpux t-slibgcc-hpux"
++ extra_parts="libgcc_stub.a"
++ md_unwind_header=pa/hpux-unwind.h
++ ;;
++hppa*-*-openbsd*)
++ tmake_file="$tmake_file pa/t-openbsd"
++ ;;
++hppa*-*-netbsd*)
++ tmake_file="$tmake_file pa/t-netbsd"
++ ;;
++i[34567]86-*-darwin*)
++ tmake_file="$tmake_file i386/t-crtpc t-crtfm i386/t-msabi"
++ tm_file="$tm_file i386/darwin-lib.h"
++ extra_parts="$extra_parts crtprec32.o crtprec64.o crtprec80.o crtfastmath.o"
++ ;;
++x86_64-*-darwin*)
++ tmake_file="$tmake_file i386/t-crtpc t-crtfm i386/t-msabi"
++ tm_file="$tm_file i386/darwin-lib.h"
++ extra_parts="$extra_parts crtprec32.o crtprec64.o crtprec80.o crtfastmath.o"
++ ;;
++i[34567]86-*-elfiamcu)
++ tmake_file="$tmake_file i386/t-crtstuff t-softfp-sfdftf i386/32/t-softfp i386/32/t-iamcu i386/t-softfp t-softfp t-dfprules"
++ ;;
++i[34567]86-*-elf*)
++ tmake_file="$tmake_file i386/t-crtstuff t-crtstuff-pic t-libgcc-pic"
++ ;;
++x86_64-*-elf* | x86_64-*-rtems*)
++ tmake_file="$tmake_file i386/t-crtstuff t-crtstuff-pic t-libgcc-pic"
++ case ${host} in
++ x86_64-*-rtems*)
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++ esac
++ ;;
++x86_64-*-fuchsia*)
++ tmake_file="$tmake_file t-libgcc-pic"
++ ;;
++i[34567]86-*-dragonfly*)
++ tmake_file="${tmake_file} i386/t-dragonfly i386/t-crtstuff"
++ md_unwind_header=i386/dragonfly-unwind.h
++ ;;
++x86_64-*-dragonfly*)
++ tmake_file="${tmake_file} i386/t-dragonfly i386/t-crtstuff"
++ md_unwind_header=i386/dragonfly-unwind.h
++ ;;
++i[34567]86-*-freebsd*)
++ tmake_file="${tmake_file} i386/t-freebsd i386/t-crtstuff"
++ md_unwind_header=i386/freebsd-unwind.h
++ ;;
++x86_64-*-freebsd*)
++ tmake_file="${tmake_file} i386/t-freebsd i386/t-crtstuff"
++ md_unwind_header=i386/freebsd-unwind.h
++ ;;
++i[34567]86-*-netbsdelf*)
++ tmake_file="${tmake_file} i386/t-crtstuff"
++ ;;
++x86_64-*-netbsd*)
++ tmake_file="${tmake_file} i386/t-crtstuff"
++ ;;
++i[34567]86-*-openbsd*)
++ ;;
++x86_64-*-openbsd*)
++ ;;
++i[34567]86-*-linux*)
++ extra_parts="$extra_parts crtprec32.o crtprec64.o crtprec80.o crtfastmath.o"
++ tmake_file="${tmake_file} i386/t-crtpc t-crtfm i386/t-crtstuff t-dfprules"
++ tm_file="${tm_file} i386/elf-lib.h"
++ md_unwind_header=i386/linux-unwind.h
++ ;;
++i[34567]86-*-kfreebsd*-gnu | i[34567]86-*-kopensolaris*-gnu)
++ extra_parts="$extra_parts crtprec32.o crtprec64.o crtprec80.o crtfastmath.o"
++ tmake_file="${tmake_file} i386/t-crtpc t-crtfm i386/t-crtstuff t-dfprules"
++ tm_file="${tm_file} i386/elf-lib.h"
++ ;;
++i[34567]86-*-gnu*)
++ extra_parts="$extra_parts crtprec32.o crtprec64.o crtprec80.o crtfastmath.o"
++ tmake_file="${tmake_file} i386/t-crtpc t-crtfm i386/t-crtstuff t-dfprules"
++ tm_file="${tm_file} i386/elf-lib.h"
++ md_unwind_header=i386/gnu-unwind.h
++ ;;
++x86_64-*-linux*)
++ extra_parts="$extra_parts crtprec32.o crtprec64.o crtprec80.o crtfastmath.o"
++ tmake_file="${tmake_file} i386/t-crtpc t-crtfm i386/t-crtstuff t-dfprules"
++ tm_file="${tm_file} i386/elf-lib.h"
++ md_unwind_header=i386/linux-unwind.h
++ ;;
++x86_64-*-kfreebsd*-gnu)
++ extra_parts="$extra_parts crtprec32.o crtprec64.o crtprec80.o crtfastmath.o"
++ tmake_file="${tmake_file} i386/t-crtpc t-crtfm i386/t-crtstuff t-dfprules"
++ tm_file="${tm_file} i386/elf-lib.h"
++ ;;
++i[34567]86-pc-msdosdjgpp*)
++ ;;
++i[34567]86-*-lynxos*)
++ ;;
++i[34567]86-*-nto-qnx*)
++ tmake_file="$tmake_file i386/t-nto t-libgcc-pic"
++ extra_parts=crtbegin.o
++ ;;
++i[34567]86-*-rtems*)
++ tmake_file="$tmake_file i386/t-crtstuff t-softfp-sfdftf i386/32/t-softfp i386/t-softfp t-softfp"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++i[34567]86-*-solaris2* | x86_64-*-solaris2*)
++ tmake_file="$tmake_file i386/t-crtpc t-crtfm i386/t-msabi"
++ extra_parts="$extra_parts crtprec32.o crtprec64.o crtprec80.o crtfastmath.o"
++ tm_file="${tm_file} i386/elf-lib.h"
++ md_unwind_header=i386/sol2-unwind.h
++ ;;
++i[4567]86-wrs-vxworks|i[4567]86-wrs-vxworksae|i[4567]86-wrs-vxworks7|x86_64-wrs-vxworks7)
++ ;;
++i[34567]86-*-cygwin*)
++ extra_parts="crtbegin.o crtbeginS.o crtend.o crtfastmath.o"
++ if test x$enable_vtable_verify = xyes; then
++ extra_parts="$extra_parts vtv_start.o vtv_end.o vtv_start_preinit.o vtv_end_preinit.o"
++ fi
++ # This has to match the logic for DWARF2_UNWIND_INFO in gcc/config/i386/cygming.h
++ if test x$ac_cv_sjlj_exceptions = xyes; then
++ tmake_eh_file="i386/t-sjlj-eh"
++ else
++ tmake_eh_file="i386/t-dw2-eh"
++ fi
++ # Shared libgcc DLL install dir depends on cross/native build.
++ if test x${build} = x${host} ; then
++ tmake_dlldir_file="i386/t-dlldir"
++ else
++ tmake_dlldir_file="i386/t-dlldir-x"
++ fi
++ tmake_file="${tmake_file} ${tmake_eh_file} ${tmake_dlldir_file} i386/t-slibgcc-cygming i386/t-cygming i386/t-cygwin t-crtfm i386/t-chkstk t-dfprules"
++ ;;
++x86_64-*-cygwin*)
++ extra_parts="crtbegin.o crtbeginS.o crtend.o crtfastmath.o"
++ if test x$enable_vtable_verify = xyes; then
++ extra_parts="$extra_parts vtv_start.o vtv_end.o vtv_start_preinit.o vtv_end_preinit.o"
++ fi
++ # This has to match the logic for DWARF2_UNWIND_INFO in gcc/config/i386/cygming.h
++ if test x$ac_cv_sjlj_exceptions = xyes; then
++ tmake_eh_file="i386/t-sjlj-eh"
++ elif test "${host_address}" = 32; then
++ # biarch -m32 with --disable-sjlj-exceptions
++ tmake_eh_file="i386/t-dw2-eh"
++ else
++ tmake_eh_file="i386/t-seh-eh"
++ fi
++ # Shared libgcc DLL install dir depends on cross/native build.
++ if test x${build} = x${host} ; then
++ tmake_dlldir_file="i386/t-dlldir"
++ else
++ tmake_dlldir_file="i386/t-dlldir-x"
++ fi
++ # FIXME - dj - t-chkstk used to be in here, need a 64-bit version of that
++ tmake_file="${tmake_file} ${tmake_eh_file} ${tmake_dlldir_file} i386/t-slibgcc-cygming i386/t-cygming i386/t-cygwin t-crtfm t-dfprules i386/t-chkstk"
++ ;;
++i[34567]86-*-mingw*)
++ extra_parts="crtbegin.o crtend.o crtfastmath.o"
++ if test x$enable_vtable_verify = xyes; then
++ extra_parts="$extra_parts vtv_start.o vtv_end.o vtv_start_preinit.o vtv_end_preinit.o"
++ fi
++ case ${target_thread_file} in
++ win32)
++ tmake_file="$tmake_file i386/t-gthr-win32"
++ ;;
++ posix)
++ tmake_file="i386/t-mingw-pthread $tmake_file"
++ ;;
++ esac
++ # This has to match the logic for DWARF2_UNWIND_INFO in gcc/config/i386/cygming.h
++ if test x$ac_cv_sjlj_exceptions = xyes; then
++ tmake_eh_file="i386/t-sjlj-eh"
++ else
++ tmake_eh_file="i386/t-dw2-eh"
++ md_unwind_header=i386/w32-unwind.h
++ fi
++ # Shared libgcc DLL install dir depends on cross/native build.
++ if test x${build} = x${host} ; then
++ tmake_dlldir_file="i386/t-dlldir"
++ else
++ tmake_dlldir_file="i386/t-dlldir-x"
++ fi
++ tmake_file="${tmake_file} ${tmake_eh_file} ${tmake_dlldir_file} i386/t-slibgcc-cygming i386/t-cygming i386/t-mingw32 t-crtfm i386/t-chkstk t-dfprules"
++ ;;
++x86_64-*-mingw*)
++ case ${target_thread_file} in
++ win32)
++ tmake_file="$tmake_file i386/t-gthr-win32"
++ ;;
++ posix)
++ tmake_file="i386/t-mingw-pthread $tmake_file"
++ ;;
++ esac
++ # This has to match the logic for DWARF2_UNWIND_INFO in gcc/config/i386/cygming.h
++ if test x$ac_cv_sjlj_exceptions = xyes; then
++ tmake_eh_file="i386/t-sjlj-eh"
++ elif test "${host_address}" = 32; then
++ # biarch -m32 with --disable-sjlj-exceptions
++ tmake_eh_file="i386/t-dw2-eh"
++ md_unwind_header=i386/w32-unwind.h
++ else
++ tmake_eh_file="i386/t-seh-eh"
++ fi
++ # Shared libgcc DLL install dir depends on cross/native build.
++ if test x${build} = x${host} ; then
++ tmake_dlldir_file="i386/t-dlldir"
++ else
++ tmake_dlldir_file="i386/t-dlldir-x"
++ fi
++ tmake_file="${tmake_file} ${tmake_eh_file} ${tmake_dlldir_file} i386/t-slibgcc-cygming i386/t-cygming i386/t-mingw32 t-dfprules t-crtfm i386/t-chkstk"
++ extra_parts="$extra_parts crtbegin.o crtend.o crtfastmath.o"
++ if test x$enable_vtable_verify = xyes; then
++ extra_parts="$extra_parts vtv_start.o vtv_end.o vtv_start_preinit.o vtv_end_preinit.o"
++ fi
++ ;;
++ia64*-*-elf*)
++ extra_parts="$extra_parts crtbeginS.o crtendS.o crtfastmath.o"
++ tmake_file="ia64/t-ia64 ia64/t-ia64-elf ia64/t-eh-ia64 t-crtfm t-softfp-tf ia64/t-softfp t-softfp ia64/t-softfp-compat"
++ ;;
++ia64*-*-freebsd*)
++ extra_parts="$extra_parts crtfastmath.o"
++ tmake_file="$tmake_file ia64/t-ia64 ia64/t-ia64-elf ia64/t-eh-ia64 t-crtfm t-softfp-tf ia64/t-softfp t-softfp ia64/t-softfp-compat"
++ ;;
++ia64*-*-linux*)
++ # Don't use crtbeginT.o from *-*-linux* default.
++ extra_parts="crtbegin.o crtend.o crtbeginS.o crtendS.o crtfastmath.o"
++ tmake_file="$tmake_file ia64/t-ia64 ia64/t-ia64-elf t-crtfm t-softfp-tf ia64/t-softfp t-softfp ia64/t-softfp-compat ia64/t-eh-ia64 t-libunwind ia64/t-linux"
++ if test x$with_system_libunwind != xyes ; then
++ tmake_file="${tmake_file} t-libunwind-elf ia64/t-linux-libunwind"
++ fi
++ md_unwind_header=ia64/linux-unwind.h
++ ;;
++ia64*-*-hpux*)
++ tmake_file="ia64/t-ia64 ia64/t-ia64-elf ia64/t-hpux t-slibgcc ia64/t-slibgcc-hpux t-slibgcc-hpux"
++ ;;
++ia64-hp-*vms*)
++ tmake_file="$tmake_file ia64/t-ia64 ia64/t-eh-ia64 ia64/t-vms t-slibgcc-vms t-softfp-tf ia64/t-softfp t-softfp"
++ extra_parts="$extra_parts crtinitS.o"
++ md_unwind_header=ia64/vms-unwind.h
++ ;;
++iq2000*-*-elf*)
++ tmake_file="iq2000/t-iq2000 t-fdpbit"
++ # Don't use default.
++ extra_parts=
++ ;;
++lm32-*-elf*)
++ extra_parts="$extra_parts crti.o crtn.o"
++ tmake_file="lm32/t-lm32 lm32/t-elf t-softfp-sfdf t-softfp"
++ ;;
++lm32-*-rtems*)
++ tmake_file="$tmake_file lm32/t-lm32 lm32/t-elf t-softfp-sfdf t-softfp"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++lm32-*-uclinux*)
++ extra_parts="$extra_parts crtbegin.o crtendS.o crtbeginT.o"
++ tmake_file="lm32/t-lm32 lm32/t-uclinux t-libgcc-pic t-softfp-sfdf t-softfp"
++ ;;
++m32r-*-elf*)
++ tmake_file="$tmake_file m32r/t-m32r t-fdpbit"
++ extra_parts="$extra_parts crtinit.o crtfini.o"
++ ;;
++m32rle-*-elf*)
++ tmake_file=t-fdpbit
++ ;;
++m32r-*-linux*)
++ tmake_file="$tmake_file m32r/t-linux t-fdpbit"
++ ;;
++m32rle-*-linux*)
++ tmake_file="$tmake_file m32r/t-linux t-fdpbit"
++ ;;
++m68k-*-elf* | fido-*-elf)
++ tmake_file="$tmake_file m68k/t-floatlib"
++ ;;
++m68k*-*-netbsdelf*)
++ ;;
++m68k*-*-openbsd*)
++ ;;
++m68k-*-uclinux*) # Motorola m68k/ColdFire running uClinux with uClibc
++ tmake_file="$tmake_file m68k/t-floatlib m68k/t-linux"
++ md_unwind_header=m68k/linux-unwind.h
++ ;;
++m68k-*-linux*) # Motorola m68k's running GNU/Linux
++ # with ELF format using glibc 2
++ # aka the GNU/Linux C library 6.
++ tmake_file="$tmake_file m68k/t-floatlib m68k/t-linux"
++ # If not configured with setjmp/longjmp exceptions, bump the
++ # libgcc version number.
++ if test x$ac_cv_sjlj_exceptions != xyes; then
++ tmake_file="$tmake_file m68k/t-slibgcc-elf-ver"
++ fi
++ md_unwind_header=m68k/linux-unwind.h
++ ;;
++m68k-*-rtems*)
++ tmake_file="$tmake_file m68k/t-floatlib"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++mcore-*-elf)
++ tmake_file="mcore/t-mcore t-fdpbit"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++microblaze*-linux*)
++ tmake_file="${tmake_file} microblaze/t-microblaze t-fdpbit t-slibgcc-libgcc"
++ ;;
++microblaze*-*-elf)
++ tmake_file="${tmake_file} microblaze/t-microblaze t-fdpbit"
++ extra_parts="$extra_parts crtbeginS.o crtendS.o crtbeginT.o crti.o crtn.o"
++ ;;
++microblaze*-*-rtems*)
++ tmake_file="${tmake_file} microblaze/t-microblaze t-fdpbit"
++ extra_parts="$extra_parts crtbeginS.o crtendS.o crtbeginT.o crti.o crtn.o"
++ ;;
++mips*-*-netbsd*) # NetBSD/mips, either endian.
++ ;;
++mips*-*-linux*) # Linux MIPS, either endian.
++ extra_parts="$extra_parts crtfastmath.o"
++ tmake_file="${tmake_file} t-crtfm"
++ case ${host} in
++ mips64r5900* | mipsr5900*)
++ # The MIPS16 support code uses floating point
++ # instructions that are not supported on r5900.
++ ;;
++ *)
++ tmake_file="${tmake_file} mips/t-mips16 t-slibgcc-libgcc"
++ ;;
++ esac
++ md_unwind_header=mips/linux-unwind.h
++ ;;
++mips*-sde-elf*)
++ tmake_file="$tmake_file mips/t-crtstuff mips/t-mips16"
++ case "${with_newlib}" in
++ yes)
++ # newlib / libgloss.
++ ;;
++ *)
++ # MIPS toolkit libraries.
++ tmake_file="$tmake_file mips/t-sdemtk"
++ ;;
++ esac
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++mipsisa32-*-elf* | mipsisa32el-*-elf* | \
++mipsisa32r2-*-elf* | mipsisa32r2el-*-elf* | \
++mipsisa32r6-*-elf* | mipsisa32r6el-*-elf* | \
++mipsisa64-*-elf* | mipsisa64el-*-elf* | \
++mipsisa64r2-*-elf* | mipsisa64r2el-*-elf* | \
++mipsisa64r6-*-elf* | mipsisa64r6el-*-elf*)
++ tmake_file="$tmake_file mips/t-elf mips/t-crtstuff mips/t-mips16"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++mipsisa64sr71k-*-elf*)
++ tmake_file="$tmake_file mips/t-elf mips/t-crtstuff t-fdpbit"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++mipsisa64sb1-*-elf* | mipsisa64sb1el-*-elf*)
++ tmake_file="$tmake_file mips/t-elf mips/t-crtstuff mips/t-mips16"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++mips-*-elf* | mipsel-*-elf*)
++ tmake_file="$tmake_file mips/t-elf mips/t-crtstuff mips/t-mips16"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++mipsr5900-*-elf* | mipsr5900el-*-elf*)
++ tmake_file="$tmake_file mips/t-elf mips/t-crtstuff"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++mips64-*-elf* | mips64el-*-elf*)
++ tmake_file="$tmake_file mips/t-elf mips/t-crtstuff mips/t-mips16"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++mips64r5900-*-elf* | mips64r5900el-*-elf*)
++ tmake_file="$tmake_file mips/t-elf mips/t-crtstuff"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++mips64vr-*-elf* | mips64vrel-*-elf*)
++ tmake_file="$tmake_file mips/t-elf mips/t-vr mips/t-crtstuff"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++mips64orion-*-elf* | mips64orionel-*-elf*)
++ tmake_file="$tmake_file mips/t-elf mips/t-crtstuff mips/t-mips16"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++mips*-*-rtems*)
++ tmake_file="$tmake_file mips/t-elf mips/t-crtstuff mips/t-mips16"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++mips-wrs-vxworks)
++ ;;
++mipstx39-*-elf* | mipstx39el-*-elf*)
++ tmake_file="$tmake_file mips/t-crtstuff mips/t-mips16"
++ ;;
++mmix-knuth-mmixware)
++ extra_parts="crti.o crtn.o crtbegin.o crtend.o"
++ tmake_file="${tmake_file} ${cpu_type}/t-${cpu_type}"
++ ;;
++mn10300-*-*)
++ tmake_file=t-fdpbit
++ ;;
++moxie-*-elf | moxie-*-moxiebox* | moxie-*-uclinux* | moxie-*-rtems*)
++ tmake_file="$tmake_file moxie/t-moxie t-softfp-sfdf t-softfp-excl t-softfp"
++ extra_parts="$extra_parts crti.o crtn.o crtbegin.o crtend.o"
++ ;;
++msp430-*-elf*)
++ tmake_file="$tm_file t-crtstuff t-fdpbit msp430/t-msp430"
++ extra_parts="crtbegin.o crtend.o crtbegin_no_eh.o crtend_no_eh.o"
++ extra_parts="$extra_parts libmul_none.a libmul_16.a libmul_32.a libmul_f5.a"
++ ;;
++nds32*-linux*)
++ # Basic makefile fragment and extra_parts for crt stuff.
++ # We also append c-isr library implementation.
++ tmake_file="${tmake_file} t-slibgcc-libgcc"
++ tmake_file="${tmake_file} nds32/t-nds32-glibc nds32/t-crtstuff t-softfp-sfdf t-softfp"
++ # The header file of defining MD_FALLBACK_FRAME_STATE_FOR.
++ md_unwind_header=nds32/linux-unwind.h
++ # Append library definition makefile fragment according to --with-nds32-lib=X setting.
++ case "${with_nds32_lib}" in
++ "" | glibc | uclibc )
++ ;;
++ *)
++ echo "Cannot accept --with-nds32-lib=$with_nds32_lib, available values are: glibc uclibc" 1>&2
++ exit 1
++ ;;
++ esac
++ ;;
++nds32*-elf*)
++ # Basic makefile fragment and extra_parts for crt stuff.
++ # We also append c-isr library implementation.
++ tmake_file="${tmake_file} nds32/t-nds32 nds32/t-nds32-isr"
++ extra_parts="crtbegin1.o crtend1.o libnds32_isr.a"
++ # Append library definition makefile fragment according to --with-nds32-lib=X setting.
++ case "${with_nds32_lib}" in
++ "" | newlib)
++ # Append library definition makefile fragment t-nds32-newlib.
++ # Append 'soft-fp' software floating point make rule fragment provided by gcc.
++ tmake_file="${tmake_file} nds32/t-nds32-newlib t-softfp-sfdf t-softfp"
++ ;;
++ mculib)
++ # Append library definition makefile fragment t-nds32-mculib.
++ # The software floating point library is included in mculib.
++ tmake_file="${tmake_file} nds32/t-nds32-mculib"
++ ;;
++ *)
++ echo "Cannot accept --with-nds32-lib=$with_nds32_lib, available values are: newlib mculib" 1>&2
++ exit 1
++ ;;
++ esac
++ ;;
++nios2-*-linux*)
++ tmake_file="$tmake_file nios2/t-nios2 nios2/t-linux t-libgcc-pic t-eh-dw2-dip t-slibgcc-libgcc"
++ tm_file="$tm_file nios2/elf-lib.h"
++ md_unwind_header=nios2/linux-unwind.h
++ ;;
++nios2-*-*)
++ tmake_file="$tmake_file nios2/t-nios2 t-softfp-sfdf t-softfp-excl t-softfp"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++or1k-*-linux*)
++ tmake_file="$tmake_file or1k/t-or1k"
++ tmake_file="$tmake_file t-softfp-sfdf t-softfp"
++ md_unwind_header=or1k/linux-unwind.h
++ ;;
++or1k-*-*)
++ tmake_file="$tmake_file or1k/t-or1k"
++ tmake_file="$tmake_file t-softfp-sfdf t-softfp"
++ ;;
++pdp11-*-*)
++ tmake_file="pdp11/t-pdp11 t-fdpbit"
++ ;;
++powerpc-*-darwin*)
++ case ${host} in
++ *-*-darwin9* | *-*-darwin[12][0-9]*)
++ # libSystem contains unwind information for signal frames since
++ # Darwin 9.
++ ;;
++ *)
++ md_unwind_header=rs6000/darwin-unwind.h
++ ;;
++ esac
++ tmake_file="$tmake_file rs6000/t-ppc64-fp rs6000/t-ibm-ldouble"
++ extra_parts="$extra_parts crt2.o crt3_2.o libef_ppc.a dw_ppc.o"
++ ;;
++powerpc64-*-darwin*)
++ tmake_file="$tmake_file rs6000/t-darwin64 rs6000/t-ibm-ldouble"
++ extra_parts="$extra_parts crt2.o crt3_2.o libef_ppc.a dw_ppc.o"
++ ;;
++powerpc*-*-freebsd*)
++ tmake_file="${tmake_file} rs6000/t-ppccomm rs6000/t-savresfgpr rs6000/t-crtstuff rs6000/t-freebsd t-softfp-sfdf t-softfp-excl t-softfp"
++ extra_parts="$extra_parts crtbeginT.o ecrti.o ecrtn.o ncrti.o ncrtn.o"
++ case ${host} in
++ powerpc64*)
++ tmake_file="${tmake_file} rs6000/t-freebsd64"
++ md_unwind_header=rs6000/freebsd-unwind.h
++ ;;
++ esac
++ ;;
++powerpc-*-netbsd*)
++ tmake_file="$tmake_file rs6000/t-netbsd rs6000/t-crtstuff"
++ ;;
++powerpc-*-eabispe*)
++ tmake_file="${tmake_file} rs6000/t-ppccomm rs6000/t-savresfgpr rs6000/t-crtstuff t-crtstuff-pic t-fdpbit"
++ extra_parts="$extra_parts crtbegin.o crtend.o crtbeginS.o crtendS.o crtbeginT.o ecrti.o ecrtn.o ncrti.o ncrtn.o"
++ ;;
++powerpc-*-eabisimaltivec*)
++ tmake_file="${tmake_file} rs6000/t-ppccomm rs6000/t-crtstuff t-crtstuff-pic t-fdpbit"
++ extra_parts="$extra_parts crtbegin.o crtend.o crtbeginS.o crtendS.o crtbeginT.o ecrti.o ecrtn.o ncrti.o ncrtn.o"
++ ;;
++powerpc-*-eabisim*)
++ tmake_file="${tmake_file} rs6000/t-ppccomm rs6000/t-crtstuff t-crtstuff-pic t-fdpbit"
++ extra_parts="$extra_parts crtbegin.o crtend.o crtbeginS.o crtendS.o crtbeginT.o ecrti.o ecrtn.o ncrti.o ncrtn.o"
++ ;;
++powerpc-*-elf*)
++ tmake_file="${tmake_file} rs6000/t-ppccomm rs6000/t-savresfgpr rs6000/t-crtstuff t-crtstuff-pic t-fdpbit"
++ extra_parts="$extra_parts crtbeginS.o crtendS.o crtbeginT.o ecrti.o ecrtn.o ncrti.o ncrtn.o"
++ ;;
++powerpc-*-eabialtivec*)
++ tmake_file="${tmake_file} rs6000/t-ppccomm rs6000/t-crtstuff t-crtstuff-pic t-fdpbit"
++ extra_parts="$extra_parts crtbegin.o crtend.o crtbeginS.o crtendS.o crtbeginT.o ecrti.o ecrtn.o ncrti.o ncrtn.o"
++ ;;
++powerpc-xilinx-eabi*)
++ tmake_file="${tmake_file} rs6000/t-ppccomm rs6000/t-crtstuff t-crtstuff-pic t-fdpbit"
++ extra_parts="$extra_parts crtbegin.o crtend.o crtbeginS.o crtendS.o crtbeginT.o ecrti.o ecrtn.o ncrti.o ncrtn.o"
++ ;;
++powerpc-*-eabi*)
++ tmake_file="${tmake_file} rs6000/t-ppccomm rs6000/t-savresfgpr rs6000/t-crtstuff t-crtstuff-pic t-fdpbit"
++ extra_parts="$extra_parts crtbegin.o crtend.o crtbeginS.o crtendS.o crtbeginT.o ecrti.o ecrtn.o ncrti.o ncrtn.o"
++ ;;
++powerpc-*-rtems*)
++ tmake_file="${tmake_file} rs6000/t-ppccomm rs6000/t-savresfgpr rs6000/t-crtstuff t-crtstuff-pic t-fdpbit"
++ extra_parts="$extra_parts crtbeginS.o crtendS.o crtbeginT.o ecrti.o ecrtn.o ncrti.o ncrtn.o"
++ ;;
++powerpc*-*-linux*)
++ tmake_file="${tmake_file} rs6000/t-ppccomm rs6000/t-savresfgpr rs6000/t-crtstuff rs6000/t-linux t-dfprules rs6000/t-ppc64-fp t-slibgcc-libgcc"
++ tmake_file="${tmake_file} t-stack rs6000/t-stack-rs6000"
++ case $ppc_fp_type in
++ 64)
++ ;;
++ hard)
++ tmake_file="${tmake_file} t-hardfp-sfdf t-hardfp"
++ ;;
++ soft)
++ tmake_file="${tmake_file} t-softfp-sfdf ${ppc_fp_compat} t-softfp"
++ ;;
++ e500v1)
++ tmake_file="${tmake_file} rs6000/t-e500v1-fp ${ppc_fp_compat} t-softfp t-hardfp"
++ ;;
++ e500v2)
++ tmake_file="${tmake_file} t-hardfp-sfdf rs6000/t-e500v2-fp ${ppc_fp_compat} t-softfp t-hardfp"
++ ;;
++ *)
++ echo "Unknown ppc_fp_type $ppc_fp_type" 1>&2
++ exit 1
++ ;;
++ esac
++
++ if test $libgcc_cv_powerpc_float128 = yes; then
++ tmake_file="${tmake_file} rs6000/t-float128"
++ fi
++
++ if test $libgcc_cv_powerpc_float128_hw = yes; then
++ tmake_file="${tmake_file} rs6000/t-float128-hw"
++ fi
++
++ extra_parts="$extra_parts ecrti.o ecrtn.o ncrti.o ncrtn.o"
++ md_unwind_header=rs6000/linux-unwind.h
++ ;;
++powerpc-wrs-vxworks*)
++ tmake_file="$tmake_file rs6000/t-ppccomm rs6000/t-savresfgpr t-fdpbit"
++ extra_parts="$extra_parts crtbegin.o crtend.o"
++ ;;
++powerpc-*-lynxos*)
++ tmake_file="$tmake_file rs6000/t-lynx t-fdpbit"
++ ;;
++powerpcle-*-elf*)
++ tmake_file="${tmake_file} rs6000/t-ppccomm rs6000/t-crtstuff t-crtstuff-pic t-fdpbit"
++ extra_parts="$extra_parts crtbeginS.o crtendS.o crtbeginT.o ecrti.o ecrtn.o ncrti.o ncrtn.o"
++ ;;
++powerpcle-*-eabisim*)
++ tmake_file="${tmake_file} rs6000/t-ppccomm rs6000/t-crtstuff t-crtstuff-pic t-fdpbit"
++ extra_parts="$extra_parts crtbegin.o crtend.o crtbeginS.o crtendS.o crtbeginT.o ecrti.o ecrtn.o ncrti.o ncrtn.o"
++ ;;
++powerpcle-*-eabi*)
++ tmake_file="${tmake_file} rs6000/t-ppccomm rs6000/t-crtstuff t-crtstuff-pic t-fdpbit"
++ extra_parts="$extra_parts crtbegin.o crtend.o crtbeginS.o crtendS.o crtbeginT.o ecrti.o ecrtn.o ncrti.o ncrtn.o"
++ ;;
++pru-*-*)
++ tmake_file="${tmake_file} t-softfp-sfdf t-softfp-excl t-softfp t-gnu-prefix pru/t-pru"
++ tm_file="$tm_file pru/pru-abi.h"
++ ;;
++riscv*-*-linux*)
++ tmake_file="${tmake_file} riscv/t-softfp${host_address} t-softfp riscv/t-elf riscv/t-elf${host_address} t-slibgcc-libgcc"
++ extra_parts="$extra_parts crtbegin.o crtend.o crti.o crtn.o crtendS.o crtbeginT.o"
++ md_unwind_header=riscv/linux-unwind.h
++ ;;
++riscv*-*-freebsd*)
++ tmake_file="${tmake_file} riscv/t-softfp${host_address} t-softfp riscv/t-elf riscv/t-elf${host_address} t-slibgcc-libgcc"
++ extra_parts="$extra_parts crtbegin.o crtend.o crti.o crtn.o crtendS.o crtbeginT.o"
++ ;;
++riscv*-*-*)
++ tmake_file="${tmake_file} riscv/t-softfp${host_address} t-softfp riscv/t-elf riscv/t-elf${host_address}"
++ extra_parts="$extra_parts crtbegin.o crtend.o crti.o crtn.o"
++ ;;
++rs6000-ibm-aix4.[3456789]* | powerpc-ibm-aix4.[3456789]*)
++ md_unwind_header=rs6000/aix-unwind.h
++ tmake_file="t-fdpbit rs6000/t-ppc64-fp rs6000/t-slibgcc-aix rs6000/t-ibm-ldouble"
++ ;;
++rs6000-ibm-aix5.1.* | powerpc-ibm-aix5.1.*)
++ md_unwind_header=rs6000/aix-unwind.h
++ tmake_file="t-fdpbit rs6000/t-ppc64-fp rs6000/t-slibgcc-aix rs6000/t-ibm-ldouble"
++ ;;
++rs6000-ibm-aix[56789].* | powerpc-ibm-aix[56789].*)
++ md_unwind_header=rs6000/aix-unwind.h
++ tmake_file="t-fdpbit rs6000/t-ppc64-fp rs6000/t-slibgcc-aix rs6000/t-ibm-ldouble rs6000/t-aix-cxa"
++ extra_parts="crtcxa.o crtcxa_s.o crtdbase.o"
++ ;;
++rl78-*-elf)
++ tmake_file="$tm_file t-fdpbit rl78/t-rl78"
++ ;;
++rx-*-elf)
++ tmake_file="rx/t-rx t-fdpbit"
++ tm_file="$tm_file rx/rx-abi.h rx/rx-lib.h"
++ ;;
++rx-*-linux*)
++ tmake_file="rx/t-rx t-fdpbit"
++ tm_file="$tm_file rx/rx-lib.h"
++ ;;
++s390-*-linux*)
++ tmake_file="${tmake_file} s390/t-crtstuff s390/t-linux s390/32/t-floattodi t-stack s390/t-stack-s390"
++ md_unwind_header=s390/linux-unwind.h
++ ;;
++s390x-*-linux*)
++ tmake_file="${tmake_file} s390/t-crtstuff s390/t-linux t-stack s390/t-stack-s390"
++ if test "${host_address}" = 32; then
++ tmake_file="${tmake_file} s390/32/t-floattodi"
++ fi
++ md_unwind_header=s390/linux-unwind.h
++ ;;
++s390x-ibm-tpf*)
++ tmake_file="${tmake_file} s390/t-crtstuff t-libgcc-pic t-eh-dw2-dip s390/t-tpf"
++ extra_parts="crtbeginS.o crtendS.o"
++ md_unwind_header=s390/tpf-unwind.h
++ ;;
++sh-*-elf* | sh[12346l]*-*-elf*)
++ tmake_file="$tmake_file sh/t-sh t-crtstuff-pic t-fdpbit"
++ extra_parts="$extra_parts crt1.o crti.o crtn.o crtbeginS.o crtendS.o \
++ libic_invalidate_array_4-100.a \
++ libic_invalidate_array_4-200.a \
++ libic_invalidate_array_4a.a \
++ libgcc-Os-4-200.a libgcc-4-300.a"
++ case ${host} in
++ sh*-superh-elf)
++ tmake_file="$tmake_file sh/t-superh"
++ extra_parts="$extra_parts crt1-mmu.o gcrt1-mmu.o gcrt1.o"
++ ;;
++ esac
++ ;;
++sh-*-linux* | sh[2346lbe]*-*-linux*)
++ tmake_file="${tmake_file} sh/t-sh t-slibgcc-libgcc sh/t-linux t-fdpbit"
++ md_unwind_header=sh/linux-unwind.h
++ ;;
++sh-*-netbsdelf* | shl*-*-netbsdelf*)
++ tmake_file="$tmake_file sh/t-sh sh/t-netbsd"
++
++ # NetBSD's C library includes a fast software FP library that
++ # has support for setting/setting the rounding mode, exception
++ # mask, etc. Therefore, we don't want to include software FP
++ # in libgcc.
++ ;;
++sh-*-rtems*)
++ tmake_file="$tmake_file sh/t-sh t-crtstuff-pic t-fdpbit"
++ extra_parts="$extra_parts crt1.o crti.o crtn.o crtbeginS.o crtendS.o \
++ libic_invalidate_array_4-100.a \
++ libic_invalidate_array_4-200.a \
++ libic_invalidate_array_4a.a \
++ libgcc-Os-4-200.a libgcc-4-300.a"
++ ;;
++sh-wrs-vxworks)
++ tmake_file="$tmake_file sh/t-sh t-crtstuff-pic t-fdpbit"
++ ;;
++sparc-*-netbsdelf*)
++ ;;
++sparc64-*-openbsd*)
++ ;;
++sparc-*-elf*)
++ case ${host} in
++ *-leon[3-9]*)
++ ;;
++ *)
++ tmake_file="sparc/t-softmul"
++ ;;
++ esac
++ tmake_file="${tmake_file} t-fdpbit t-crtfm"
++ extra_parts="$extra_parts crti.o crtn.o crtfastmath.o"
++ ;;
++sparc-*-linux*) # SPARC's running GNU/Linux, libc6
++ tmake_file="${tmake_file} t-crtfm"
++ if test "${host_address}" = 64; then
++ tmake_file="$tmake_file sparc/t-linux64"
++ fi
++ case ${host} in
++ *-leon*)
++ tmake_file="${tmake_file} t-fdpbit"
++ ;;
++ *)
++ tmake_file="${tmake_file} sparc/t-linux"
++ ;;
++ esac
++ case ${host} in
++ *-leon[3-9]*)
++ ;;
++ *)
++ if test "${host_address}" = 32; then
++ tmake_file="$tmake_file sparc/t-softmul"
++ fi
++ ;;
++ esac
++ extra_parts="$extra_parts crtfastmath.o"
++ md_unwind_header=sparc/linux-unwind.h
++ ;;
++sparc-*-rtems*)
++ tmake_file="$tmake_file sparc/t-elf sparc/t-softmul t-crtfm t-fdpbit"
++ extra_parts="$extra_parts crti.o crtn.o crtfastmath.o"
++ ;;
++sparc*-*-solaris2*)
++ tmake_file="$tmake_file t-crtfm"
++ extra_parts="$extra_parts crtfastmath.o"
++ md_unwind_header=sparc/sol2-unwind.h
++ ;;
++sparc64-*-elf*)
++ tmake_file="${tmake_file} t-crtfm"
++ extra_parts="$extra_parts crti.o crtn.o crtfastmath.o"
++ ;;
++sparc64-*-rtems*)
++ tmake_file="$tmake_file t-crtfm"
++ extra_parts="$extra_parts crti.o crtn.o crtfastmath.o"
++ ;;
++sparc-wrs-vxworks)
++ ;;
++sparc64-*-freebsd*|ultrasparc-*-freebsd*)
++ tmake_file="$tmake_file t-crtfm"
++ extra_parts="$extra_parts crtfastmath.o"
++ ;;
++sparc64-*-linux*) # 64-bit SPARC's running GNU/Linux
++ extra_parts="$extra_parts crtfastmath.o"
++ tmake_file="${tmake_file} t-crtfm sparc/t-linux"
++ if test "${host_address}" = 64; then
++ tmake_file="${tmake_file} sparc/t-linux64"
++ fi
++ if test "${host_address}" = 32; then
++ tmake_file="${tmake_file} sparc/t-softmul"
++ fi
++ md_unwind_header=sparc/linux-unwind.h
++ ;;
++sparc64-*-netbsd*)
++ ;;
++tic6x-*-uclinux)
++ tmake_file="${tmake_file} t-softfp-sfdf t-softfp-excl t-softfp \
++ c6x/t-elf c6x/t-uclinux t-crtstuff-pic t-libgcc-pic \
++ t-slibgcc t-slibgcc-gld t-slibgcc-elf-ver t-gnu-prefix"
++ tm_file="$tm_file c6x/c6x-abi.h"
++ extra_parts="$extra_parts crtbeginS.o crtendS.o crti.o crtn.o"
++ unwind_header=config/c6x/unwind-c6x.h
++ ;;
++tic6x-*-elf)
++ tmake_file="${tmake_file} t-softfp-sfdf t-softfp-excl t-softfp t-gnu-prefix c6x/t-elf"
++ tm_file="$tm_file c6x/c6x-abi.h"
++ extra_parts="$extra_parts crtbeginS.o crtendS.o crti.o crtn.o"
++ unwind_header=config/c6x/unwind-c6x.h
++ ;;
++tilegx*-*-linux*)
++ if test "${host_address}" = 64; then
++ tmake_file="${tmake_file} tilegx/t-softfp"
++ fi
++ tmake_file="${tmake_file} tilegx/t-crtstuff t-softfp-sfdf t-softfp tilegx/t-tilegx"
++ md_unwind_header=tilepro/linux-unwind.h
++ ;;
++tilepro*-*-linux*)
++ tmake_file="${tmake_file} tilepro/t-crtstuff t-softfp-sfdf t-softfp tilepro/t-tilepro t-slibgcc-libgcc"
++ md_unwind_header=tilepro/linux-unwind.h
++ ;;
++v850*-*-*)
++ tmake_file="${tmake_file} v850/t-v850 t-fdpbit"
++ ;;
++vax-*-linux*)
++ tmake_file="$tmake_file vax/t-linux"
++ ;;
++vax-*-netbsdelf*)
++ ;;
++vax-*-openbsd*)
++ ;;
++visium-*-elf*)
++ extra_parts="$extra_parts crtbegin.o crtend.o crti.o crtn.o"
++ tmake_file="visium/t-visium t-fdpbit"
++ ;;
++xstormy16-*-elf)
++ tmake_file="stormy16/t-stormy16 t-fdpbit"
++ ;;
++xtensa*-*-elf*)
++ tmake_file="$tmake_file xtensa/t-xtensa xtensa/t-elf"
++ extra_parts="$extra_parts crti.o crtn.o"
++ ;;
++xtensa*-*-linux*)
++ tmake_file="$tmake_file xtensa/t-xtensa xtensa/t-linux t-slibgcc-libgcc"
++ md_unwind_header=xtensa/linux-unwind.h
++ ;;
++xtensa*-*-uclinux*)
++ tmake_file="$tmake_file xtensa/t-xtensa xtensa/t-linux t-slibgcc-libgcc"
++ md_unwind_header=xtensa/linux-unwind.h
++ extra_parts="$extra_parts crtbeginS.o crtbeginT.o crtendS.o"
++ ;;
++am33_2.0-*-linux*)
++ # Don't need crtbeginT.o from *-*-linux* default.
++ extra_parts="crtbegin.o crtend.o crtbeginS.o crtendS.o"
++ tmake_file="$tmake_file t-fdpbit"
++ ;;
++m32c-*-elf*|m32c-*-rtems*)
++ tmake_file="$tmake_file m32c/t-m32c"
++ ;;
++nvptx-*)
++ tmake_file="$tmake_file nvptx/t-nvptx"
++ extra_parts="crt0.o"
++ ;;
++*)
++ echo "*** Configuration ${host} not supported" 1>&2
++ exit 1
++ ;;
++esac
++
++case ${host} in
++i[34567]86-*-* | x86_64-*-*)
++ case ${host} in
++ *-musl*)
++ tmake_file="${tmake_file} i386/t-cpuinfo-static"
++ ;;
++ *)
++ tmake_file="${tmake_file} i386/t-cpuinfo"
++ ;;
++ esac
++ ;;
++esac
++
++case ${host} in
++i[34567]86-*-linux* | x86_64-*-linux* | \
++ i[34567]86-*-kfreebsd*-gnu | x86_64-*-kfreebsd*-gnu | \
++ i[34567]86-*-gnu*)
++ tmake_file="${tmake_file} t-tls i386/t-linux i386/t-msabi t-slibgcc-libgcc"
++ if test "$libgcc_cv_cfi" = "yes"; then
++ tmake_file="${tmake_file} t-stack i386/t-stack-i386"
++ fi
++ ;;
++esac
++
++case ${host} in
++i[34567]86-*-elfiamcu | i[34567]86-*-rtems*)
++ # These use soft-fp for SFmode and DFmode, not just TFmode.
++ ;;
++i[34567]86-*-* | x86_64-*-*)
++ tmake_file="${tmake_file} t-softfp-tf"
++ if test "${host_address}" = 32; then
++ tmake_file="${tmake_file} i386/${host_address}/t-softfp"
++ fi
++ tmake_file="${tmake_file} i386/t-softfp t-softfp"
++ ;;
++esac
++
++case ${host} in
++i[34567]86-*-linux* | x86_64-*-linux*)
++ # Provide backward binary compatibility for 64bit Linux/x86.
++ if test "${host_address}" = 64; then
++ tmake_file="${tmake_file} i386/${host_address}/t-softfp-compat"
++ fi
++ tm_file="${tm_file} i386/value-unwind.h"
++ ;;
++aarch64*-*-*)
++ # ILP32 needs an extra header for unwinding
++ tm_file="${tm_file} aarch64/value-unwind.h"
++ ;;
++esac
++
++# The vxworks threads implementation relies on a few extra sources,
++# which we arrange to add after everything else:
++
++case ${target_thread_file} in
++vxworks)
++ case ${host} in
++ *-*-vxworksae)
++ tmake_file="${tmake_file} t-gthr-vxworksae"
++ ;;
++ *-*-vxworks*)
++ tmake_file="${tmake_file} t-gthr-vxworks"
++ ;;
++ esac
++esac
++
++case ${host} in
++*-*-musl*)
++ # The gthr weak references are unsafe with static linking
++ tmake_file="$tmake_file t-gthr-noweak"
++ ;;
++esac
+diff -ruN a/libstdc++-v3/configure b/libstdc++-v3/configure
+--- a/libstdc++-v3/configure 2020-07-23 09:35:19.188404867 +0300
++++ b/libstdc++-v3/configure 2020-12-12 10:43:35.288270409 +0200
+@@ -29846,6 +29846,5986 @@
# Base decisions on target environment.
case "${host}" in
@@ -6190,11 +7776,10 @@ index 9f9c5a241..9055fe09e 100755
arm*-*-symbianelf*)
# This is a freestanding configuration; there is nothing to do here.
;;
-diff --git a/libstdc++-v3/crossconfig.m4 b/libstdc++-v3/crossconfig.m4
-index fe1828835..2775c3646 100644
---- a/libstdc++-v3/crossconfig.m4
-+++ b/libstdc++-v3/crossconfig.m4
-@@ -5,6 +5,13 @@ dnl
+diff -ruN a/libstdc++-v3/crossconfig.m4 b/libstdc++-v3/crossconfig.m4
+--- a/libstdc++-v3/crossconfig.m4 2020-07-23 09:35:19.188404867 +0300
++++ b/libstdc++-v3/crossconfig.m4 2020-12-12 10:43:35.288270409 +0200
+@@ -5,6 +5,13 @@
AC_DEFUN([GLIBCXX_CROSSCONFIG],[
# Base decisions on target environment.
case "${host}" in
@@ -6208,23 +7793,3 @@ index fe1828835..2775c3646 100644
arm*-*-symbianelf*)
# This is a freestanding configuration; there is nothing to do here.
;;
-diff -ru a/libgcc/config/t-slibgcc b/libgcc/config/t-slibgcc
---- a/libgcc/config/t-slibgcc 2020-07-23 09:35:18.796400548 +0300
-+++ b/libgcc/config/t-slibgcc 2020-10-17 14:29:19.936792298 +0300
-@@ -26,7 +26,6 @@
- SHLIB_OBJS = @shlib_objs@
- SHLIB_DIR = @multilib_dir@
- SHLIB_SLIBDIR_QUAL = @shlib_slibdir_qual@
--SHLIB_LC = -lc
- SHLIB_MAKE_SOLINK = $(LN_S) $(SHLIB_SONAME) $(SHLIB_DIR)/$(SHLIB_SOLINK)
- SHLIB_INSTALL_SOLINK = $(LN_S) $(SHLIB_SONAME) \
- $(DESTDIR)$(slibdir)$(SHLIB_SLIBDIR_QUAL)/$(SHLIB_SOLINK)
-@@ -34,7 +33,7 @@
- SHLIB_LINK = $(CC) $(LIBGCC2_CFLAGS) -shared -nodefaultlibs \
- $(SHLIB_LDFLAGS) \
- -o $(SHLIB_DIR)/$(SHLIB_SONAME).tmp @multilib_flags@ \
-- $(SHLIB_OBJS) $(SHLIB_LC) && \
-+ $(SHLIB_OBJS) && \
- rm -f $(SHLIB_DIR)/$(SHLIB_SOLINK) && \
- if [ -f $(SHLIB_DIR)/$(SHLIB_SONAME) ]; then \
- mv -f $(SHLIB_DIR)/$(SHLIB_SONAME) \