diff options
author | Ralf Corsepius <ralf.corsepius@rtems.org> | 2010-03-26 09:29:10 +0000 |
---|---|---|
committer | Ralf Corsepius <ralf.corsepius@rtems.org> | 2010-03-26 09:29:10 +0000 |
commit | 59ecea598ff4e94f0c1f43fcf89d3a44d8c33006 (patch) | |
tree | 0a21fe7f211a354ad6932ea34484dfc880a73693 /contrib | |
parent | Regenerate. (diff) | |
download | rtems-59ecea598ff4e94f0c1f43fcf89d3a44d8c33006.tar.bz2 |
Rebase patch against gcc-4.5-20100325.
Diffstat (limited to 'contrib')
-rw-r--r-- | contrib/crossrpms/patches/gcc-core-4.5-20100325-rtems4.11-20100326.diff | 340 |
1 files changed, 340 insertions, 0 deletions
diff --git a/contrib/crossrpms/patches/gcc-core-4.5-20100325-rtems4.11-20100326.diff b/contrib/crossrpms/patches/gcc-core-4.5-20100325-rtems4.11-20100326.diff new file mode 100644 index 0000000000..019c568182 --- /dev/null +++ b/contrib/crossrpms/patches/gcc-core-4.5-20100325-rtems4.11-20100326.diff @@ -0,0 +1,340 @@ +diff -Naur gcc-4.5-20100325.orig/ChangeLog.rtems gcc-4.5-20100325/ChangeLog.rtems +--- gcc-4.5-20100325.orig/ChangeLog.rtems 1970-01-01 01:00:00.000000000 +0100 ++++ gcc-4.5-20100325/ChangeLog.rtems 2010-03-26 05:33:40.000000000 +0100 +@@ -0,0 +1,4 @@ ++ Ralf Corsépius <ralf.corsepius@rtems.org> ++ ++ * configure, configure.ac (skipdirs): Add target-libiberty. ++ +diff -Naur gcc-4.5-20100325.orig/configure gcc-4.5-20100325/configure +--- gcc-4.5-20100325.orig/configure 2010-03-23 17:04:30.000000000 +0100 ++++ gcc-4.5-20100325/configure 2010-03-26 05:33:40.000000000 +0100 +@@ -3291,6 +3291,7 @@ + noconfigdirs="$noconfigdirs target-newlib target-libiberty target-libgloss ${libgcj} target-libmudflap" + ;; + *-*-rtems*) ++ skipdirs="$skipdirs target-libiberty" + noconfigdirs="$noconfigdirs target-libgloss ${libgcj}" + ;; + # The tpf target doesn't support gdb yet. +@@ -7892,7 +7893,7 @@ + # to it. This is right: we don't want to search that directory + # for binaries, but we want the header files in there, so add + # them explicitly. +- FLAGS_FOR_TARGET=$FLAGS_FOR_TARGET' -isystem $$r/$(HOST_SUBDIR)/gcc/include' ++ FLAGS_FOR_TARGET=$FLAGS_FOR_TARGET' -isystem $$r/$(HOST_SUBDIR)/gcc/include -isystem $$r/$(HOST_SUBDIR)/gcc/include-fixed' + + # Someone might think of using the pre-installed headers on + # Canadian crosses, in case the installed compiler is not fully +diff -Naur gcc-4.5-20100325.orig/configure.ac gcc-4.5-20100325/configure.ac +--- gcc-4.5-20100325.orig/configure.ac 2010-03-23 17:04:30.000000000 +0100 ++++ gcc-4.5-20100325/configure.ac 2010-03-26 05:33:40.000000000 +0100 +@@ -528,6 +528,7 @@ + noconfigdirs="$noconfigdirs target-newlib target-libiberty target-libgloss ${libgcj} target-libmudflap" + ;; + *-*-rtems*) ++ skipdirs="$skipdirs target-libiberty" + noconfigdirs="$noconfigdirs target-libgloss ${libgcj}" + ;; + # The tpf target doesn't support gdb yet. +@@ -2996,7 +2997,7 @@ + # to it. This is right: we don't want to search that directory + # for binaries, but we want the header files in there, so add + # them explicitly. +- FLAGS_FOR_TARGET=$FLAGS_FOR_TARGET' -isystem $$r/$(HOST_SUBDIR)/gcc/include' ++ FLAGS_FOR_TARGET=$FLAGS_FOR_TARGET' -isystem $$r/$(HOST_SUBDIR)/gcc/include -isystem $$r/$(HOST_SUBDIR)/gcc/include-fixed' + + # Someone might think of using the pre-installed headers on + # Canadian crosses, in case the installed compiler is not fully +diff -Naur gcc-4.5-20100325.orig/gcc/ChangeLog.rtems gcc-4.5-20100325/gcc/ChangeLog.rtems +--- gcc-4.5-20100325.orig/gcc/ChangeLog.rtems 1970-01-01 01:00:00.000000000 +0100 ++++ gcc-4.5-20100325/gcc/ChangeLog.rtems 2010-03-26 05:33:40.000000000 +0100 +@@ -0,0 +1,49 @@ ++2010-03-15 Ralf Corsépius <ralf.corsepius@rtems.org> ++ ++ Patch from Thomas Doerfler <Thomas.Doerfler@embedded-brains.de>: ++ * config/arm/rtems-elf.h, config/arm/t-rtems: Add optional support ++ for vfp FPU model ++ ++2010-02-10 Ralf Corsépius <ralf.corsepius@rtems.org> ++ ++ * config/rtems.h: Abandon -qrtems_debug. ++ ++2009-12-01 Ralf Corsépius <ralf.corsepius@rtems.org> ++ ++ * config/avr/avr.h (LINK_SPEC): Pass -m avrN to ld for -mmcu=avrN. ++ ++2009-11-04 Ralf Corsépius <ralf.corsepius@rtems.org> ++ ++ * config/m32c/rtems.h, config/m68k/rtemself.h, ++ config/m68k/rtemself.h, config/sh/rtemself.h, ++ config/sparc/rtemself.h: Undef WCHAR_TYPE_SIZE, WCHAR_TYPE. ++ (Resets WCHAR_TYPE's to defaults. Prevents broken GCC tm_files ++ to interfere and cause wchar_t/wint_t incompatibilities). ++ ++2009-10-15 Ralf Corsépius <ralf.corsepius@rtems.org> ++ ++ * config/avr/t-rtems: Don't build _exit. ++ ++ Jon Beniston <jon@beniston.com> ++ ++ * config/lm32/arithmetic.c, config/lm32/crti.S, ++ config/lm32/crtn.S, config/lm32/lib1funcs.S, ++ config/lm32/lm32.c, config/lm32/lm32.h, ++ config/lm32/lm32.md, config/lm32/lm32.opt, ++ config/lm32/lm32-protos.h, config/lm32/predicates.md, ++ config/lm32/rtems.h, config/lm32/sfp-machine.h, ++ config/lm32/t-fprules-softfp, config/lm32/t-lm32, ++ config/lm32/uclinux-elf.h: New (lm32 port). ++ * config.gcc: Add lm32* targets. ++ * doc/contrib.texi, doc/invoke.texi: Add lm32. ++ ++ Ralf Corsépius <ralf.corsepius@rtems.org> ++ ++ * config/rs6000/rtems.h: Support for custom RTEMS multilibs. ++ Support TARGET_E500. ++ * config/rs6000/t-rtems: Custom RTEMS multilibs. ++ ++ Ralf Corsépius <ralf.corsepius@rtems.org> ++ ++ * config/mips/elf.h: Remove NO_IMPLICIT_EXTERN_C. ++ +diff -Naur gcc-4.5-20100325.orig/gcc/config/arm/rtems-elf.h gcc-4.5-20100325/gcc/config/arm/rtems-elf.h +--- gcc-4.5-20100325.orig/gcc/config/arm/rtems-elf.h 2009-03-25 13:54:16.000000000 +0100 ++++ gcc-4.5-20100325/gcc/config/arm/rtems-elf.h 2010-03-26 05:33:40.000000000 +0100 +@@ -36,7 +36,7 @@ + */ + #undef SUBTARGET_EXTRA_ASM_SPEC + #define SUBTARGET_EXTRA_ASM_SPEC "\ +- %{!mhard-float: %{!msoft-float:-mfpu=softfpa}}" ++ %{!mhard-float: %{!mfpu=vfp: %{!msoft-float:-mfpu=softfpa}}}" + + /* + * The default includes --start-group and --end-group which conflicts +diff -Naur gcc-4.5-20100325.orig/gcc/config/arm/t-rtems gcc-4.5-20100325/gcc/config/arm/t-rtems +--- gcc-4.5-20100325.orig/gcc/config/arm/t-rtems 2004-11-23 06:30:32.000000000 +0100 ++++ gcc-4.5-20100325/gcc/config/arm/t-rtems 2010-03-26 05:33:40.000000000 +0100 +@@ -5,6 +5,41 @@ + MULTILIB_EXCEPTIONS = + MULTILIB_MATCHES = marm=mno-thumb + +-MULTILIB_OPTIONS += msoft-float/mhard-float +-MULTILIB_DIRNAMES += soft fpu +-MULTILIB_EXCEPTIONS += *mthumb/*mhard-float* ++MULTILIB_OPTIONS += mhard-float/mfloat-abi=softfp ++MULTILIB_DIRNAMES += fpu softfp ++MULTILIB_EXCEPTIONS += *mthumb*/*mhard-float* *mthumb*/*mfloat-abi=softfp* ++MULTILIB_MATCHES = ++ ++MULTILIB_OPTIONS += mfpu=vfp ++MULTILIB_DIRNAMES += vfp ++MULTILIB_EXCEPTIONS += *mhard-float*/*mfpu=vfp* *marm*/*mfloat-abi=softfp*/*mfpu=fpa* ++MULTILIB_EXCLUSIONS += !mthumb/mfloat-abi=softfp/!mfpu=vfp ++ ++# default float model is fpa, so don't create a explicit copy of it ++MULTILIB_EXCEPTIONS += *marm*/*mfpa* ++ ++# permutations of the options which are useful (+) or make no sense (-), ++# defaults are in brackets: ++# + (arm/soft/fpa) ++# + (arm/soft)/vfp ++# - (arm)/softfp(/fpa) ++# + (arm)/softfp/vfp ++# + (arm)/hard-float(/fpa) ++# - (arm)/hard-float/vfp ++# + thumb/(soft/fpa) ++# + thumb/(soft/)vfp ++# - thumb/softfp/fpa ++# - thumb/softfp/vfp ++# - thumb/hard-float/fpa ++# - thumb/hard-float/vfp ++ ++# subdirs to be used for multilibs and their respective options: ++#/thumb/vfp -> thumb/soft/vfp ++#/thumb/fpa -> thumb/soft/fpa ++#/thumb -> thumb/soft/fpa ++#/vfp -> arm/soft/vfp ++#/softfp/vfp -> arm/softfp/cfp ++#/fpu/fpa -> arm/hard/fpa ++#/fpu -> arm/hard/fpa ++#/fpa -> arm/soft/fpa ++#. -> arm/soft/fpa +diff -Naur gcc-4.5-20100325.orig/gcc/config/avr/t-rtems gcc-4.5-20100325/gcc/config/avr/t-rtems +--- gcc-4.5-20100325.orig/gcc/config/avr/t-rtems 2004-11-23 04:44:03.000000000 +0100 ++++ gcc-4.5-20100325/gcc/config/avr/t-rtems 2010-03-26 05:33:40.000000000 +0100 +@@ -1,3 +1,4 @@ + # Multilibs for avr RTEMS targets. + +-# ATM, this is just a stub ++# RTEMS uses _exit from newlib ++LIB1ASMFUNCS := $(filter-out _exit,$(LIB1ASMFUNCS)) +diff -Naur gcc-4.5-20100325.orig/gcc/config/lm32/rtems.h gcc-4.5-20100325/gcc/config/lm32/rtems.h +--- gcc-4.5-20100325.orig/gcc/config/lm32/rtems.h 1970-01-01 01:00:00.000000000 +0100 ++++ gcc-4.5-20100325/gcc/config/lm32/rtems.h 2010-03-26 05:33:40.000000000 +0100 +@@ -0,0 +1,32 @@ ++/* Definitions for rtems targeting a lm32 using ELF. ++ Copyright (C) 2009, Free Software Foundation, Inc. ++ ++This file is part of GCC. ++ ++GCC is free software; you can redistribute it and/or modify ++it under the terms of the GNU General Public License as published by ++the Free Software Foundation; either version 3, or (at your option) ++any later version. ++ ++GCC is distributed in the hope that it will be useful, ++but WITHOUT ANY WARRANTY; without even the implied warranty of ++MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++GNU General Public License for more details. ++ ++You should have received a copy of the GNU General Public License ++along with GCC; see the file COPYING3. If not see ++<http://www.gnu.org/licenses/>. */ ++ ++/* Target OS builtins. */ ++#undef TARGET_OS_CPP_BUILTINS ++#define TARGET_OS_CPP_BUILTINS() \ ++ do \ ++ { \ ++ builtin_define ("__rtems__"); \ ++ builtin_define ("__USE_INIT_FINI__"); \ ++ builtin_assert ("system=rtems"); \ ++ } \ ++ while (0) ++ ++/* Use the default */ ++#undef LINK_GCC_C_SEQUENCE_SPEC +diff -Naur gcc-4.5-20100325.orig/gcc/config/m32c/rtems.h gcc-4.5-20100325/gcc/config/m32c/rtems.h +--- gcc-4.5-20100325.orig/gcc/config/m32c/rtems.h 2008-12-01 17:34:42.000000000 +0100 ++++ gcc-4.5-20100325/gcc/config/m32c/rtems.h 2010-03-26 05:33:40.000000000 +0100 +@@ -29,5 +29,9 @@ + } \ + while (0) + +-/* Use the default */ ++/* Use the defaults */ + #undef LINK_GCC_C_SEQUENCE_SPEC ++ ++#undef WCHAR_TYPE ++ ++#undef WCHAR_TYPE_SIZE +diff -Naur gcc-4.5-20100325.orig/gcc/config/m68k/rtemself.h gcc-4.5-20100325/gcc/config/m68k/rtemself.h +--- gcc-4.5-20100325.orig/gcc/config/m68k/rtemself.h 2007-08-02 12:49:31.000000000 +0200 ++++ gcc-4.5-20100325/gcc/config/m68k/rtemself.h 2010-03-26 05:33:40.000000000 +0100 +@@ -31,3 +31,8 @@ + builtin_assert ("system=rtems"); \ + } \ + while (0) ++ ++/* Use the defaults */ ++#undef WCHAR_TYPE ++ ++#undef WCHAR_TYPE_SIZE +diff -Naur gcc-4.5-20100325.orig/gcc/config/mips/elf.h gcc-4.5-20100325/gcc/config/mips/elf.h +--- gcc-4.5-20100325.orig/gcc/config/mips/elf.h 2007-08-02 12:49:31.000000000 +0200 ++++ gcc-4.5-20100325/gcc/config/mips/elf.h 2010-03-26 05:33:40.000000000 +0100 +@@ -48,6 +48,4 @@ + #undef ENDFILE_SPEC + #define ENDFILE_SPEC "crtend%O%s crtn%O%s" + +-#define NO_IMPLICIT_EXTERN_C 1 +- + #define HANDLE_PRAGMA_PACK_PUSH_POP 1 +diff -Naur gcc-4.5-20100325.orig/gcc/config/rs6000/rtems.h gcc-4.5-20100325/gcc/config/rs6000/rtems.h +--- gcc-4.5-20100325.orig/gcc/config/rs6000/rtems.h 2007-08-02 12:49:31.000000000 +0200 ++++ gcc-4.5-20100325/gcc/config/rs6000/rtems.h 2010-03-26 05:33:40.000000000 +0100 +@@ -49,8 +49,22 @@ + %{mcpu=604: %{!Dppc*: %{!Dmpc*: -Dmpc604} } } \ + %{mcpu=750: %{!Dppc*: %{!Dmpc*: -Dmpc750} } } \ + %{mcpu=821: %{!Dppc*: %{!Dmpc*: -Dmpc821} } } \ +-%{mcpu=860: %{!Dppc*: %{!Dmpc*: -Dmpc860} } }" ++%{mcpu=860: %{!Dppc*: %{!Dmpc*: -Dmpc860} } } \ ++%{mcpu=8540: %{!Dppc*: %{!Dmpc*: -Dppc8540} } }" + + #undef SUBSUBTARGET_EXTRA_SPECS + #define SUBSUBTARGET_EXTRA_SPECS \ + { "cpp_os_rtems", CPP_OS_RTEMS_SPEC } ++ ++#undef SUBSUBTARGET_OVERRIDE_OPTIONS ++#define SUBSUBTARGET_OVERRIDE_OPTIONS \ ++ do { \ ++ if (TARGET_E500) \ ++ { \ ++ rs6000_float_gprs = 1; \ ++ } \ ++ } while(0) ++ ++#undef WCHAR_TYPE ++ ++#undef WCHAR_TYPE_SIZE +diff -Naur gcc-4.5-20100325.orig/gcc/config/rs6000/t-rtems gcc-4.5-20100325/gcc/config/rs6000/t-rtems +--- gcc-4.5-20100325.orig/gcc/config/rs6000/t-rtems 2009-04-21 21:03:23.000000000 +0200 ++++ gcc-4.5-20100325/gcc/config/rs6000/t-rtems 2010-03-26 05:33:40.000000000 +0100 +@@ -19,12 +19,12 @@ + # <http://www.gnu.org/licenses/>. + + MULTILIB_OPTIONS = \ +-mcpu=403/mcpu=505/mcpu=601/mcpu=603e/mcpu=604/mcpu=860/mcpu=7400 \ ++mcpu=403/mcpu=505/mcpu=601/mcpu=603e/mcpu=604/mcpu=860/mcpu=7400/mcpu=8540 \ + Dmpc8260 \ + msoft-float + + MULTILIB_DIRNAMES = \ +-m403 m505 m601 m603e m604 m860 m7400 \ ++m403 m505 m601 m603e m604 m860 m7400 m8540 \ + mpc8260 \ + nof + +@@ -47,6 +47,10 @@ + # Map 750 to . + MULTILIB_MATCHES += mcpu?750= + ++# Map e500, 8548 to 8540 ++MULTILIB_MATCHES += mcpu?8540=mcpu?e500 ++MULTILIB_MATCHES += mcpu?8540=mcpu?8548 ++ + # Soft-float only, default implies msoft-float + # NOTE: Must match with MULTILIB_MATCHES_FLOAT and MULTILIB_MATCHES + MULTILIB_SOFTFLOAT_ONLY = \ +@@ -80,3 +84,4 @@ + MULTILIB_EXCEPTIONS += *mcpu=750/Dmpc* + MULTILIB_EXCEPTIONS += *mcpu=860/Dmpc* + MULTILIB_EXCEPTIONS += *mcpu=7400/Dmpc* ++MULTILIB_EXCEPTIONS += *mcpu=8540/Dmpc* +diff -Naur gcc-4.5-20100325.orig/gcc/config/rtems.h gcc-4.5-20100325/gcc/config/rtems.h +--- gcc-4.5-20100325.orig/gcc/config/rtems.h 2007-08-02 12:49:31.000000000 +0200 ++++ gcc-4.5-20100325/gcc/config/rtems.h 2010-03-26 05:33:40.000000000 +0100 +@@ -38,6 +38,5 @@ + #undef LIB_SPEC + #define LIB_SPEC "%{!qrtems: " STD_LIB_SPEC "} " \ + "%{!nostdlib: %{qrtems: --start-group \ +- %{!qrtems_debug: -lrtemsbsp -lrtemscpu} \ +- %{qrtems_debug: -lrtemsbsp_g -lrtemscpu_g} \ ++ -lrtemsbsp -lrtemscpu \ + -lc -lgcc --end-group %{!qnolinkcmds: -T linkcmds%s}}}" +diff -Naur gcc-4.5-20100325.orig/gcc/config/sh/rtemself.h gcc-4.5-20100325/gcc/config/sh/rtemself.h +--- gcc-4.5-20100325.orig/gcc/config/sh/rtemself.h 2007-08-02 12:49:31.000000000 +0200 ++++ gcc-4.5-20100325/gcc/config/sh/rtemself.h 2010-03-26 05:33:40.000000000 +0100 +@@ -24,3 +24,8 @@ + builtin_define( "__rtems__" ); \ + builtin_assert( "system=rtems" ); \ + } while (0) ++ ++/* Use the defaults */ ++#undef WCHAR_TYPE ++ ++#undef WCHAR_TYPE_SIZE +diff -Naur gcc-4.5-20100325.orig/gcc/config/sparc/rtemself.h gcc-4.5-20100325/gcc/config/sparc/rtemself.h +--- gcc-4.5-20100325.orig/gcc/config/sparc/rtemself.h 2007-08-02 12:49:31.000000000 +0200 ++++ gcc-4.5-20100325/gcc/config/sparc/rtemself.h 2010-03-26 05:33:40.000000000 +0100 +@@ -29,5 +29,9 @@ + } \ + while (0) + +-/* Use the default */ ++/* Use the defaults */ + #undef LINK_GCC_C_SEQUENCE_SPEC ++ ++#undef WCHAR_TYPE ++ ++#undef WCHAR_TYPE_SIZE |