patches/gcc/3.4.6/210-all_sh-pr20617.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Tue Oct 14 17:42:10 2008 +0000 (2008-10-14)
changeset 929 7c958fb04f28
parent 402 197e1b49586e
permissions -rw-r--r--
Sample config for e500v2 toolchain

On Tuesday 14 October 2008 17:05:31 Nate Case wrote:
> This is a sample config file for Freescale e500v2 processors (e.g.,
> MPC8548, MPC8572). It uses eglibc (for e500/SPE patches) and a recent
> gcc (4.3.1, for e500v2 DPFP support) and will generate appropriate
> dual-precision floating point instructions by default.
>
> Note: If building a Linux kernel with this toolchain, you will want to
> make sure -mno-spe AND -mspe=no are passed to gcc to prevent SPE
> ABI/instructions from getting into the kernel (which is currently
> unsupported). At this time, the kernel build system only passes
> -mno-spe by default (this should be fixed soon hopefully).
>
> A binutils snapshot is used to fix a bug present in 2.18 preventing
> U-Boot from being compiled (CodeSourcery issue #2297: internal.h
> (ELF_IS_SECTION_IN_SEGMENT): Adjust to cope with segments at the end of
> memory).

Obsoletes the powerpc-unknown-linux-gnuspe sample, so remove it.

/trunk/samples/powerpc-e500v2-linux-gnuspe/crosstool.config | 307 307 0 0 +++++++++++++++++++
1 file changed, 307 insertions(+)
yann@402
     1
diff -durN gcc-3.4.6.orig/gcc/config/sh/lib1funcs.asm gcc-3.4.6/gcc/config/sh/lib1funcs.asm
yann@402
     2
--- gcc-3.4.6.orig/gcc/config/sh/lib1funcs.asm	2003-08-12 03:25:07.000000000 +0200
yann@402
     3
+++ gcc-3.4.6/gcc/config/sh/lib1funcs.asm	2007-08-15 23:04:26.000000000 +0200
yann@402
     4
@@ -37,9 +37,19 @@
yann@402
     5
    ELF local label prefixes by J"orn Rennecke
yann@402
     6
    amylaar@cygnus.com  */
yann@402
     7
 
yann@402
     8
+#define ALIAS(X,Y)	.global GLOBAL(X); .set GLOBAL(X),GLOBAL(Y)
yann@402
     9
+
yann@402
    10
 #ifdef __ELF__
yann@402
    11
 #define LOCAL(X)	.L_##X
yann@402
    12
-#define FUNC(X)		.type X,@function
yann@402
    13
+
yann@402
    14
+#if 1 /* ??? The export list mechanism is broken, everything that is not
yann@402
    15
+	 hidden is exported.  */
yann@402
    16
+#undef FUNC
yann@402
    17
+#define FUNC(X)		.type X,@function; .hidden X
yann@402
    18
+#undef ALIAS
yann@402
    19
+#define ALIAS(X,Y)	.global GLOBAL(X); .set GLOBAL(X),GLOBAL(Y); .hidden GLOBAL(X)
yann@402
    20
+#endif
yann@402
    21
+
yann@402
    22
 #define ENDFUNC0(X)	.Lfe_##X: .size X,.Lfe_##X-X
yann@402
    23
 #define ENDFUNC(X)	ENDFUNC0(X)
yann@402
    24
 #else