patches/gcc/4.3.6/330-unwind-for-uClibc.patch
author Michael Hope <michael.hope@linaro.org>
Wed Oct 19 15:27:32 2011 +1300 (2011-10-19)
changeset 2739 f320e22f2cba
parent 2124 5dd0b83ae528
permissions -rw-r--r--
arch: add softfp support

Some architectures support a mixed hard/soft floating point, where
the compiler emits hardware floating point instructions, but passes
the operands in core (aka integer) registers.

For example, ARM supports this mode (to come in the next changeset).

Add support for softfp cross compilers to the GCC and GLIBC
configuration. Needed for Ubuntu and other distros that are softfp.

Signed-off-by: Michael Hope <michael.hope@linaro.org>
[yann.morin.1998@anciens.enib.fr: split the original patch]
Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
thomas@1461
     1
Original patch from: ../4.3.2/330-unwind-for-uClibc.patch
thomas@1461
     2
thomas@1461
     3
-= BEGIN original header =-
thomas@1461
     4
-= END original header =-
thomas@1461
     5
thomas@1461
     6
diff -durN gcc-4.3.3.orig/gcc/config/t-linux-uclibc gcc-4.3.3/gcc/config/t-linux-uclibc
thomas@1461
     7
--- gcc-4.3.3.orig/gcc/config/t-linux-uclibc	1970-01-01 01:00:00.000000000 +0100
thomas@1461
     8
+++ gcc-4.3.3/gcc/config/t-linux-uclibc	2009-01-27 22:28:53.000000000 +0100
thomas@1461
     9
@@ -0,0 +1,5 @@
thomas@1461
    10
+# Remove glibc specific files added in t-linux
thomas@1461
    11
+SHLIB_MAPFILES := $(filter-out $(srcdir)/config/libgcc-glibc.ver, $(SHLIB_MAPFILES))
thomas@1461
    12
+
thomas@1461
    13
+# Use unwind-dw2-fde instead of unwind-dw2-fde-glibc
thomas@1461
    14
+LIB2ADDEH := $(subst unwind-dw2-fde-glibc.c,unwind-dw2-fde.c,$(LIB2ADDEH))
thomas@1461
    15
diff -durN gcc-4.3.3.orig/gcc/config.gcc gcc-4.3.3/gcc/config.gcc
thomas@1461
    16
--- gcc-4.3.3.orig/gcc/config.gcc	2009-01-27 22:25:37.000000000 +0100
thomas@1461
    17
+++ gcc-4.3.3/gcc/config.gcc	2009-01-27 22:28:53.000000000 +0100
thomas@1461
    18
@@ -2648,6 +2648,12 @@
thomas@1461
    19
 	;;
thomas@1461
    20
 esac
thomas@1461
    21
 
thomas@1461
    22
+# Rather than hook into each target, just do it after all the linux
thomas@1461
    23
+# targets have been processed
thomas@1461
    24
+case ${target} in
thomas@1461
    25
+  *-linux-uclibc*) tm_defines="${tm_defines} USE_UCLIBC" ; tmake_file="${tmake_file} t-linux-uclibc";;
thomas@1461
    26
+esac
thomas@1461
    27
+
thomas@1461
    28
 case ${target} in
thomas@1461
    29
 i[34567]86-*-linux*aout* | i[34567]86-*-linux*libc1)
thomas@1461
    30
 	tmake_file="${tmake_file} i386/t-gmm_malloc"