patches/gcc/4.2.4/270-soft-float.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Sat Jan 31 17:49:27 2009 +0000 (2009-01-31)
changeset 1183 268544004e77
parent 687 b2b6b1d46aa1
permissions -rw-r--r--
On 20090131.1659+0100, Vincent Sanders <vince@kyllikki.org> wrote:
[This]patch is a bit more involved. The patch addresses a gcc
regression in the 4.3 series (specifically this patch is against 4.3.2
which does *not* have a lot of other issues which affect kernel building)

GCC bug tracker has this issue as
#38453 http://gcc.gnu.org/bugzilla/show_bug.cgi?id=38453
#32044 http://gcc.gnu.org/bugzilla/show_bug.cgi?id=32044

comment 65 of #32044 has the fix being applied to gcc trunk as revision #142719

The attached patch is a backport to gcc 4.3.2 which allows this
version to be used to generate correct output for various ARM kernel
build (and indeed is teh correct answer in general).

/trunk/patches/gcc/4.3.2/360-fix-expensive-optimize.patch | 207 207 0 0 +++++++++++++++++++++
1 file changed, 207 insertions(+)
yann@687
     1
diff -uNpr gcc-4.2.1_orig/gcc/config/rs6000/darwin-ldouble.c gcc-4.2.1/gcc/config/rs6000/darwin-ldouble.c
yann@687
     2
--- gcc-4.2.1_orig/gcc/config/rs6000/darwin-ldouble.c	2007-03-05 11:54:00.000000000 -0500
yann@687
     3
+++ gcc-4.2.1/gcc/config/rs6000/darwin-ldouble.c	2008-01-31 17:51:24.000000000 -0500
yann@687
     4
@@ -70,6 +70,8 @@ Software Foundation, 51 Franklin Street,
yann@687
     5
    but GCC currently generates poor code when a union is used to turn
yann@687
     6
    a long double into a pair of doubles.  */
yann@687
     7
 
yann@687
     8
+#if defined (_SOFT_FLOAT) && defined (__LONG_DOUBLE_128__)
yann@687
     9
+
yann@687
    10
 long double __gcc_qadd (double, double, double, double);
yann@687
    11
 long double __gcc_qsub (double, double, double, double);
yann@687
    12
 long double __gcc_qmul (double, double, double, double);
yann@687
    13
@@ -219,8 +221,6 @@ __gcc_qdiv (double a, double b, double c
yann@687
    14
   return z.ldval;
yann@687
    15
 }
yann@687
    16
 
yann@687
    17
-#if defined (_SOFT_FLOAT) && defined (__LONG_DOUBLE_128__)
yann@687
    18
-
yann@687
    19
 long double __gcc_qneg (double, double);
yann@687
    20
 int __gcc_qeq (double, double, double, double);
yann@687
    21
 int __gcc_qne (double, double, double, double);