patches/gcc/4.1.1/190-arm-bigendian.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 1 eeea35fbf182
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(+)
     1 By Lennert Buytenhek <buytenh@wantstofly.org>
     2 Adds support for arm*b-linux* big-endian ARM targets
     3 
     4 See http://gcc.gnu.org/PR16350
     5 
     6 --- gcc-4.1.0/gcc/config/arm/linux-elf.h
     7 +++ gcc-4.1.0/gcc/config/arm/linux-elf.h
     8 @@ -28,19 +28,33 @@
     9  #undef  TARGET_VERSION
    10  #define TARGET_VERSION  fputs (" (ARM GNU/Linux with ELF)", stderr);
    11  
    12 +/*
    13 + * 'config.gcc' defines TARGET_BIG_ENDIAN_DEFAULT as 1 for arm*b-*
    14 + * (big endian) configurations.
    15 + */
    16 +#if TARGET_BIG_ENDIAN_DEFAULT
    17 +#define TARGET_ENDIAN_DEFAULT MASK_BIG_END
    18 +#define TARGET_ENDIAN_OPTION "mbig-endian"
    19 +#define TARGET_LINKER_EMULATION "armelfb_linux"
    20 +#else
    21 +#define TARGET_ENDIAN_DEFAULT 0
    22 +#define TARGET_ENDIAN_OPTION "mlittle-endian"
    23 +#define TARGET_LINKER_EMULATION "armelf_linux"
    24 +#endif
    25 +
    26  #undef  TARGET_DEFAULT_FLOAT_ABI
    27  #define TARGET_DEFAULT_FLOAT_ABI ARM_FLOAT_ABI_HARD
    28  
    29  #undef  TARGET_DEFAULT
    30 -#define TARGET_DEFAULT (0)
    31 +#define TARGET_DEFAULT (TARGET_ENDIAN_DEFAULT)
    32  
    33  #define SUBTARGET_CPU_DEFAULT TARGET_CPU_arm6
    34  
    35 -#define SUBTARGET_EXTRA_LINK_SPEC " -m armelf_linux -p"
    36 +#define SUBTARGET_EXTRA_LINK_SPEC " -m " TARGET_LINKER_EMULATION " -p"
    37  
    38  #undef  MULTILIB_DEFAULTS
    39  #define MULTILIB_DEFAULTS \
    40 -	{ "marm", "mlittle-endian", "mhard-float", "mno-thumb-interwork" }
    41 +	{ "marm", TARGET_ENDIAN_OPTION, "mhard-float", "mno-thumb-interwork" }
    42  
    43  /* Now we define the strings used to build the spec file.  */
    44  #undef  LIB_SPEC
    45 @@ -61,7 +75,7 @@
    46     %{rdynamic:-export-dynamic} \
    47     %{!dynamic-linker:-dynamic-linker " LINUX_TARGET_INTERPRETER "} \
    48     -X \
    49 -   %{mbig-endian:-EB}" \
    50 +   %{mbig-endian:-EB} %{mlittle-endian:-EL}" \
    51     SUBTARGET_EXTRA_LINK_SPEC
    52  
    53  #undef  LINK_SPEC
    54 --- gcc-4.1.0/gcc/config.gcc
    55 +++ gcc-4.1.0/gcc/config.gcc
    56 @@ -672,6 +672,11 @@
    57  	;;
    58  arm*-*-linux*)			# ARM GNU/Linux with ELF
    59  	tm_file="dbxelf.h elfos.h linux.h arm/elf.h arm/linux-gas.h arm/linux-elf.h" 
    60 +	case $target in
    61 +	arm*b-*)
    62 +		tm_defines="${tm_defines} TARGET_BIG_ENDIAN_DEFAULT=1"
    63 +		;;
    64 +	esac
    65  	tmake_file="${tmake_file} t-linux arm/t-arm"
    66  	case ${target} in
    67  	arm*-*-linux-gnueabi)