[rtems-crossrpms commit] New.

Ralf Corsepius ralf at rtems.org
Thu Sep 20 12:30:59 UTC 2012


Module:    rtems-crossrpms
Branch:    master
Commit:    70e2adab1a4976d0828da81f15f774ba8387c0be
Changeset: http://git.rtems.org/rtems-crossrpms/commit/?id=70e2adab1a4976d0828da81f15f774ba8387c0be

Author:    Ralf Corsépius <ralf.corsepius at rtems.org>
Date:      Thu Sep 20 14:33:27 2012 +0200

New.

---

 patches/gcc-4.7.2-rtems4.11-20120920.diff |  414 +++++++++++++++++++++++++++++
 1 files changed, 414 insertions(+), 0 deletions(-)

diff --git a/patches/gcc-4.7.2-rtems4.11-20120920.diff b/patches/gcc-4.7.2-rtems4.11-20120920.diff
new file mode 100644
index 0000000..8454749
--- /dev/null
+++ b/patches/gcc-4.7.2-rtems4.11-20120920.diff
@@ -0,0 +1,414 @@
+diff -Naur gcc-4.7.2.orig/gcc/ChangeLog.rtems gcc-4.7.2/gcc/ChangeLog.rtems
+--- gcc-4.7.2.orig/gcc/ChangeLog.rtems	1970-01-01 01:00:00.000000000 +0100
++++ gcc-4.7.2/gcc/ChangeLog.rtems	2012-09-20 14:31:40.255353087 +0200
+@@ -0,0 +1,61 @@
++2012-07-05	Ralf Corsépius <ralf.corsepius at rtems.org>
++
++	* config.gcc (sparc64-*-rtems*): Remove sparc/t-crtin, sparc/t-crtfm.
++	Add sparc/t-rtems-64.
++	* config/sparc/t-rtems-64: New.
++
++2012-07-04	Ralf Corsépius <ralf.corsepius at rtems.org>
++
++	* config/sparc/t-rtems: Resurrect gcc-4.6.x multilibs.
++
++2012-04-19	Ralf Corsépius <ralf.corsepius at rtems.org>
++
++	* config.gcc (microblaze*-*-rtems*): New target.
++	* config/microblaze/rtems.h: New.
++	* config/microblaze/t-rtems: New.
++
++2011-10-28	Ralf Corsépius <ralf.corsepius at rtems.org>
++
++	* config/avr/rtems.h: Remove __USE_INIT_FINI__.
++
++2011-06-20	Ralf Corsépius <ralf.corsepius at rtems.org>
++
++	* sparc/t-rtems: Reflect introduction of sparc/t-crtin.
++
++2011-03-23	Joel Sherrill <joel.sherrill at oarcorp.com>
++
++	* config.gcc (sparc-*-rtems*, sparc64-*-rtems*):
++	Add sparc/t-rtems, crti.o crtn.o.
++	* config/sparc/t-rtems: New.
++
++2011-03-22	Ralf Corsépius <ralf.corsepius at rtems.org>
++
++	* config.gcc (sparc64-rtems*): Remove sysv.h from tm_file.
++
++2010-05-19  Joel Sherrill <joel.sherrill at oarcorp.com>
++
++    	* config.gcc (sparc64-*-rtems*): New target.
++	* config/sparc/sp64-rtemself.h: New file.
++
++2010-04-19	Ralf Corsépius <ralf.corsepius at rtems.org>
++
++	* ginclude/stddef.h: Define _MACHINE_ANSI_H_ if _X86_64_ANSI_H_ is 
++	defined (Used by amd64-*-netbsdelf5.*).
++
++2010-04-18	Ralf Corsépius <ralf.corsepius at rtems.org>
++
++	* ginclude/stddef.h: Define _MACHINE_ANSI_H_ if _I386_ANSI_H_ is 
++	defined (Used by i386-*-netbsdelf5.*).
++
++2009-11-04	Ralf Corsépius <ralf.corsepius at 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).
++
++		Ralf Corsépius <ralf.corsepius at rtems.org>
++
++	* config/mips/elf.h: Remove NO_IMPLICIT_EXTERN_C.
++	
+diff -Naur gcc-4.7.2.orig/gcc/config/avr/rtems.h gcc-4.7.2/gcc/config/avr/rtems.h
+--- gcc-4.7.2.orig/gcc/config/avr/rtems.h	2007-08-02 12:49:31.000000000 +0200
++++ gcc-4.7.2/gcc/config/avr/rtems.h	2012-09-20 14:31:40.257353117 +0200
+@@ -23,6 +23,5 @@
+ #define TARGET_OS_CPP_BUILTINS()	\
+ do {					\
+   builtin_define ("__rtems__");		\
+-  builtin_define ("__USE_INIT_FINI__");	\
+   builtin_assert ("system=rtems");	\
+ } while (0)
+diff -Naur gcc-4.7.2.orig/gcc/config/avr/t-rtems gcc-4.7.2/gcc/config/avr/t-rtems
+--- gcc-4.7.2.orig/gcc/config/avr/t-rtems	2004-11-23 04:44:03.000000000 +0100
++++ gcc-4.7.2/gcc/config/avr/t-rtems	2012-09-20 14:31:40.258353132 +0200
+@@ -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.7.2.orig/gcc/config/h8300/h8300.h gcc-4.7.2/gcc/config/h8300/h8300.h
+--- gcc-4.7.2.orig/gcc/config/h8300/h8300.h	2012-08-06 16:34:27.000000000 +0200
++++ gcc-4.7.2/gcc/config/h8300/h8300.h	2012-09-20 14:31:40.258353132 +0200
+@@ -129,6 +129,7 @@
+ #define INCOMING_FRAME_SP_OFFSET   (POINTER_SIZE / 8)
+ 
+ #define DWARF_CIE_DATA_ALIGNMENT	2
++#define DWARF2_ADDR_SIZE		4
+ 
+ /* Define this if addresses of constant functions
+    shouldn't be put through pseudo regs where they can be cse'd.
+diff -Naur gcc-4.7.2.orig/gcc/config/m32c/rtems.h gcc-4.7.2/gcc/config/m32c/rtems.h
+--- gcc-4.7.2.orig/gcc/config/m32c/rtems.h	2008-12-01 17:34:42.000000000 +0100
++++ gcc-4.7.2/gcc/config/m32c/rtems.h	2012-09-20 14:31:40.259353147 +0200
+@@ -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.7.2.orig/gcc/config/m68k/rtemself.h gcc-4.7.2/gcc/config/m68k/rtemself.h
+--- gcc-4.7.2.orig/gcc/config/m68k/rtemself.h	2007-08-02 12:49:31.000000000 +0200
++++ gcc-4.7.2/gcc/config/m68k/rtemself.h	2012-09-20 14:31:40.260353163 +0200
+@@ -31,3 +31,8 @@
+ 	builtin_assert ("system=rtems");	\
+     }						\
+   while (0)
++
++/* Use the defaults */
++#undef WCHAR_TYPE
++
++#undef WCHAR_TYPE_SIZE
+diff -Naur gcc-4.7.2.orig/gcc/config/microblaze/rtems.h gcc-4.7.2/gcc/config/microblaze/rtems.h
+--- gcc-4.7.2.orig/gcc/config/microblaze/rtems.h	1970-01-01 01:00:00.000000000 +0100
++++ gcc-4.7.2/gcc/config/microblaze/rtems.h	2012-09-20 14:31:40.260353163 +0200
+@@ -0,0 +1,25 @@
++/* Definitions for rtems targeting a microblaze using ELF.
++   Copyright (C) 2012 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/>.  */
++
++/* Specify predefined symbols in preprocessor.  */
++
++#define TARGET_OS_CPP_BUILTINS() do {		\
++  builtin_define( "__rtems__" );		\
++  builtin_assert( "system=rtems" );		\
++} while (0)
+diff -Naur gcc-4.7.2.orig/gcc/config/microblaze/t-rtems gcc-4.7.2/gcc/config/microblaze/t-rtems
+--- gcc-4.7.2.orig/gcc/config/microblaze/t-rtems	1970-01-01 01:00:00.000000000 +0100
++++ gcc-4.7.2/gcc/config/microblaze/t-rtems	2012-09-20 14:31:40.260353163 +0200
+@@ -0,0 +1 @@
++# Custom multilibs for RTEMS
+diff -Naur gcc-4.7.2.orig/gcc/config/mips/elf.h gcc-4.7.2/gcc/config/mips/elf.h
+--- gcc-4.7.2.orig/gcc/config/mips/elf.h	2010-11-21 01:54:14.000000000 +0100
++++ gcc-4.7.2/gcc/config/mips/elf.h	2012-09-20 14:31:40.267353271 +0200
+@@ -47,5 +47,3 @@
+ 
+ #undef  ENDFILE_SPEC
+ #define ENDFILE_SPEC "crtend%O%s crtn%O%s"
+-
+-#define NO_IMPLICIT_EXTERN_C 1
+diff -Naur gcc-4.7.2.orig/gcc/config/rs6000/rtems.h gcc-4.7.2/gcc/config/rs6000/rtems.h
+--- gcc-4.7.2.orig/gcc/config/rs6000/rtems.h	2011-12-06 23:49:57.000000000 +0100
++++ gcc-4.7.2/gcc/config/rs6000/rtems.h	2012-09-20 14:31:40.268353286 +0200
+@@ -69,3 +69,7 @@
+           rs6000_spe_abi = 1;                                             \
+       }                                                                   \
+   } while(0)
++
++#undef WCHAR_TYPE
++
++#undef WCHAR_TYPE_SIZE
+diff -Naur gcc-4.7.2.orig/gcc/config/sh/rtemself.h gcc-4.7.2/gcc/config/sh/rtemself.h
+--- gcc-4.7.2.orig/gcc/config/sh/rtemself.h	2007-08-02 12:49:31.000000000 +0200
++++ gcc-4.7.2/gcc/config/sh/rtemself.h	2012-09-20 14:31:40.268353286 +0200
+@@ -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.7.2.orig/gcc/config/sparc/rtemself.h gcc-4.7.2/gcc/config/sparc/rtemself.h
+--- gcc-4.7.2.orig/gcc/config/sparc/rtemself.h	2007-08-02 12:49:31.000000000 +0200
++++ gcc-4.7.2/gcc/config/sparc/rtemself.h	2012-09-20 14:31:40.268353286 +0200
+@@ -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.7.2.orig/gcc/config/sparc/sp64-rtemself.h gcc-4.7.2/gcc/config/sparc/sp64-rtemself.h
+--- gcc-4.7.2.orig/gcc/config/sparc/sp64-rtemself.h	1970-01-01 01:00:00.000000000 +0100
++++ gcc-4.7.2/gcc/config/sparc/sp64-rtemself.h	2012-09-20 14:31:40.269353302 +0200
+@@ -0,0 +1,37 @@
++/* Definitions for rtems targeting a SPARC64 using ELF.
++   Copyright (C) 2010 Free Software Foundation, Inc.
++   Contributed by Joel Sherrill (joel at OARcorp.com).
++
++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
++
++/* we are not svr4 */
++#undef CPP_SUBTARGET_SPEC
++#define CPP_SUBTARGET_SPEC ""
+diff -Naur gcc-4.7.2.orig/gcc/config/sparc/t-rtems gcc-4.7.2/gcc/config/sparc/t-rtems
+--- gcc-4.7.2.orig/gcc/config/sparc/t-rtems	1970-01-01 01:00:00.000000000 +0100
++++ gcc-4.7.2/gcc/config/sparc/t-rtems	2012-09-20 14:31:40.269353302 +0200
+@@ -0,0 +1,22 @@
++# Copyright (C) 2011 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/>.
++#
++
++MULTILIB_OPTIONS = msoft-float mcpu=v8
++MULTILIB_DIRNAMES = soft v8
++MULTILIB_MATCHES = msoft-float=mno-fpu
+diff -Naur gcc-4.7.2.orig/gcc/config/sparc/t-rtems-64 gcc-4.7.2/gcc/config/sparc/t-rtems-64
+--- gcc-4.7.2.orig/gcc/config/sparc/t-rtems-64	1970-01-01 01:00:00.000000000 +0100
++++ gcc-4.7.2/gcc/config/sparc/t-rtems-64	2012-09-20 14:31:40.269353302 +0200
+@@ -0,0 +1,22 @@
++# Copyright (C) 2012 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/>.
++#
++
++MULTILIB_OPTIONS = msoft-float
++MULTILIB_DIRNAMES = soft
++MULTILIB_MATCHES = msoft-float=mno-fpu
+diff -Naur gcc-4.7.2.orig/gcc/config.gcc gcc-4.7.2/gcc/config.gcc
+--- gcc-4.7.2.orig/gcc/config.gcc	2012-09-12 11:03:54.000000000 +0200
++++ gcc-4.7.2/gcc/config.gcc	2012-09-20 14:31:40.257353117 +0200
+@@ -1723,6 +1723,14 @@
+ 	c_target_objs="${c_target_objs} microblaze-c.o"
+ 	cxx_target_objs="${cxx_target_objs} microblaze-c.o"
+ 	;;
++microblaze*-*-rtems*)
++	tm_file="${tm_file} dbxelf.h"
++	tm_file="${tm_file} microblaze/rtems.h rtems.h newlib-stdint.h"
++	c_target_objs="${c_target_objs} microblaze-c.o"
++	cxx_target_objs="${cxx_target_objs} microblaze-c.o"
++	tmake_file="${tmake_file} microblaze/t-microblaze"
++	tmake_file="${tmake_file} t-rtems microblaze/t-rtems"
++        ;;
+ microblaze*-*-*)
+         tm_file="${tm_file} dbxelf.h"
+ 	c_target_objs="${c_target_objs} microblaze-c.o"
+@@ -2404,7 +2412,8 @@
+ 	;;
+ sparc-*-rtems*)
+ 	tm_file="${tm_file} dbxelf.h elfos.h sparc/sysv4.h sparc/sp-elf.h sparc/rtemself.h rtems.h newlib-stdint.h"
+-	tmake_file="sparc/t-sparc sparc/t-elf t-rtems"
++	tmake_file="sparc/t-sparc sparc/t-elf sparc/t-rtems t-rtems"
++	extra_parts="crtbegin.o crtend.o"
+ 	;;
+ sparc-*-linux*)
+ 	tm_file="${tm_file} dbxelf.h elfos.h sparc/sysv4.h gnu-user.h linux.h glibc-stdint.h sparc/tso.h"
+@@ -2457,8 +2466,9 @@
+ sparc64-*-rtems*)
+ 	tm_file="${tm_file} dbxelf.h elfos.h newlib-stdint.h sparc/sysv4.h sparc/sp64-elf.h sparc/rtemself.h rtems.h"
+ 	extra_options="${extra_options}"
+-	tmake_file="${tmake_file} sparc/t-sparc t-rtems"
+-	;;
++	tmake_file="${tmake_file} sparc/t-sparc sparc/t-rtems-64 t-rtems"
++	extra_parts="crtbegin.o crtend.o"
++ 	;;
+ sparc64-*-linux*)
+ 	tm_file="sparc/biarch64.h ${tm_file} dbxelf.h elfos.h sparc/sysv4.h gnu-user.h linux.h glibc-stdint.h sparc/default-64.h sparc/linux64.h sparc/tso.h"
+ 	extra_options="${extra_options} sparc/long-double-switch.opt"
+diff -Naur gcc-4.7.2.orig/gcc/ginclude/stddef.h gcc-4.7.2/gcc/ginclude/stddef.h
+--- gcc-4.7.2.orig/gcc/ginclude/stddef.h	2012-02-12 02:06:04.000000000 +0100
++++ gcc-4.7.2/gcc/ginclude/stddef.h	2012-09-20 14:31:40.270353318 +0200
+@@ -53,7 +53,13 @@
+    one less case to deal with in the following.  */
+ #if defined (__BSD_NET2__) || defined (____386BSD____) || (defined (__FreeBSD__) && (__FreeBSD__ < 5)) || defined(__NetBSD__)
+ #include <machine/ansi.h>
++#if !defined(_MACHINE_ANSI_H_)
++#if defined(_I386_ANSI_H_) || defined(_X86_64_ANSI_H_)
++#define _MACHINE_ANSI_H_
+ #endif
++#endif
++#endif
++
+ /* On FreeBSD 5, machine/ansi.h does not exist anymore... */
+ #if defined (__FreeBSD__) && (__FreeBSD__ >= 5)
+ #include <sys/_types.h>
+diff -Naur gcc-4.7.2.orig/libgcc/ChangeLog.rtems gcc-4.7.2/libgcc/ChangeLog.rtems
+--- gcc-4.7.2.orig/libgcc/ChangeLog.rtems	1970-01-01 01:00:00.000000000 +0100
++++ gcc-4.7.2/libgcc/ChangeLog.rtems	2012-09-20 14:31:40.270353318 +0200
+@@ -0,0 +1,18 @@
++2012-07-10  Ralf Corsépius <ralf.corsepius at rtems.org>
++
++	* config.host (sh*-*-rtems*): Add sh*-*-elf*'s extra_parts. 
++
++2012-07-05  Ralf Corsépius <ralf.corsepius at rtems.org>
++
++	* config.host (sparc64-*-rtems*): Remove sparc/t-elf.
++
++2012-05-16  Joel Sherrill <joel.sherrill at oarcorp.com>
++
++	* config.host (m32r-*-rtems*): Include crtinit.o and crtfinit.o
++     	as extra_parts.
++
++2012-03-08  Sebastian Huber  <sebastian.huber at embedded-brains.de>
++
++        * config.host (powerpc-*-rtems*): Add rs6000/t-savresfgpr to
++        tmake_file.
++
+diff -Naur gcc-4.7.2.orig/libgcc/config.host gcc-4.7.2/libgcc/config.host
+--- gcc-4.7.2.orig/libgcc/config.host	2012-09-05 14:19:47.000000000 +0200
++++ gcc-4.7.2/libgcc/config.host	2012-09-20 14:31:40.271353334 +0200
+@@ -693,6 +693,7 @@
+  	;;
+ m32r-*-rtems*)
+ 	tmake_file="$tmake_file m32r/t-m32r t-fdpbit"
++	extra_parts="$extra_parts crtinit.o crtfini.o"
+ 	;;
+ m32rle-*-elf*)
+ 	tmake_file=t-fdpbit
+@@ -891,7 +892,7 @@
+ 	extra_parts="$extra_parts crtbegin.o crtend.o crtbeginS.o crtendS.o crtbeginT.o ecrti.o ecrtn.o ncrti.o ncrtn.o"
+ 	;;
+ powerpc-*-rtems*)
+-	tmake_file="${tmake_file} rs6000/t-ppccomm rs6000/t-crtstuff t-crtstuff-pic t-fdpbit"
++	tmake_file="${tmake_file} rs6000/t-ppccomm rs6000/t-savresfgpr rs6000/t-crtstuff t-crtstuff-pic t-fdpbit"
+ 	extra_parts="$extra_parts crtbeginS.o crtendS.o crtbeginT.o ecrti.o ecrtn.o ncrti.o ncrtn.o"
+ 	;;
+ powerpc-*-linux* | powerpc64-*-linux*)
+@@ -995,7 +996,10 @@
+ sh-*-rtems*)
+ 	tmake_file="$tmake_file sh/t-sh t-crtstuff-pic t-fdpbit"
+ 	extra_parts="$extra_parts crt1.o crti.o crtn.o crtbeginS.o crtendS.o \
+-		$sh_ic_extra_parts $sh_opt_extra_parts"
++		libic_invalidate_array_4-100.a \
++		libic_invalidate_array_4-200.a \
++		libic_invalidate_array_4a.a \
++		libgcc-Os-4-200.a libgcc-4-300.a"
+ 	;;
+ sh-wrs-vxworks)
+ 	tmake_file="$tmake_file sh/t-sh t-crtstuff-pic t-fdpbit"
+@@ -1054,7 +1058,7 @@
+ 	extra_parts="$extra_parts crti.o crtn.o crtfastmath.o"
+ 	;;
+ sparc64-*-rtems*)
+-	tmake_file="$tmake_file sparc/t-elf t-crtfm"
++	tmake_file="$tmake_file t-crtfm"
+ 	extra_parts="$extra_parts crti.o crtn.o crtfastmath.o"
+ 	;;
+ sparc-wrs-vxworks)




More information about the vc mailing list