patches/gcc/4.4.1/170-sparc64-bsd.patch
author Michael Hope <michael.hope@linaro.org>
Wed Oct 19 15:27:32 2011 +1300 (2011-10-19)
changeset 2739 f320e22f2cba
parent 1393 b432bd628b10
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>
     1 diff -durN gcc-4.4.0.orig/gcc/config/sparc/freebsd.h gcc-4.4.0/gcc/config/sparc/freebsd.h
     2 --- gcc-4.4.0.orig/gcc/config/sparc/freebsd.h	2007-08-02 12:49:31.000000000 +0200
     3 +++ gcc-4.4.0/gcc/config/sparc/freebsd.h	2009-05-27 21:38:16.000000000 +0200
     4 @@ -25,9 +25,22 @@
     5  /* FreeBSD needs the platform name (sparc64) defined.
     6     Emacs needs to know if the arch is 64 or 32-bits.  */
     7  
     8 -#undef  CPP_CPU64_DEFAULT_SPEC
     9 -#define CPP_CPU64_DEFAULT_SPEC \
    10 -  "-D__sparc64__ -D__sparc_v9__ -D__sparcv9 -D__arch64__"
    11 +#undef  FBSD_TARGET_CPU_CPP_BUILTINS
    12 +#define FBSD_TARGET_CPU_CPP_BUILTINS()                  \
    13 +  do                                                    \
    14 +    {                                                   \
    15 +      if (TARGET_ARCH64)                                \
    16 +        {                                               \
    17 +          builtin_define ("__sparc64__");               \
    18 +          builtin_define ("__sparc_v9__");              \
    19 +          builtin_define ("__sparcv9");                 \
    20 +        }                                               \
    21 +      else                                              \
    22 +        builtin_define ("__sparc");                     \
    23 +      builtin_define ("__sparc__");                     \
    24 +    }                                                   \
    25 +  while (0)
    26 +
    27  
    28  #define LINK_SPEC "%(link_arch)						\
    29    %{!mno-relax:%{!r:-relax}}						\