patches/glibc/2.7/170-use_short_for_fnstsw.patch
author Cody Schafer <dev@codyps.com>
Fri May 09 19:13:49 2014 -0700 (2014-05-09)
changeset 3312 4876ff97e039
parent 612 fc9588d57c0f
permissions -rw-r--r--
cc/gcc: allow CC_EXTRA_CONFIG_ARRAY on baremetal

The final bare-metal compiler is built using the core backend.
Currently the core uses the CC_CORE_EXTRA_CONFIG_ARRAY variable.

While this works as supposed to, this can leave the user puzzled
in the menuconfig, since all he can see is the core options, not
the final options.

Only show the core options if any of the core passes are needed,
and use the final options in the core-backend if we're issuing
the bare-metal compiler.

Signed-off-by: Cody P Schafer <dev@codyps.com>
[yann.morin.1998@free.fr: hide core options if no core pass needed;
use final option in core backend if issuing the bare-metal compiler]
Signed-off-by: "Yann E. MORIN" <yann.morin.1998@free.fr>
Message-Id: <22181e546ba746202489.1399688067@localhost>
Patchwork-Id: 347586
yann@607
     1
Original patch from H.J. Lu, as reported there:
yann@607
     2
http://www.nabble.com/PATCH:-Use-short-for-fnstsw-td14775171.html
yann@607
     3
yann@607
     4
fnstsw stores 16bit into %ax. The upper 16bit of %eax is unchanged.
yann@607
     5
The new assembler (binutils-2.18.50.0.4 and up) will disallow "fnstsw %eax".
yann@607
     6
yann@607
     7
diff -dur glibc-2.7.orig/sysdeps/i386/fpu/ftestexcept.c glibc-2.7/sysdeps/i386/fpu/ftestexcept.c
yann@607
     8
--- glibc-2.7.orig/sysdeps/i386/fpu/ftestexcept.c	2004-03-05 11:14:48.000000000 +0100
yann@607
     9
+++ glibc-2.7/sysdeps/i386/fpu/ftestexcept.c	2008-06-24 10:54:43.000000000 +0200
yann@607
    10
@@ -26,7 +26,7 @@
yann@607
    11
 int
yann@607
    12
 fetestexcept (int excepts)
yann@607
    13
 {
yann@607
    14
-  int temp;
yann@607
    15
+  short temp;
yann@607
    16
   int xtemp = 0;
yann@607
    17
 
yann@607
    18
   /* Get current exceptions.  */