mirror of
https://gitlab.rtems.org/rtems/rtos/rtems.git
synced 2025-12-05 15:15:44 +00:00
Rebase patch against gcc-4.5-20100325.
This commit is contained in:
@@ -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
|
||||
Reference in New Issue
Block a user