From 1255ee64ee58fb5f0acd0bdbf4f0a54afd5ceeaf Mon Sep 17 00:00:00 2001 From: Richard Purdie Date: Tue, 18 Mar 2008 10:41:39 +0000 Subject: gcc: Merge in the major cleanup I made in OE.dev git-svn-id: https://svn.o-hand.com/repos/poky/trunk@4038 311d38ba-8fff-0310-9ca6-ca027cbcb966 --- .../gcc/gcc-4.1.1/ppc-gcc-41-20060515.patch | 2225 -------------------- 1 file changed, 2225 deletions(-) delete mode 100644 meta/packages/gcc/gcc-4.1.1/ppc-gcc-41-20060515.patch (limited to 'meta/packages/gcc/gcc-4.1.1/ppc-gcc-41-20060515.patch') diff --git a/meta/packages/gcc/gcc-4.1.1/ppc-gcc-41-20060515.patch b/meta/packages/gcc/gcc-4.1.1/ppc-gcc-41-20060515.patch deleted file mode 100644 index 166e79c7e9..0000000000 --- a/meta/packages/gcc/gcc-4.1.1/ppc-gcc-41-20060515.patch +++ /dev/null @@ -1,2225 +0,0 @@ -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/ChangeLog gcc-41-20060515/gcc/ChangeLog ---- gcc-41-20060515.orig/gcc/ChangeLog 2006-05-15 11:14:20.000000000 -0500 -+++ gcc-41-20060515/gcc/ChangeLog 2006-05-15 14:00:27.693964000 -0500 -@@ -724,6 +724,51 @@ - * reload1.c (choose_reload_regs): Added call of regno_clobbered_p - with new meaning of SETS. - -+2006-02-14 Jakub Jelinek -+ Aldy Hernandez -+ -+ PR target/25864 -+ * configure.ac: Add --with{out}-long-double-128 configure option. -+ (TARGET_DEFAULT_LONG_DOUBLE_128): New test. -+ * configure: Rebuilt. -+ * config.in: Rebuilt. -+ * doc/install.texi (Options specification): Document -+ --with-long-double-128. -+ -+ * config.gcc (sparc-*-linux*): Add sparc/t-linux to tmake_file. -+ (sparc64-*-linux*): Likewise. -+ * config/sparc/t-linux64 (SHLIB_MAPFILES): Removed. -+ * config/sparc/t-linux: New file. -+ * config/sparc/libgcc-sparc-glibc.ver (__fixtfdi, __fixunstfdi, -+ __floatditf): Export at GCC_LDBL_3.0 if -m32 -mlong-double-128. -+ (__divtc3, __multc3, __powitf2): Export at GCC_LDBL_4.0.0 if -+ -m32 -mlong-double-128. -+ -+ * config.gcc (alpha*-*-linux*): Add alpha/t-linux to tmake_file. -+ * config/alpha/t-linux: New file. -+ * config/alpha/libgcc-alpha-ldbl.ver: New file. -+ -+ * config/sparc/linux.h (TARGET_OS_CPP_BUILTINS): Define -+ __LONG_DOUBLE_128__ if TARGET_LONG_DOUBLE_128. -+ (CPP_SUBTARGET_SPEC): Don't add -D__LONG_DOUBLE_128__ here. -+ * config/sparc/linux64.h (TARGET_OS_CPP_BUILTINS): Define -+ __LONG_DOUBLE_128__ if TARGET_LONG_DOUBLE_128 and TARGET_ARCH32. -+ (CPP_ARCH32_SPEC): Remove. -+ -+ * config/s390/s390.c (override_options): Handle -+ TARGET_DEFAULT_LONG_DOUBLE_128. -+ -+ * config/alpha/alpha.c (override_options): Handle -+ TARGET_DEFAULT_LONG_DOUBLE_128. -+ -+ * config/sparc/sparc.c (sparc_override_options): Handle -+ TARGET_DEFAULT_LONG_DOUBLE_128. -+ -+ * config/rs6000/linux.h [TARGET_DEFAULT_LONG_DOUBLE_128] -+ (RS6000_DEFAULT_LONG_DOUBLE_SIZE): Define to 128. -+ * config/rs6000/linux64.h [TARGET_DEFAULT_LONG_DOUBLE_128] -+ (RS6000_DEFAULT_LONG_DOUBLE_SIZE): Define to 128. -+ - 2006-02-19 John David Anglin - - * doc/install.texi: Add missing `@samp'. -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/config/alpha/alpha.c gcc-41-20060515/gcc/config/alpha/alpha.c ---- gcc-41-20060515.orig/gcc/config/alpha/alpha.c 2006-05-15 11:13:49.000000000 -0500 -+++ gcc-41-20060515/gcc/config/alpha/alpha.c 2006-05-15 13:47:27.566272961 -0500 -@@ -516,6 +516,11 @@ override_options (void) - REAL_MODE_FORMAT (DFmode) = &vax_g_format; - REAL_MODE_FORMAT (TFmode) = NULL; - } -+ -+#ifdef TARGET_DEFAULT_LONG_DOUBLE_128 -+ if (!(target_flags_explicit & MASK_LONG_DOUBLE_128)) -+ target_flags |= MASK_LONG_DOUBLE_128; -+#endif - } - - /* Returns 1 if VALUE is a mask that contains full bytes of zero or ones. */ -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/config/alpha/libgcc-alpha-ldbl.ver gcc-41-20060515/gcc/config/alpha/libgcc-alpha-ldbl.ver ---- gcc-41-20060515.orig/gcc/config/alpha/libgcc-alpha-ldbl.ver 1969-12-31 18:00:00.000000000 -0600 -+++ gcc-41-20060515/gcc/config/alpha/libgcc-alpha-ldbl.ver 2006-05-15 13:47:27.566272961 -0500 -@@ -0,0 +1,32 @@ -+%ifdef __LONG_DOUBLE_128__ -+ -+# long double 128 bit support in libgcc_s.so.1 is only available -+# when configured with --with-long-double-128. Make sure all the -+# symbols are available at @@GCC_LDBL_* versions to make it clear -+# there is a configurable symbol set. -+ -+%exclude { -+ __fixtfdi -+ __fixunstfdi -+ __floatditf -+ -+ __divtc3 -+ __multc3 -+ __powitf2 -+} -+ -+%inherit GCC_LDBL_3.0 GCC_3.0 -+GCC_LDBL_3.0 { -+ __fixtfdi -+ __fixunstfdi -+ __floatditf -+} -+ -+%inherit GCC_LDBL_4.0.0 GCC_4.0.0 -+GCC_LDBL_4.0.0 { -+ __divtc3 -+ __multc3 -+ __powitf2 -+} -+ -+%endif -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/config/alpha/t-linux gcc-41-20060515/gcc/config/alpha/t-linux ---- gcc-41-20060515.orig/gcc/config/alpha/t-linux 1969-12-31 18:00:00.000000000 -0600 -+++ gcc-41-20060515/gcc/config/alpha/t-linux 2006-05-15 13:47:27.567272807 -0500 -@@ -0,0 +1 @@ -+SHLIB_MAPFILES += $(srcdir)/config/alpha/libgcc-alpha-ldbl.ver -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/config/rs6000/linux64.h gcc-41-20060515/gcc/config/rs6000/linux64.h ---- gcc-41-20060515.orig/gcc/config/rs6000/linux64.h 2006-05-15 11:14:02.000000000 -0500 -+++ gcc-41-20060515/gcc/config/rs6000/linux64.h 2006-05-15 13:47:27.568272653 -0500 -@@ -570,3 +570,8 @@ while (0) - #endif - - #define POWERPC_LINUX -+ -+/* ppc{32,64} linux has 128-bit long double support in glibc 2.4 and later. */ -+#ifdef TARGET_DEFAULT_LONG_DOUBLE_128 -+#define RS6000_DEFAULT_LONG_DOUBLE_SIZE 128 -+#endif -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/config/rs6000/linux.h gcc-41-20060515/gcc/config/rs6000/linux.h ---- gcc-41-20060515.orig/gcc/config/rs6000/linux.h 2006-05-15 11:14:02.000000000 -0500 -+++ gcc-41-20060515/gcc/config/rs6000/linux.h 2006-05-15 13:47:27.567272807 -0500 -@@ -120,3 +120,8 @@ - #endif - - #define POWERPC_LINUX -+ -+/* ppc linux has 128-bit long double support in glibc 2.4 and later. */ -+#ifdef TARGET_DEFAULT_LONG_DOUBLE_128 -+#define RS6000_DEFAULT_LONG_DOUBLE_SIZE 128 -+#endif -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/config/s390/s390.c gcc-41-20060515/gcc/config/s390/s390.c ---- gcc-41-20060515.orig/gcc/config/s390/s390.c 2006-05-15 11:13:50.000000000 -0500 -+++ gcc-41-20060515/gcc/config/s390/s390.c 2006-05-15 13:47:27.574271730 -0500 -@@ -1415,6 +1415,11 @@ override_options (void) - } - else if (s390_stack_guard) - error ("-mstack-guard implies use of -mstack-size"); -+ -+#ifdef TARGET_DEFAULT_LONG_DOUBLE_128 -+ if (!(target_flags_explicit & MASK_LONG_DOUBLE_128)) -+ target_flags |= MASK_LONG_DOUBLE_128; -+#endif - } - - /* Map for smallest class containing reg regno. */ -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/config/sparc/libgcc-sparc-glibc.ver gcc-41-20060515/gcc/config/sparc/libgcc-sparc-glibc.ver ---- gcc-41-20060515.orig/gcc/config/sparc/libgcc-sparc-glibc.ver 2006-05-15 11:13:55.000000000 -0500 -+++ gcc-41-20060515/gcc/config/sparc/libgcc-sparc-glibc.ver 2006-05-15 13:47:27.574271730 -0500 -@@ -26,3 +26,36 @@ GLIBC_VER { - __frame_state_for - __register_frame_info_table - } -+ -+%if !defined (__arch64__) && defined (__LONG_DOUBLE_128__) -+ -+# long double 128 bit support from 32-bit libgcc_s.so.1 is only available -+# when configured with --with-long-double-128. Make sure all the -+# symbols are available at @@GCC_LDBL_* versions to make it clear -+# there is a configurable symbol set. -+ -+%exclude { -+ __fixtfdi -+ __fixunstfdi -+ __floatditf -+ -+ __divtc3 -+ __multc3 -+ __powitf2 -+} -+ -+%inherit GCC_LDBL_3.0 GCC_3.0 -+GCC_LDBL_3.0 { -+ __fixtfdi -+ __fixunstfdi -+ __floatditf -+} -+ -+%inherit GCC_LDBL_4.0.0 GCC_4.0.0 -+GCC_LDBL_4.0.0 { -+ __divtc3 -+ __multc3 -+ __powitf2 -+} -+ -+%endif -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/config/sparc/linux64.h gcc-41-20060515/gcc/config/sparc/linux64.h ---- gcc-41-20060515.orig/gcc/config/sparc/linux64.h 2006-05-15 11:13:55.000000000 -0500 -+++ gcc-41-20060515/gcc/config/sparc/linux64.h 2006-05-15 13:47:27.576271422 -0500 -@@ -20,22 +20,24 @@ along with GCC; see the file COPYING. I - the Free Software Foundation, 51 Franklin Street, Fifth Floor, - Boston, MA 02110-1301, USA. */ - --#define TARGET_OS_CPP_BUILTINS() \ -- do \ -- { \ -- builtin_define_std ("unix"); \ -- builtin_define_std ("linux"); \ -- builtin_define ("_LONGLONG"); \ -- builtin_define ("__gnu_linux__"); \ -- builtin_assert ("system=linux"); \ -- builtin_assert ("system=unix"); \ -- builtin_assert ("system=posix"); \ -- if (flag_pic) \ -- { \ -- builtin_define ("__PIC__"); \ -- builtin_define ("__pic__"); \ -- } \ -- } \ -+#define TARGET_OS_CPP_BUILTINS() \ -+ do \ -+ { \ -+ builtin_define_std ("unix"); \ -+ builtin_define_std ("linux"); \ -+ builtin_define ("_LONGLONG"); \ -+ builtin_define ("__gnu_linux__"); \ -+ builtin_assert ("system=linux"); \ -+ builtin_assert ("system=unix"); \ -+ builtin_assert ("system=posix"); \ -+ if (flag_pic) \ -+ { \ -+ builtin_define ("__PIC__"); \ -+ builtin_define ("__pic__"); \ -+ } \ -+ if (TARGET_ARCH32 && TARGET_LONG_DOUBLE_128) \ -+ builtin_define ("__LONG_DOUBLE_128__"); \ -+ } \ - while (0) - - /* Don't assume anything about the header files. */ -@@ -59,13 +61,6 @@ Boston, MA 02110-1301, USA. */ - #undef ASM_CPU_DEFAULT_SPEC - #define ASM_CPU_DEFAULT_SPEC "-Av9a" - --#ifdef SPARC_BI_ARCH -- --#undef CPP_ARCH32_SPEC --#define CPP_ARCH32_SPEC "%{mlong-double-128:-D__LONG_DOUBLE_128__}" -- --#endif -- - /* Provide a STARTFILE_SPEC appropriate for GNU/Linux. Here we add - the GNU/Linux magical crtbegin.o file (see crtstuff.c) which - provides part of the support for getting C++ file-scope static -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/config/sparc/linux.h gcc-41-20060515/gcc/config/sparc/linux.h ---- gcc-41-20060515.orig/gcc/config/sparc/linux.h 2006-05-15 11:13:55.000000000 -0500 -+++ gcc-41-20060515/gcc/config/sparc/linux.h 2006-05-15 13:47:27.575271576 -0500 -@@ -23,17 +23,19 @@ Boston, MA 02110-1301, USA. */ - #define TARGET_OS_CPP_BUILTINS() \ - do \ - { \ -- builtin_define_std ("unix"); \ -- builtin_define_std ("linux"); \ -- builtin_define ("__gnu_linux__"); \ -- builtin_assert ("system=linux"); \ -- builtin_assert ("system=unix"); \ -- builtin_assert ("system=posix"); \ -- if (flag_pic) \ -- { \ -- builtin_define ("__PIC__"); \ -- builtin_define ("__pic__"); \ -- } \ -+ builtin_define_std ("unix"); \ -+ builtin_define_std ("linux"); \ -+ builtin_define ("__gnu_linux__"); \ -+ builtin_assert ("system=linux"); \ -+ builtin_assert ("system=unix"); \ -+ builtin_assert ("system=posix"); \ -+ if (flag_pic) \ -+ { \ -+ builtin_define ("__PIC__"); \ -+ builtin_define ("__pic__"); \ -+ } \ -+ if (TARGET_LONG_DOUBLE_128) \ -+ builtin_define ("__LONG_DOUBLE_128__"); \ - } \ - while (0) - -@@ -100,8 +102,7 @@ Boston, MA 02110-1301, USA. */ - - #undef CPP_SUBTARGET_SPEC - #define CPP_SUBTARGET_SPEC \ --"%{posix:-D_POSIX_SOURCE} \ --%{pthread:-D_REENTRANT} %{mlong-double-128:-D__LONG_DOUBLE_128__}" -+"%{posix:-D_POSIX_SOURCE} %{pthread:-D_REENTRANT}" - - #undef LIB_SPEC - #define LIB_SPEC \ -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/config/sparc/sparc.c gcc-41-20060515/gcc/config/sparc/sparc.c ---- gcc-41-20060515.orig/gcc/config/sparc/sparc.c 2006-05-15 11:13:55.000000000 -0500 -+++ gcc-41-20060515/gcc/config/sparc/sparc.c 2006-05-15 13:47:27.581270653 -0500 -@@ -790,6 +790,11 @@ sparc_override_options (void) - sparc_costs = &ultrasparc3_costs; - break; - }; -+ -+#ifdef TARGET_DEFAULT_LONG_DOUBLE_128 -+ if (!(target_flags_explicit & MASK_LONG_DOUBLE_128)) -+ target_flags |= MASK_LONG_DOUBLE_128; -+#endif - } - - #ifdef SUBTARGET_ATTRIBUTE_TABLE -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/config/sparc/t-linux gcc-41-20060515/gcc/config/sparc/t-linux ---- gcc-41-20060515.orig/gcc/config/sparc/t-linux 1969-12-31 18:00:00.000000000 -0600 -+++ gcc-41-20060515/gcc/config/sparc/t-linux 2006-05-15 13:47:27.582270499 -0500 -@@ -0,0 +1,5 @@ -+# Override t-slibgcc-elf-ver to export some libgcc symbols with -+# the symbol versions that glibc used. -+# Avoid the t-linux version file. -+SHLIB_MAPFILES = $(srcdir)/libgcc-std.ver \ -+ $(srcdir)/config/sparc/libgcc-sparc-glibc.ver -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/config/sparc/t-linux64 gcc-41-20060515/gcc/config/sparc/t-linux64 ---- gcc-41-20060515.orig/gcc/config/sparc/t-linux64 2006-05-15 11:13:55.000000000 -0500 -+++ gcc-41-20060515/gcc/config/sparc/t-linux64 2006-05-15 13:47:27.582270499 -0500 -@@ -8,12 +8,6 @@ INSTALL_LIBGCC = install-multilib - EXTRA_MULTILIB_PARTS=crtbegin.o crtend.o crtbeginS.o crtendS.o crtbeginT.o \ - crtfastmath.o - --# Override t-slibgcc-elf-ver to export some libgcc symbols with --# the symbol versions that glibc used. --# Avoid the t-linux version file. --SHLIB_MAPFILES = $(srcdir)/libgcc-std.ver \ -- $(srcdir)/config/sparc/libgcc-sparc-glibc.ver -- - CRTSTUFF_T_CFLAGS = `if test x$$($(GCC_FOR_TARGET) $(MULTILIB_CFLAGS) \ - -print-multi-os-directory) \ - = x../lib64; then echo -mcmodel=medany; fi` -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/config.gcc gcc-41-20060515/gcc/config.gcc ---- gcc-41-20060515.orig/gcc/config.gcc 2006-05-15 11:14:20.000000000 -0500 -+++ gcc-41-20060515/gcc/config.gcc 2006-05-15 13:47:27.555274654 -0500 -@@ -568,7 +568,7 @@ alpha*-*-unicosmk*) - alpha*-*-linux*) - tm_file="${tm_file} alpha/elf.h alpha/linux.h alpha/linux-elf.h" - target_cpu_default="MASK_GAS" -- tmake_file="${tmake_file} alpha/t-crtfm alpha/t-alpha alpha/t-ieee" -+ tmake_file="${tmake_file} alpha/t-crtfm alpha/t-alpha alpha/t-ieee alpha/t-linux" - ;; - alpha*-*-gnu*) - target_cpu_default="MASK_GAS" -@@ -2056,7 +2056,7 @@ sparc-*-elf*) - sparc-*-linux*) # SPARC's running GNU/Linux, libc6 - tm_file="${tm_file} dbxelf.h elfos.h svr4.h sparc/sysv4.h sparc/linux.h" - extra_options="${extra_options} sparc/long-double-switch.opt" -- tmake_file="${tmake_file} sparc/t-crtfm" -+ tmake_file="${tmake_file} sparc/t-linux sparc/t-crtfm" - ;; - sparc-*-rtems*) - tm_file="${tm_file} dbxelf.h elfos.h svr4.h sparc/sysv4.h sparc/sp-elf.h sparc/rtemself.h rtems.h" -@@ -2175,7 +2175,7 @@ sparc64-*-freebsd*|ultrasparc-*-freebsd* - sparc64-*-linux*) # 64-bit SPARC's running GNU/Linux - tm_file="sparc/biarch64.h ${tm_file} dbxelf.h elfos.h svr4.h sparc/sysv4.h sparc/linux64.h" - extra_options="${extra_options} sparc/long-double-switch.opt" -- tmake_file="${tmake_file} sparc/t-linux64 sparc/t-crtfm" -+ tmake_file="${tmake_file} sparc/t-linux sparc/t-linux64 sparc/t-crtfm" - ;; - sparc64-*-netbsd*) - tm_file="sparc/biarch64.h ${tm_file}" -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/config.in gcc-41-20060515/gcc/config.in ---- gcc-41-20060515.orig/gcc/config.in 2006-05-15 11:14:20.000000000 -0500 -+++ gcc-41-20060515/gcc/config.in 2006-05-15 13:47:27.559274038 -0500 -@@ -1277,6 +1277,12 @@ - #endif - - -+/* Define if TFmode long double should be the default */ -+#ifndef USED_FOR_TARGET -+#undef TARGET_DEFAULT_LONG_DOUBLE_128 -+#endif -+ -+ - /* Define if your target C library provides stack protector support */ - #ifndef USED_FOR_TARGET - #undef TARGET_LIBC_PROVIDES_SSP -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/configure gcc-41-20060515/gcc/configure ---- gcc-41-20060515.orig/gcc/configure 2006-05-15 11:14:19.000000000 -0500 -+++ gcc-41-20060515/gcc/configure 2006-05-15 13:47:27.594268652 -0500 -@@ -931,6 +931,7 @@ Optional Packages: - --with-libiconv-prefix[=DIR] search for libiconv in DIR/include and DIR/lib - --without-libiconv-prefix don't search for libiconv in includedir and libdir - --with-system-libunwind use installed libunwind -+ --with-long-double-128 Use 128-bit long double by default. - --with-gc={page,zone} choose the garbage collection mechanism to use - with the compiler - --with-system-zlib use installed libz -@@ -7492,7 +7493,7 @@ if test "${gcc_cv_prog_makeinfo_modern+s - else - ac_prog_version=`$MAKEINFO --version 2>&1 | - sed -n 's/^.*GNU texinfo.* \([0-9][0-9.]*\).*$/\1/p'` -- echo "configure:7495: version of makeinfo is $ac_prog_version" >&5 -+ echo "configure:7496: version of makeinfo is $ac_prog_version" >&5 - case $ac_prog_version in - '') gcc_cv_prog_makeinfo_modern=no;; - 4.[2-9]*) -@@ -16213,6 +16214,46 @@ _ACEOF - - fi - -+# Check if TFmode long double should be used by default or not. -+# Some glibc targets used DFmode long double, but with glibc 2.4 -+# and later they can use TFmode. -+case "$target" in -+ powerpc*-*-*gnu* | \ -+ sparc*-*-linux* | \ -+ s390*-*-linux* | \ -+ alpha*-*-linux*) -+ -+# Check whether --with-long-double-128 or --without-long-double-128 was given. -+if test "${with_long_double_128+set}" = set; then -+ withval="$with_long_double_128" -+ gcc_cv_target_ldbl128="$with_long_double_128" -+else -+ gcc_cv_target_ldbl128=no -+ if test x$host != x$target || test "x$TARGET_SYSTEM_ROOT" != x; then -+ if test "x$with_sysroot" = x; then -+ glibc_header_dir="${exec_prefix}/${target_noncanonical}/sys-include" -+ elif test "x$with_sysroot" = xyes; then -+ glibc_header_dir="${exec_prefix}/${target_noncanonical}/sys-root/usr/include" -+ else -+ glibc_header_dir="${with_sysroot}/usr/include" -+ fi -+ else -+ glibc_header_dir=/usr/include -+ fi -+ grep '^ *#[ ]*define[ ][ ]*__LONG_DOUBLE_MATH_OPTIONAL' \ -+ $glibc_header_dir/bits/wordsize.h > /dev/null 2>&1 \ -+ && gcc_cv_target_ldbl128=yes -+fi; -+ ;; -+esac -+if test x$gcc_cv_target_ldbl128 = xyes; then -+ -+cat >>confdefs.h <<\_ACEOF -+#define TARGET_DEFAULT_LONG_DOUBLE_128 1 -+_ACEOF -+ -+fi -+ - # Find out what GC implementation we want, or may, use. - - # Check whether --with-gc or --without-gc was given. -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/configure.ac gcc-41-20060515/gcc/configure.ac ---- gcc-41-20060515.orig/gcc/configure.ac 2006-05-15 11:14:20.000000000 -0500 -+++ gcc-41-20060515/gcc/configure.ac 2006-05-15 13:47:27.597400000 -0500 -@@ -3130,6 +3130,39 @@ if test x$gcc_cv_libc_provides_ssp = xye - [Define if your target C library provides stack protector support]) - fi - -+# Check if TFmode long double should be used by default or not. -+# Some glibc targets used DFmode long double, but with glibc 2.4 -+# and later they can use TFmode. -+case "$target" in -+ powerpc*-*-*gnu* | \ -+ sparc*-*-linux* | \ -+ s390*-*-linux* | \ -+ alpha*-*-linux*) -+ AC_ARG_WITH(long-double-128, -+[ --with-long-double-128 Use 128-bit long double by default.], -+ gcc_cv_target_ldbl128="$with_long_double_128", -+ [gcc_cv_target_ldbl128=no -+ if test x$host != x$target || test "x$TARGET_SYSTEM_ROOT" != x; then -+ if test "x$with_sysroot" = x; then -+ glibc_header_dir="${exec_prefix}/${target_noncanonical}/sys-include" -+ elif test "x$with_sysroot" = xyes; then -+ glibc_header_dir="${exec_prefix}/${target_noncanonical}/sys-root/usr/include" -+ else -+ glibc_header_dir="${with_sysroot}/usr/include" -+ fi -+ else -+ glibc_header_dir=/usr/include -+ fi -+ grep '^[ ]*#[ ]*define[ ][ ]*__LONG_DOUBLE_MATH_OPTIONAL' \ -+ $glibc_header_dir/bits/wordsize.h > /dev/null 2>&1 \ -+ && gcc_cv_target_ldbl128=yes]) -+ ;; -+esac -+if test x$gcc_cv_target_ldbl128 = xyes; then -+ AC_DEFINE(TARGET_DEFAULT_LONG_DOUBLE_128, 1, -+ [Define if TFmode long double should be the default]) -+fi -+ - # Find out what GC implementation we want, or may, use. - AC_ARG_WITH(gc, - [ --with-gc={page,zone} choose the garbage collection mechanism to use -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/gcc/doc/install.texi gcc-41-20060515/gcc/doc/install.texi ---- gcc-41-20060515.orig/gcc/doc/install.texi 2006-05-15 11:10:10.000000000 -0500 -+++ gcc-41-20060515/gcc/doc/install.texi 2006-05-15 13:47:27.600399538 -0500 -@@ -1224,6 +1224,14 @@ error message. - All support for systems which have been obsoleted in one release of GCC - is removed entirely in the next major release, unless someone steps - forward to maintain the port. -+ -+@item --with-long-double-128 -+Specify if @code{long double} type should be 128-bit by default on selected -+GNU/Linux architectures. If using @code{--without-long-double-128}, -+@code{long double} will be by default 64-bit, the same as @code{double} type. -+When neither of these configure options are used, the default will be -+128-bit @code{long double} when built against GNU C Library 2.4 and later, -+64-bit @code{long double} otherwise. - @end table - - @subheading Cross-Compiler-Specific Options -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/ChangeLog gcc-41-20060515/libstdc++-v3/ChangeLog ---- gcc-41-20060515.orig/libstdc++-v3/ChangeLog 2006-05-15 11:15:42.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/ChangeLog 2006-05-15 14:02:07.401662657 -0500 -@@ -153,6 +153,64 @@ - Likewise. - * docs/html/ext/pb_assoc/tree_assoc_cntnr_node_iterator.html: Likewise. - -+2006-02-07 Jakub Jelinek -+ Benjamin Kosnik -+ -+ PR target/25864 -+ * configure.ac (_GLIBCXX_LONG_DOUBLE_COMPAT): New check. -+ If true, set also port_specific_symbol_files and create -+ as_symver_specs. -+ (GLIBCXX_LDBL_COMPAT): New GLIBCXX_CONDITIONAL. -+ * configure: Rebuilt. -+ * config.h.in: Rebuilt. -+ * config/os/gnu-linux/ldbl-extra.ver: New file. -+ * config/linker-map.gnu: Make sure no __float128 symbols are -+ exported. -+ * include/bits/c++config (_GLIBCXX_LONG_DOUBLE_COMPAT, -+ _GLIBCXX_LDBL_NAMESPACE, _GLIBCXX_BEGIN_LDBL_NAMESPACE, -+ _GLIBCXX_END_LDBL_NAMESPACE): Define. -+ * include/bits/localefwd.h: Use them to conditionally scope facets. -+ * include/bits/locale_facets.h: Surround std::{money,num}_{get,put} -+ with _GLIBCXX_BEGIN_LDBL_NAMESPACE and _GLIBCXX_END_LDBL_NAMESPACE. -+ [_GLIBCXX_LONG_DOUBLE_COMPAT] (std::money_get): Add __do_get method. -+ [_GLIBCXX_LONG_DOUBLE_COMPAT] (std::money_put): Add __do_put method. -+ [_GLIBCXX_LONG_DOUBLE_COMPAT] (std::num_get): Add __do_get method. -+ [_GLIBCXX_LONG_DOUBLE_COMPAT] (std::num_put): Add __do_put method. -+ * include/bits/locale_facets.tcc: Surround std::{money,num}_{get,put} -+ with _GLIBCXX_BEGIN_LDBL_NAMESPACE and _GLIBCXX_END_LDBL_NAMESPACE. -+ (std::money_get::__do_get, std::money_put::__do_put, -+ std::num_get::__do_get, std::num_put::__do_put): New -+ specializations. -+ * include/Makefile.am: Conditionally define -+ _GLIBCXX_LONG_DOUBLE_COMPAT in c++config. -+ * include/Makefile.in: Regenerate. -+ * src/locale.cc [_GLIBCXX_LONG_DOUBLE_COMPAT] (_GLIBCXX_LOC_ID, -+ _GLIBCXX_SYNC_ID): Define, use them. -+ * src/compatibility-ldbl.cc: New file. -+ * src/complex_io.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Add compatibility -+ symbols. -+ * src/limits.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise. -+ * src/locale.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise. -+ * src/locale-inst.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise. -+ * src/locale-misc-inst.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise. -+ * src/istream-inst.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise. -+ * src/ostream-inst.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise. -+ * src/locale.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise. -+ * src/wlocale-inst.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise. -+ * src/compatibility.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise. -+ * config/locale/generic/c_locale.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: -+ Likewise. -+ * config/locale/gnu/c_locale.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: -+ Likewise. -+ * src/Makefile.am (libstdc++-symbol.ver): Append instead of -+ insert in the middle if port specific symbol file requests it. -+ (ldbl_compat_sources): New variable. -+ (sources): Use it. -+ (compatibility-ldbl.lo, compatibility-ldbl.o): New rules. -+ * src/Makefile.in: Rebuilt. -+ * testsuite/testsuite_abi.cc: Recognize GLIBCXX_LDBL_3.4, -+ GLIBCXX_LDBL_3.4.7, CXXABI_LDBL_1.3. -+ - 2006-02-07 Paolo Carlini - - * include/tr1/hashtable: Trivial formatting fixes. -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/config/linker-map.gnu gcc-41-20060515/libstdc++-v3/config/linker-map.gnu ---- gcc-41-20060515.orig/libstdc++-v3/config/linker-map.gnu 2006-05-15 11:15:41.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/config/linker-map.gnu 2006-05-15 13:47:27.603399076 -0500 -@@ -1,6 +1,6 @@ - ## Linker script for GNU ld 2.13.91+ only. - ## --## Copyright (C) 2002, 2003, 2004, 2005 Free Software Foundation, Inc. -+## Copyright (C) 2002, 2003, 2004, 2005, 2006 Free Software Foundation, Inc. - ## - ## This file is part of the libstdc++ version 3 distribution. - ## -@@ -44,7 +44,10 @@ GLIBCXX_3.4 { - std::basic_[j-n]*; - std::basic_o[a-e]*; - # std::basic_ofstream; -- std::basic_o[g-z]*; -+# std::basic_o[g-z]*; -+ std::basic_o[g-r]*; -+ std::basic_ostr[a-d]*; -+ std::basic_ostr[f-z]*; - std::basic_[p-r]*; - std::basic_streambuf*; - # std::basic_string -@@ -88,7 +91,14 @@ GLIBCXX_3.4 { - std::locale::_[J-Ra-z]*; - std::locale::_S_normalize_category*; - std::locale::_[T-Za-z]*; -- std::[A-Zm-r]*; -+# std::[A-Zm-r]*; -+ std::[A-Zmp-r]*; -+ std::n[^u]*; -+ std::nu[^m]*; -+ std::num[^e]*; -+ std::ostrstream*; -+ std::out_of_range*; -+ std::overflow_error*; - std::set_new_handler*; - std::set_terminate*; - std::set_unexpected*; -@@ -256,7 +266,7 @@ GLIBCXX_3.4 { - _ZNSi[0-9][a-h]*; - _ZNSi[0-9][j-z]*; - _ZNSi6ignoreE[il][il]; -- _ZNSirsE*; -+ _ZNSirsE*[^g]; - - # std::basic_istream - _ZNSt13basic_istreamIwSt11char_traitsIwEEC*; -@@ -265,7 +275,7 @@ GLIBCXX_3.4 { - _ZNSt13basic_istreamIwSt11char_traitsIwEE[0-9][a-h]*; - _ZNSt13basic_istreamIwSt11char_traitsIwEE[0-9][j-z]*; - _ZNSt13basic_istreamIwSt11char_traitsIwEE6ignoreE[il][ijlm]; -- _ZNSt13basic_istreamIwSt11char_traitsIwEErsE*; -+ _ZNSt13basic_istreamIwSt11char_traitsIwEErsE*[^g]; - - # std::istream operators and inserters - _ZSt7getlineI[cw]St11char_traitsI[cw]ESaI[cw]EERSt13basic_istream*; -@@ -277,6 +287,37 @@ GLIBCXX_3.4 { - _ZStrsIe[cw]St11char_traitsI[cw]EERSt13basic_istream*; - _ZStrsIf[cw]St11char_traitsI[cw]EERSt13basic_istream*; - -+ # std::basic_ostream -+ _ZNSoC*; -+ _ZNSoD*; -+ _ZNKSo6sentrycvbEv; -+ _ZNSo8_M_write*; -+ _ZNSo[0-9][a-z]*; -+ _ZNSolsE*[^g]; -+ -+ # std::basic_ostream -+ _ZNSt13basic_ostreamIwSt11char_traitsIwEEC*; -+ _ZNSt13basic_ostreamIwSt11char_traitsIwEED*; -+ _ZNKSt13basic_ostreamIwSt11char_traitsIwEE[0-9][a-z]*; -+ _ZNSt13basic_ostreamIwSt11char_traitsIwEE3putEw; -+ _ZNSt13basic_ostreamIwSt11char_traitsIwEE5flushEv; -+ _ZNSt13basic_ostreamIwSt11char_traitsIwEE5seekpE*; -+ _ZNSt13basic_ostreamIwSt11char_traitsIwEE5tellpEv; -+ _ZNSt13basic_ostreamIwSt11char_traitsIwEE5writeEPKw*; -+ _ZNSt13basic_ostreamIwSt11char_traitsIwEE6sentry*; -+ _ZNSt13basic_ostreamIwSt11char_traitsIwEE8_M_write*; -+ _ZNSt13basic_ostreamIwSt11char_traitsIwEElsE*[^g]; -+ -+ # std::ostream operators and inserters -+ _ZSt4end[ls]I[cw]St11char_traitsI[cw]EERSt13basic_ostream*; -+ _ZSt5flushI[cw]St11char_traitsI[cw]EERSt13basic_ostream*; -+ _ZStlsI[cw]St11char_traitsI[cw]EERSt13basic_ostream*; -+ _ZStlsI[cw]St11char_traitsI[cw]ESaI[cw]EERSt13basic_ostream*; -+ _ZStlsISt11char_traitsI[cw]EERSt13basic_ostream*; -+ _ZStlsId[cw]St11char_traitsI[cw]EERSt13basic_ostream*; -+ _ZStlsIe[cw]St11char_traitsI[cw]EERSt13basic_ostream*; -+ _ZStlsIf[cw]St11char_traitsI[cw]EERSt13basic_ostream*; -+ - # std::locale destructors - _ZNSt6localeD*; - -@@ -292,14 +333,23 @@ GLIBCXX_3.4 { - _ZNSt8ios_base4InitD*; - - # bool std::has_facet -- _ZSt9has_facet*; -+ _ZSt9has_facetIS*; - - # std::num_get - _ZNKSt7num_getI[cw]St19istreambuf_iteratorI[cw]St11char_traitsI[cw]EEE*; - -+ # std::num_put -+ _ZNKSt7num_putI[cw]St19ostreambuf_iteratorI[cw]St11char_traitsI[cw]EEE*; -+ - # std::money_get - _ZNKSt9money_getI[cw]St19istreambuf_iteratorI[cw]St11char_traitsI[cw]EEE*; - -+ # std::money_put -+ _ZNKSt9money_putI[cw]St19ostreambuf_iteratorI[cw]St11char_traitsI[cw]EEE*; -+ -+ # std::numeric_limits -+ _ZNSt14numeric_limitsI[^g]*; -+ - # std::_Rb_tree - _ZSt18_Rb_tree_decrementPKSt18_Rb_tree_node_base; - _ZSt18_Rb_tree_decrementPSt18_Rb_tree_node_base; -@@ -327,7 +377,7 @@ GLIBCXX_3.4 { - _ZNSt12__basic_fileIcED*; - - # std::__convert_to_v -- _ZSt14__convert_to_v*; -+ _ZSt14__convert_to_vI[^g]*; - - # __gnu_cxx::stdio_sync_filebuf - _ZTVN9__gnu_cxx18stdio_sync_filebufI[cw]St11char_traitsI[cw]EEE; -@@ -399,7 +449,8 @@ GLIBCXX_3.4 { - _ZTSN9__gnu_cxx13stdio_filebufI[cw]St11char_traitsI[cw]EEE; - - # function-scope static objects requires a guard variable. -- _ZGVNSt*; -+ _ZGVNSt[^1]*; -+ _ZGVNSt1[^7]*; - - # virtual function thunks - _ZThn8_NS*; -@@ -665,9 +716,9 @@ CXXABI_1.3 { - _ZTVN10__cxxabiv121__vmi_class_type_infoE; - - # typeinfo structure (and some names) -- _ZTI[a-z]; -- _ZTIP[a-z]; -- _ZTIPK[a-z]; -+ _ZTI[a-fh-z]; -+ _ZTIP[a-fh-z]; -+ _ZTIPK[a-fh-z]; - _ZTIN10__cxxabiv117__array_type_infoE; - _ZTIN10__cxxabiv117__class_type_infoE; - _ZTIN10__cxxabiv116__enum_type_infoE; -@@ -680,9 +731,9 @@ CXXABI_1.3 { - _ZTIN10__cxxabiv121__vmi_class_type_infoE; - - # typeinfo name -- _ZTS[a-z]; -- _ZTSP[a-z]; -- _ZTSPK[a-z]; -+ _ZTS[a-fh-z]; -+ _ZTSP[a-fh-z]; -+ _ZTSPK[a-fh-z]; - _ZTSN10__cxxabiv117__array_type_infoE; - _ZTSN10__cxxabiv117__class_type_infoE; - _ZTSN10__cxxabiv116__enum_type_infoE; -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/config/locale/generic/c_locale.cc gcc-41-20060515/libstdc++-v3/config/locale/generic/c_locale.cc ---- gcc-41-20060515.orig/libstdc++-v3/config/locale/generic/c_locale.cc 2006-05-15 11:15:39.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/config/locale/generic/c_locale.cc 2006-05-15 13:47:27.605398768 -0500 -@@ -1,6 +1,6 @@ - // Wrapper for underlying C-language localization -*- C++ -*- - --// Copyright (C) 2001, 2002, 2003, 2004, 2005 -+// Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006 - // Free Software Foundation, Inc. - // - // This file is part of the GNU ISO C++ Library. This library is free -@@ -168,3 +168,10 @@ namespace std - { - const char* const* const locale::_S_categories = __gnu_cxx::category_names; - } // namespace std -+ -+// XXX GLIBCXX_ABI Deprecated -+#ifdef _GLIBCXX_LONG_DOUBLE_COMPAT -+#define _GLIBCXX_LDBL_COMPAT(dbl, ldbl) \ -+ extern "C" void ldbl (void) __attribute__ ((alias (#dbl))) -+_GLIBCXX_LDBL_COMPAT(_ZSt14__convert_to_vIdEvPKcRT_RSt12_Ios_IostateRKPi, _ZSt14__convert_to_vIeEvPKcRT_RSt12_Ios_IostateRKPi); -+#endif // _GLIBCXX_LONG_DOUBLE_COMPAT -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/config/locale/gnu/c_locale.cc gcc-41-20060515/libstdc++-v3/config/locale/gnu/c_locale.cc ---- gcc-41-20060515.orig/libstdc++-v3/config/locale/gnu/c_locale.cc 2006-05-15 11:15:39.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/config/locale/gnu/c_locale.cc 2006-05-15 13:47:27.606398615 -0500 -@@ -1,6 +1,6 @@ - // Wrapper for underlying C-language localization -*- C++ -*- - --// Copyright (C) 2001, 2002, 2003, 2004, 2005 -+// Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006 - // Free Software Foundation, Inc. - // - // This file is part of the GNU ISO C++ Library. This library is free -@@ -132,3 +132,10 @@ namespace std - { - const char* const* const locale::_S_categories = __gnu_cxx::category_names; - } // namespace std -+ -+// XXX GLIBCXX_ABI Deprecated -+#ifdef _GLIBCXX_LONG_DOUBLE_COMPAT -+#define _GLIBCXX_LDBL_COMPAT(dbl, ldbl) \ -+ extern "C" void ldbl (void) __attribute__ ((alias (#dbl))) -+_GLIBCXX_LDBL_COMPAT(_ZSt14__convert_to_vIdEvPKcRT_RSt12_Ios_IostateRKP15__locale_struct, _ZSt14__convert_to_vIeEvPKcRT_RSt12_Ios_IostateRKP15__locale_struct); -+#endif // _GLIBCXX_LONG_DOUBLE_COMPAT -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/config/os/gnu-linux/ldbl-extra.ver gcc-41-20060515/libstdc++-v3/config/os/gnu-linux/ldbl-extra.ver ---- gcc-41-20060515.orig/libstdc++-v3/config/os/gnu-linux/ldbl-extra.ver 1969-12-31 18:00:00.000000000 -0600 -+++ gcc-41-20060515/libstdc++-v3/config/os/gnu-linux/ldbl-extra.ver 2006-05-15 13:47:27.606398615 -0500 -@@ -0,0 +1,19 @@ -+# Appended to version file. -+ -+GLIBCXX_LDBL_3.4 { -+ _ZNSt14numeric_limitsIg*; -+ _ZNSirsERg; -+ _ZNSolsEg; -+ _ZNSt13basic_istreamIwSt11char_traitsIwEErsERg; -+ _ZNSt13basic_ostreamIwSt11char_traitsIwEElsEg; -+ _ZSt14__convert_to_vIgEvPKcRT_RSt12_Ios_IostateRKP*; -+ _ZStlsIg[cw]St11char_traitsI[cw]EERSt13basic_ostreamIT0_T1_ES6_RKSt7complexIT_E; -+ _ZStrsIg[cw]St11char_traitsI[cw]EERSt13basic_istreamIT0_T1_ES6_RSt7complexIT_E; -+ *__gnu_cxx_ldbl128*; -+}; -+ -+CXXABI_LDBL_1.3 { -+ _ZT[IS]g; -+ _ZT[IS]Pg; -+ _ZT[IS]PKg; -+}; -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/config.h.in gcc-41-20060515/libstdc++-v3/config.h.in ---- gcc-41-20060515.orig/libstdc++-v3/config.h.in 2006-05-15 11:15:42.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/config.h.in 2006-05-15 13:47:27.601399384 -0500 -@@ -658,6 +658,9 @@ - /* Define to 1 if a full hosted library is built, or 0 if freestanding. */ - #undef _GLIBCXX_HOSTED - -+/* Define if compatibility should be provided for -mlong-double-64. */ -+#undef _GLIBCXX_LONG_DOUBLE_COMPAT -+ - /* Define if ptrdiff_t is int. */ - #undef _GLIBCXX_PTRDIFF_T_IS_INT - -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/configure gcc-41-20060515/libstdc++-v3/configure ---- gcc-41-20060515.orig/libstdc++-v3/configure 2006-05-15 11:15:42.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/configure 2006-05-15 13:47:27.664389689 -0500 -@@ -309,7 +309,7 @@ ac_includes_default="\ - # include - #endif" - --ac_subst_vars='SHELL PATH_SEPARATOR PACKAGE_NAME PACKAGE_TARNAME PACKAGE_VERSION PACKAGE_STRING PACKAGE_BUGREPORT exec_prefix prefix program_transform_name bindir sbindir libexecdir datadir sysconfdir sharedstatedir localstatedir libdir includedir oldincludedir infodir mandir build_alias host_alias target_alias DEFS ECHO_C ECHO_N ECHO_T LIBS libtool_VERSION multi_basedir build build_cpu build_vendor build_os host host_cpu host_vendor host_os target target_cpu target_vendor target_os INSTALL_PROGRAM INSTALL_SCRIPT INSTALL_DATA CYGPATH_W PACKAGE VERSION ACLOCAL AUTOCONF AUTOMAKE AUTOHEADER MAKEINFO install_sh STRIP ac_ct_STRIP INSTALL_STRIP_PROGRAM mkdir_p AWK SET_MAKE am__leading_dot AMTAR am__tar am__untar glibcxx_builddir glibcxx_srcdir toplevel_srcdir CC ac_ct_CC EXEEXT OBJEXT CXX ac_ct_CXX CFLAGS CXXFLAGS LN_S AS ac_ct_AS AR ac_ct_AR RANLIB ac_ct_RANLIB MAINTAINER_MODE_TRUE MAINTAINER_MODE_FALSE MAINT LIBTOOL CXXCPP CPPFLAGS enable_shared enable_static GLIBCXX_HOSTED_TRUE GLIBCXX_HOSTED_FALSE GLIBCXX_BUILD_PCH_TRUE GLIBCXX_BUILD_PCH_FALSE glibcxx_PCHFLAGS CSTDIO_H BASIC_FILE_H BASIC_FILE_CC CPP EGREP check_msgfmt glibcxx_MOFILES glibcxx_POFILES glibcxx_localedir USE_NLS CLOCALE_H CMESSAGES_H CCODECVT_CC CCOLLATE_CC CCTYPE_CC CMESSAGES_CC CMONEY_CC CNUMERIC_CC CTIME_H CTIME_CC CLOCALE_CC CLOCALE_INTERNAL_H ALLOCATOR_H ALLOCATOR_NAME C_INCLUDE_DIR GLIBCXX_C_HEADERS_C_TRUE GLIBCXX_C_HEADERS_C_FALSE GLIBCXX_C_HEADERS_C_STD_TRUE GLIBCXX_C_HEADERS_C_STD_FALSE GLIBCXX_C_HEADERS_COMPATIBILITY_TRUE GLIBCXX_C_HEADERS_COMPATIBILITY_FALSE DEBUG_FLAGS GLIBCXX_BUILD_DEBUG_TRUE GLIBCXX_BUILD_DEBUG_FALSE EXTRA_CXX_FLAGS glibcxx_thread_h WERROR SECTION_FLAGS SECTION_LDFLAGS OPT_LDFLAGS LIBMATHOBJS LIBICONV SYMVER_MAP port_specific_symbol_files ENABLE_SYMVERS_GNU_TRUE ENABLE_SYMVERS_GNU_FALSE ENABLE_SYMVERS_DARWIN_EXPORT_TRUE ENABLE_SYMVERS_DARWIN_EXPORT_FALSE baseline_dir ATOMICITY_SRCDIR ATOMIC_WORD_SRCDIR CPU_DEFINES_SRCDIR ABI_TWEAKS_SRCDIR OS_INC_SRCDIR glibcxx_prefixdir gxx_include_dir glibcxx_toolexecdir glibcxx_toolexeclibdir GLIBCXX_INCLUDES TOPLEVEL_INCLUDES OPTIMIZE_CXXFLAGS WARN_FLAGS LIBSUPCXX_PICFLAGS LIBOBJS LTLIBOBJS' -+ac_subst_vars='SHELL PATH_SEPARATOR PACKAGE_NAME PACKAGE_TARNAME PACKAGE_VERSION PACKAGE_STRING PACKAGE_BUGREPORT exec_prefix prefix program_transform_name bindir sbindir libexecdir datadir sysconfdir sharedstatedir localstatedir libdir includedir oldincludedir infodir mandir build_alias host_alias target_alias DEFS ECHO_C ECHO_N ECHO_T LIBS libtool_VERSION multi_basedir build build_cpu build_vendor build_os host host_cpu host_vendor host_os target target_cpu target_vendor target_os INSTALL_PROGRAM INSTALL_SCRIPT INSTALL_DATA CYGPATH_W PACKAGE VERSION ACLOCAL AUTOCONF AUTOMAKE AUTOHEADER MAKEINFO install_sh STRIP ac_ct_STRIP INSTALL_STRIP_PROGRAM mkdir_p AWK SET_MAKE am__leading_dot AMTAR am__tar am__untar glibcxx_builddir glibcxx_srcdir toplevel_srcdir CC ac_ct_CC EXEEXT OBJEXT CXX ac_ct_CXX CFLAGS CXXFLAGS LN_S AS ac_ct_AS AR ac_ct_AR RANLIB ac_ct_RANLIB MAINTAINER_MODE_TRUE MAINTAINER_MODE_FALSE MAINT LIBTOOL CXXCPP CPPFLAGS enable_shared enable_static GLIBCXX_HOSTED_TRUE GLIBCXX_HOSTED_FALSE GLIBCXX_BUILD_PCH_TRUE GLIBCXX_BUILD_PCH_FALSE glibcxx_PCHFLAGS CSTDIO_H BASIC_FILE_H BASIC_FILE_CC CPP EGREP check_msgfmt glibcxx_MOFILES glibcxx_POFILES glibcxx_localedir USE_NLS CLOCALE_H CMESSAGES_H CCODECVT_CC CCOLLATE_CC CCTYPE_CC CMESSAGES_CC CMONEY_CC CNUMERIC_CC CTIME_H CTIME_CC CLOCALE_CC CLOCALE_INTERNAL_H ALLOCATOR_H ALLOCATOR_NAME C_INCLUDE_DIR GLIBCXX_C_HEADERS_C_TRUE GLIBCXX_C_HEADERS_C_FALSE GLIBCXX_C_HEADERS_C_STD_TRUE GLIBCXX_C_HEADERS_C_STD_FALSE GLIBCXX_C_HEADERS_COMPATIBILITY_TRUE GLIBCXX_C_HEADERS_COMPATIBILITY_FALSE DEBUG_FLAGS GLIBCXX_BUILD_DEBUG_TRUE GLIBCXX_BUILD_DEBUG_FALSE EXTRA_CXX_FLAGS glibcxx_thread_h WERROR SECTION_FLAGS SECTION_LDFLAGS OPT_LDFLAGS LIBMATHOBJS LIBICONV SYMVER_MAP port_specific_symbol_files ENABLE_SYMVERS_GNU_TRUE ENABLE_SYMVERS_GNU_FALSE ENABLE_SYMVERS_DARWIN_EXPORT_TRUE ENABLE_SYMVERS_DARWIN_EXPORT_FALSE GLIBCXX_LDBL_COMPAT_TRUE GLIBCXX_LDBL_COMPAT_FALSE baseline_dir ATOMICITY_SRCDIR ATOMIC_WORD_SRCDIR CPU_DEFINES_SRCDIR ABI_TWEAKS_SRCDIR OS_INC_SRCDIR glibcxx_prefixdir gxx_include_dir glibcxx_toolexecdir glibcxx_toolexeclibdir GLIBCXX_INCLUDES TOPLEVEL_INCLUDES OPTIMIZE_CXXFLAGS WARN_FLAGS LIBSUPCXX_PICFLAGS LIBOBJS LTLIBOBJS' - ac_subst_files='' - - # Initialize some variables set by options. -@@ -87959,6 +87959,72 @@ echo "${ECHO_T}$glibcxx_ptrdiff_t_is_i" - echo "$as_me: versioning on shared library symbols is $enable_symvers" >&6;} - - -+ac_ldbl_compat=no -+case "$target" in -+ powerpc*-*-*gnu* | \ -+ sparc*-*-linux* | \ -+ s390*-*-linux* | \ -+ alpha*-*-linux*) -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+int -+main () -+{ -+ -+#if !defined __LONG_DOUBLE_128__ || (defined(__sparc__) && defined(__arch64__)) -+#error no need for long double compatibility -+#endif -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_ldbl_compat=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_ldbl_compat=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ if test "$ac_ldbl_compat" = yes; then -+ -+cat >>confdefs.h <<\_ACEOF -+#define _GLIBCXX_LONG_DOUBLE_COMPAT 1 -+_ACEOF -+ -+ port_specific_symbol_files="\$(top_srcdir)/config/os/gnu-linux/ldbl-extra.ver" -+ fi -+esac -+ -+ - # This depends on GLIBCXX_ENABLE_SYMVERS and GLIBCXX_IS_NATIVE. - - if $GLIBCXX_IS_NATIVE ; then -@@ -88811,6 +88877,17 @@ fi - - - -+if test $ac_ldbl_compat = yes; then -+ GLIBCXX_LDBL_COMPAT_TRUE= -+ GLIBCXX_LDBL_COMPAT_FALSE='#' -+else -+ GLIBCXX_LDBL_COMPAT_TRUE='#' -+ GLIBCXX_LDBL_COMPAT_FALSE= -+fi -+ -+ -+ -+ - cat >confcache <<\_ACEOF - # This file is a shell script that caches the results of configure - # tests run on this system so they can be shared between configure -@@ -89166,6 +89243,13 @@ echo "$as_me: error: conditional \"ENABL - Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } - fi -+if test -z "${GLIBCXX_LDBL_COMPAT_TRUE}" && test -z "${GLIBCXX_LDBL_COMPAT_FALSE}"; then -+ { { echo "$as_me:$LINENO: error: conditional \"GLIBCXX_LDBL_COMPAT\" was never defined. -+Usually this means the macro was only invoked conditionally." >&5 -+echo "$as_me: error: conditional \"GLIBCXX_LDBL_COMPAT\" was never defined. -+Usually this means the macro was only invoked conditionally." >&2;} -+ { (exit 1); exit 1; }; } -+fi - - : ${CONFIG_STATUS=./config.status} - ac_clean_files_save=$ac_clean_files -@@ -89836,6 +89920,8 @@ s,@ENABLE_SYMVERS_GNU_TRUE@,$ENABLE_SYMV - s,@ENABLE_SYMVERS_GNU_FALSE@,$ENABLE_SYMVERS_GNU_FALSE,;t t - s,@ENABLE_SYMVERS_DARWIN_EXPORT_TRUE@,$ENABLE_SYMVERS_DARWIN_EXPORT_TRUE,;t t - s,@ENABLE_SYMVERS_DARWIN_EXPORT_FALSE@,$ENABLE_SYMVERS_DARWIN_EXPORT_FALSE,;t t -+s,@GLIBCXX_LDBL_COMPAT_TRUE@,$GLIBCXX_LDBL_COMPAT_TRUE,;t t -+s,@GLIBCXX_LDBL_COMPAT_FALSE@,$GLIBCXX_LDBL_COMPAT_FALSE,;t t - s,@baseline_dir@,$baseline_dir,;t t - s,@ATOMICITY_SRCDIR@,$ATOMICITY_SRCDIR,;t t - s,@ATOMIC_WORD_SRCDIR@,$ATOMIC_WORD_SRCDIR,;t t -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/configure.ac gcc-41-20060515/libstdc++-v3/configure.ac ---- gcc-41-20060515.orig/libstdc++-v3/configure.ac 2006-05-15 11:15:42.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/configure.ac 2006-05-15 13:47:27.665389535 -0500 -@@ -281,6 +281,25 @@ fi - # This depends on GLIBCXX CHECK_LINKER_FEATURES, but without it assumes no. - GLIBCXX_ENABLE_SYMVERS([yes]) - -+ac_ldbl_compat=no -+case "$target" in -+ powerpc*-*-*gnu* | \ -+ sparc*-*-linux* | \ -+ s390*-*-linux* | \ -+ alpha*-*-linux*) -+ AC_TRY_COMPILE(, [ -+#if !defined __LONG_DOUBLE_128__ || (defined(__sparc__) && defined(__arch64__)) -+#error no need for long double compatibility -+#endif -+ ], [ac_ldbl_compat=yes], [ac_ldbl_compat=no]) -+ if test "$ac_ldbl_compat" = yes; then -+ AC_DEFINE([_GLIBCXX_LONG_DOUBLE_COMPAT],1, -+ [Define if compatibility should be provided for -mlong-double-64.]) -+ port_specific_symbol_files="\$(top_srcdir)/config/os/gnu-linux/ldbl-extra.ver" -+ fi -+esac -+GLIBCXX_CONDITIONAL(GLIBCXX_LDBL_COMPAT, test $ac_ldbl_compat = yes) -+ - # This depends on GLIBCXX_ENABLE_SYMVERS and GLIBCXX_IS_NATIVE. - GLIBCXX_CONFIGURE_TESTSUITE - -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/include/bits/c++config gcc-41-20060515/libstdc++-v3/include/bits/c++config ---- gcc-41-20060515.orig/libstdc++-v3/include/bits/c++config 2006-05-15 11:14:38.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/include/bits/c++config 2006-05-15 13:47:27.668389073 -0500 -@@ -1,6 +1,6 @@ - // Predefined symbols and macros -*- C++ -*- - --// Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005 -+// Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006 - // Free Software Foundation, Inc. - // - // This file is part of the GNU ISO C++ Library. This library is free -@@ -65,6 +65,26 @@ namespace std - # define _GLIBCXX_STD std - #endif - -+/* Define if compatibility should be provided for -mlong-double-64. */ -+#undef _GLIBCXX_LONG_DOUBLE_COMPAT -+ -+// XXX GLIBCXX_ABI Deprecated -+// Namespace associations for long double 128 mode. -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -+# define _GLIBCXX_LDBL_NAMESPACE __gnu_cxx_ldbl128:: -+# define _GLIBCXX_BEGIN_LDBL_NAMESPACE namespace __gnu_cxx_ldbl128 { -+# define _GLIBCXX_END_LDBL_NAMESPACE } -+namespace std -+{ -+ namespace __gnu_cxx_ldbl128 { } -+ using namespace __gnu_cxx_ldbl128 __attribute__((__strong__)); -+} -+#else -+# define _GLIBCXX_LDBL_NAMESPACE -+# define _GLIBCXX_BEGIN_LDBL_NAMESPACE -+# define _GLIBCXX_END_LDBL_NAMESPACE -+#endif -+ - // Allow use of "export template." This is currently not a feature - // that g++ supports. - // #define _GLIBCXX_EXPORT_TEMPLATE 1 -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/include/bits/locale_facets.h gcc-41-20060515/libstdc++-v3/include/bits/locale_facets.h ---- gcc-41-20060515.orig/libstdc++-v3/include/bits/locale_facets.h 2006-05-15 11:14:38.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/include/bits/locale_facets.h 2006-05-15 13:47:27.673388304 -0500 -@@ -1,6 +1,6 @@ - // Locale support -*- C++ -*- - --// Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005 -+// Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006 - // Free Software Foundation, Inc. - // - // This file is part of the GNU ISO C++ Library. This library is free -@@ -1910,6 +1910,7 @@ namespace std - ~numpunct_byname() { } - }; - -+_GLIBCXX_BEGIN_LDBL_NAMESPACE - /** - * @brief Facet for parsing number strings. - * -@@ -2176,13 +2177,27 @@ namespace std - do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, - double&) const; - -+ // XXX GLIBCXX_ABI Deprecated -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -+ virtual iter_type -+ __do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, -+ double&) const; -+#else - virtual iter_type - do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, - long double&) const; -+#endif - - virtual iter_type - do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, - void*&) const; -+ -+ // XXX GLIBCXX_ABI Deprecated -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -+ virtual iter_type -+ do_get(iter_type, iter_type, ios_base&, ios_base::iostate& __err, -+ long double&) const; -+#endif - //@} - }; - -@@ -2438,17 +2453,30 @@ namespace std - virtual iter_type - do_put(iter_type, ios_base&, char_type __fill, double __v) const; - -+ // XXX GLIBCXX_ABI Deprecated -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -+ virtual iter_type -+ __do_put(iter_type, ios_base&, char_type __fill, double __v) const; -+#else - virtual iter_type - do_put(iter_type, ios_base&, char_type __fill, long double __v) const; -+#endif - - virtual iter_type - do_put(iter_type, ios_base&, char_type __fill, const void* __v) const; -+ -+ // XXX GLIBCXX_ABI Deprecated -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -+ virtual iter_type -+ do_put(iter_type, ios_base&, char_type __fill, long double __v) const; -+#endif - //@} - }; - - template - locale::id num_put<_CharT, _OutIter>::id; - -+_GLIBCXX_END_LDBL_NAMESPACE - - /** - * @brief Facet for localized string comparison. -@@ -3953,6 +3981,7 @@ namespace std - template - const bool moneypunct_byname<_CharT, _Intl>::intl; - -+_GLIBCXX_BEGIN_LDBL_NAMESPACE - /** - * @brief Facet for parsing monetary amounts. - * -@@ -4064,9 +4093,16 @@ namespace std - * value. This function is a hook for derived classes to change the - * value returned. @see get() for details. - */ -+ // XXX GLIBCXX_ABI Deprecated -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -+ virtual iter_type -+ __do_get(iter_type __s, iter_type __end, bool __intl, ios_base& __io, -+ ios_base::iostate& __err, double& __units) const; -+#else - virtual iter_type - do_get(iter_type __s, iter_type __end, bool __intl, ios_base& __io, - ios_base::iostate& __err, long double& __units) const; -+#endif - - /** - * @brief Read and parse a monetary value. -@@ -4079,6 +4115,13 @@ namespace std - do_get(iter_type __s, iter_type __end, bool __intl, ios_base& __io, - ios_base::iostate& __err, string_type& __digits) const; - -+ // XXX GLIBCXX_ABI Deprecated -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -+ virtual iter_type -+ do_get(iter_type __s, iter_type __end, bool __intl, ios_base& __io, -+ ios_base::iostate& __err, long double& __units) const; -+#endif -+ - template - iter_type - _M_extract(iter_type __s, iter_type __end, ios_base& __io, -@@ -4191,9 +4234,16 @@ namespace std - * @param units Place to store result of parsing. - * @return Iterator after writing. - */ -+ // XXX GLIBCXX_ABI Deprecated -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -+ virtual iter_type -+ __do_put(iter_type __s, bool __intl, ios_base& __io, char_type __fill, -+ double __units) const; -+#else - virtual iter_type - do_put(iter_type __s, bool __intl, ios_base& __io, char_type __fill, - long double __units) const; -+#endif - - /** - * @brief Format and output a monetary value. -@@ -4217,6 +4267,13 @@ namespace std - do_put(iter_type __s, bool __intl, ios_base& __io, char_type __fill, - const string_type& __digits) const; - -+ // XXX GLIBCXX_ABI Deprecated -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -+ virtual iter_type -+ do_put(iter_type __s, bool __intl, ios_base& __io, char_type __fill, -+ long double __units) const; -+#endif -+ - template - iter_type - _M_insert(iter_type __s, ios_base& __io, char_type __fill, -@@ -4226,6 +4283,8 @@ namespace std - template - locale::id money_put<_CharT, _OutIter>::id; - -+_GLIBCXX_END_LDBL_NAMESPACE -+ - /** - * @brief Messages facet base class providing catalog typedef. - */ -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/include/bits/locale_facets.tcc gcc-41-20060515/libstdc++-v3/include/bits/locale_facets.tcc ---- gcc-41-20060515.orig/libstdc++-v3/include/bits/locale_facets.tcc 2006-05-15 11:14:38.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/include/bits/locale_facets.tcc 2006-05-15 13:47:27.676387842 -0500 -@@ -1,6 +1,6 @@ - // Locale support -*- C++ -*- - --// Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005 -+// Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006 - // Free Software Foundation, Inc. - // - // This file is part of the GNU ISO C++ Library. This library is free -@@ -272,6 +272,8 @@ namespace std - __verify_grouping(const char* __grouping, size_t __grouping_size, - const string& __grouping_tmp); - -+_GLIBCXX_BEGIN_LDBL_NAMESPACE -+ - template - _InIter - num_get<_CharT, _InIter>:: -@@ -446,6 +448,8 @@ namespace std - return __beg; - } - -+_GLIBCXX_END_LDBL_NAMESPACE -+ - template - struct __to_unsigned_type - { typedef _ValueT __type; }; -@@ -460,6 +464,8 @@ namespace std - { typedef unsigned long long __type; }; - #endif - -+_GLIBCXX_BEGIN_LDBL_NAMESPACE -+ - template - template - _InIter -@@ -772,6 +778,21 @@ namespace std - return __beg; - } - -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -+ template -+ _InIter -+ num_get<_CharT, _InIter>:: -+ __do_get(iter_type __beg, iter_type __end, ios_base& __io, -+ ios_base::iostate& __err, double& __v) const -+ { -+ string __xtrc; -+ __xtrc.reserve(32); -+ __beg = _M_extract_float(__beg, __end, __io, __err, __xtrc); -+ std::__convert_to_v(__xtrc.c_str(), __v, __err, _S_get_c_locale()); -+ return __beg; -+ } -+#endif -+ - template - _InIter - num_get<_CharT, _InIter>:: -@@ -822,6 +843,8 @@ namespace std - __len = static_cast(__w); - } - -+_GLIBCXX_END_LDBL_NAMESPACE -+ - // Forwarding functions to peel signed from unsigned integer types and - // either cast or compute the absolute value for the former, depending - // on __basefield. -@@ -911,6 +934,8 @@ namespace std - return __bufend - __buf; - } - -+_GLIBCXX_BEGIN_LDBL_NAMESPACE -+ - template - void - num_put<_CharT, _OutIter>:: -@@ -1233,6 +1258,14 @@ namespace std - do_put(iter_type __s, ios_base& __io, char_type __fill, double __v) const - { return _M_insert_float(__s, __io, __fill, char(), __v); } - -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -+ template -+ _OutIter -+ num_put<_CharT, _OutIter>:: -+ __do_put(iter_type __s, ios_base& __io, char_type __fill, double __v) const -+ { return _M_insert_float(__s, __io, __fill, char(), __v); } -+#endif -+ - template - _OutIter - num_put<_CharT, _OutIter>:: -@@ -1474,6 +1507,23 @@ namespace std - return __beg; - } - -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -+ template -+ _InIter -+ money_get<_CharT, _InIter>:: -+ __do_get(iter_type __beg, iter_type __end, bool __intl, ios_base& __io, -+ ios_base::iostate& __err, double& __units) const -+ { -+ string __str; -+ if (__intl) -+ __beg = _M_extract(__beg, __end, __io, __err, __str); -+ else -+ __beg = _M_extract(__beg, __end, __io, __err, __str); -+ std::__convert_to_v(__str.c_str(), __units, __err, _S_get_c_locale()); -+ return __beg; -+ } -+#endif -+ - template - _InIter - money_get<_CharT, _InIter>:: -@@ -1678,7 +1728,18 @@ namespace std - __io.width(0); - return __s; - } -- -+ -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ -+ template -+ _OutIter -+ money_put<_CharT, _OutIter>:: -+ __do_put(iter_type __s, bool __intl, ios_base& __io, char_type __fill, -+ double __units) const -+ { -+ return this->do_put(__s, __intl, __io, __fill, (long double) __units); -+ } -+#endif -+ - template - _OutIter - money_put<_CharT, _OutIter>:: -@@ -1726,6 +1787,7 @@ namespace std - { return __intl ? _M_insert(__s, __io, __fill, __digits) - : _M_insert(__s, __io, __fill, __digits); } - -+_GLIBCXX_END_LDBL_NAMESPACE - - // NB: Not especially useful. Without an ios_base object or some - // kind of locale reference, we are left clawing at the air where -@@ -2511,12 +2573,12 @@ namespace std - extern template class moneypunct; - extern template class moneypunct_byname; - extern template class moneypunct_byname; -- extern template class money_get; -- extern template class money_put; -+ extern template class _GLIBCXX_LDBL_NAMESPACE money_get; -+ extern template class _GLIBCXX_LDBL_NAMESPACE money_put; - extern template class numpunct; - extern template class numpunct_byname; -- extern template class num_get; -- extern template class num_put; -+ extern template class _GLIBCXX_LDBL_NAMESPACE num_get; -+ extern template class _GLIBCXX_LDBL_NAMESPACE num_put; - extern template class __timepunct; - extern template class time_put; - extern template class time_put_byname; -@@ -2638,12 +2700,12 @@ namespace std - extern template class moneypunct; - extern template class moneypunct_byname; - extern template class moneypunct_byname; -- extern template class money_get; -- extern template class money_put; -+ extern template class _GLIBCXX_LDBL_NAMESPACE money_get; -+ extern template class _GLIBCXX_LDBL_NAMESPACE money_put; - extern template class numpunct; - extern template class numpunct_byname; -- extern template class num_get; -- extern template class num_put; -+ extern template class _GLIBCXX_LDBL_NAMESPACE num_get; -+ extern template class _GLIBCXX_LDBL_NAMESPACE num_put; - extern template class __timepunct; - extern template class time_put; - extern template class time_put_byname; -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/include/bits/localefwd.h gcc-41-20060515/libstdc++-v3/include/bits/localefwd.h ---- gcc-41-20060515.orig/libstdc++-v3/include/bits/localefwd.h 2006-05-15 11:14:38.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/include/bits/localefwd.h 2006-05-15 13:47:27.676387842 -0500 -@@ -129,10 +129,12 @@ namespace std - class codecvt_byname; - - // 22.2.2 and 22.2.3 numeric -+_GLIBCXX_BEGIN_LDBL_NAMESPACE - template > - class num_get; - template > - class num_put; -+_GLIBCXX_END_LDBL_NAMESPACE - template class numpunct; - template class numpunct_byname; - -@@ -155,10 +157,12 @@ namespace std - - // 22.2.6 money - class money_base; -+_GLIBCXX_BEGIN_LDBL_NAMESPACE - template > - class money_get; - template > - class money_put; -+_GLIBCXX_END_LDBL_NAMESPACE - template - class moneypunct; - template -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/include/Makefile.am gcc-41-20060515/libstdc++-v3/include/Makefile.am ---- gcc-41-20060515.orig/libstdc++-v3/include/Makefile.am 2006-05-15 11:14:39.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/include/Makefile.am 2006-05-15 13:47:27.666389381 -0500 -@@ -825,13 +825,18 @@ ${host_builddir}/c++config.h: ${top_buil - ${glibcxx_srcdir}/include/bits/c++config \ - stamp-${host_alias} \ - ${toplevel_srcdir}/gcc/DATESTAMP -- @cat ${glibcxx_srcdir}/include/bits/c++config > $@ ;\ -+ @ldbl_compat='' ;\ -+ grep "^[ ]*#[ ]*define[ ][ ]*_GLIBCXX_LONG_DOUBLE_COMPAT[ ][ ]*1[ ]*$$" \ -+ ${CONFIG_HEADER} > /dev/null 2>&1 \ -+ && ldbl_compat='s,^#undef _GLIBCXX_LONG_DOUBLE_COMPAT$$,#define _GLIBCXX_LONG_DOUBLE_COMPAT 1,' ;\ -+ sed -e "$$ldbl_compat" ${glibcxx_srcdir}/include/bits/c++config > $@ ;\ - sed -e 's/^/#define __GLIBCXX__ /' \ -- < ${toplevel_srcdir}/gcc/DATESTAMP >> $@ ;\ -+ < ${toplevel_srcdir}/gcc/DATESTAMP >> $@ ;\ - sed -e 's/HAVE_/_GLIBCXX_HAVE_/g' \ - -e 's/PACKAGE/_GLIBCXX_PACKAGE/g' \ - -e 's/VERSION/_GLIBCXX_VERSION/g' \ - -e 's/WORDS_/_GLIBCXX_WORDS_/g' \ -+ -e '/[ ]_GLIBCXX_LONG_DOUBLE_COMPAT[ ]/d' \ - < ${CONFIG_HEADER} >> $@ ;\ - echo "#endif // _CXXCONFIG_" >>$@ - -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/include/Makefile.in gcc-41-20060515/libstdc++-v3/include/Makefile.in ---- gcc-41-20060515.orig/libstdc++-v3/include/Makefile.in 2006-05-15 11:14:39.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/include/Makefile.in 2006-05-15 13:47:27.668389073 -0500 -@@ -1203,13 +1203,18 @@ ${host_builddir}/c++config.h: ${top_buil - ${glibcxx_srcdir}/include/bits/c++config \ - stamp-${host_alias} \ - ${toplevel_srcdir}/gcc/DATESTAMP -- @cat ${glibcxx_srcdir}/include/bits/c++config > $@ ;\ -+ @ldbl_compat='' ;\ -+ grep "^[ ]*#[ ]*define[ ][ ]*_GLIBCXX_LONG_DOUBLE_COMPAT[ ][ ]*1[ ]*$$" \ -+ ${CONFIG_HEADER} > /dev/null 2>&1 \ -+ && ldbl_compat='s,^#undef _GLIBCXX_LONG_DOUBLE_COMPAT$$,#define _GLIBCXX_LONG_DOUBLE_COMPAT 1,' ;\ -+ sed -e "$$ldbl_compat" ${glibcxx_srcdir}/include/bits/c++config > $@ ;\ - sed -e 's/^/#define __GLIBCXX__ /' \ -- < ${toplevel_srcdir}/gcc/DATESTAMP >> $@ ;\ -+ < ${toplevel_srcdir}/gcc/DATESTAMP >> $@ ;\ - sed -e 's/HAVE_/_GLIBCXX_HAVE_/g' \ - -e 's/PACKAGE/_GLIBCXX_PACKAGE/g' \ - -e 's/VERSION/_GLIBCXX_VERSION/g' \ - -e 's/WORDS_/_GLIBCXX_WORDS_/g' \ -+ -e '/[ ]_GLIBCXX_LONG_DOUBLE_COMPAT[ ]/d' \ - < ${CONFIG_HEADER} >> $@ ;\ - echo "#endif // _CXXCONFIG_" >>$@ - -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/src/compatibility.cc gcc-41-20060515/libstdc++-v3/src/compatibility.cc ---- gcc-41-20060515.orig/libstdc++-v3/src/compatibility.cc 2006-05-15 11:14:42.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/src/compatibility.cc 2006-05-15 13:47:27.681387073 -0500 -@@ -1,6 +1,6 @@ - // Compatibility symbols for previous versions -*- C++ -*- - --// Copyright (C) 2005 -+// Copyright (C) 2005, 2006 - // Free Software Foundation, Inc. - // - // This file is part of the GNU ISO C++ Library. This library is free -@@ -49,6 +49,7 @@ - #include - #include - #include -+#include - - namespace std - { -@@ -362,6 +363,107 @@ namespace std - - #endif - -+// gcc-4.1.0 -+#ifdef _GLIBCXX_LONG_DOUBLE_COMPAT -+#define _GLIBCXX_MATHL_WRAPPER(name, argdecl, args, ver) \ -+extern "C" double \ -+__ ## name ## l_wrapper argdecl \ -+{ \ -+ return name args; \ -+} \ -+asm (".symver __" #name "l_wrapper, " #name "l@" #ver) -+ -+#define _GLIBCXX_MATHL_WRAPPER1(name, ver) \ -+ _GLIBCXX_MATHL_WRAPPER (name, (double x), (x), ver) -+ -+#define _GLIBCXX_MATHL_WRAPPER2(name, ver) \ -+ _GLIBCXX_MATHL_WRAPPER (name, (double x, double y), (x, y), ver) -+ -+#ifdef _GLIBCXX_HAVE_ACOSL -+_GLIBCXX_MATHL_WRAPPER1 (acos, GLIBCXX_3.4.3); -+#endif -+#ifdef _GLIBCXX_HAVE_ASINL -+_GLIBCXX_MATHL_WRAPPER1 (asin, GLIBCXX_3.4.3); -+#endif -+#ifdef _GLIBCXX_HAVE_ATAN2L -+_GLIBCXX_MATHL_WRAPPER2 (atan2, GLIBCXX_3.4); -+#endif -+#ifdef _GLIBCXX_HAVE_ATANL -+_GLIBCXX_MATHL_WRAPPER1 (atan, GLIBCXX_3.4.3); -+#endif -+#ifdef _GLIBCXX_HAVE_CEILL -+_GLIBCXX_MATHL_WRAPPER1 (ceil, GLIBCXX_3.4.3); -+#endif -+#ifdef _GLIBCXX_HAVE_COSHL -+_GLIBCXX_MATHL_WRAPPER1 (cosh, GLIBCXX_3.4); -+#endif -+#ifdef _GLIBCXX_HAVE_COSL -+_GLIBCXX_MATHL_WRAPPER1 (cos, GLIBCXX_3.4); -+#endif -+#ifdef _GLIBCXX_HAVE_EXPL -+_GLIBCXX_MATHL_WRAPPER1 (exp, GLIBCXX_3.4); -+#endif -+#ifdef _GLIBCXX_HAVE_FLOORL -+_GLIBCXX_MATHL_WRAPPER1 (floor, GLIBCXX_3.4.3); -+#endif -+#ifdef _GLIBCXX_HAVE_FMODL -+_GLIBCXX_MATHL_WRAPPER2 (fmod, GLIBCXX_3.4.3); -+#endif -+#ifdef _GLIBCXX_HAVE_FREXPL -+_GLIBCXX_MATHL_WRAPPER (frexp, (double x, int *y), (x, y), GLIBCXX_3.4.3); -+#endif -+#ifdef _GLIBCXX_HAVE_HYPOTL -+_GLIBCXX_MATHL_WRAPPER2 (hypot, GLIBCXX_3.4); -+#endif -+#ifdef _GLIBCXX_HAVE_LDEXPL -+_GLIBCXX_MATHL_WRAPPER (ldexp, (double x, int y), (x, y), GLIBCXX_3.4.3); -+#endif -+#ifdef _GLIBCXX_HAVE_LOG10L -+_GLIBCXX_MATHL_WRAPPER1 (log10, GLIBCXX_3.4); -+#endif -+#ifdef _GLIBCXX_HAVE_LOGL -+_GLIBCXX_MATHL_WRAPPER1 (log, GLIBCXX_3.4); -+#endif -+#ifdef _GLIBCXX_HAVE_MODFL -+_GLIBCXX_MATHL_WRAPPER (modf, (double x, double *y), (x, y), GLIBCXX_3.4.3); -+#endif -+#ifdef _GLIBCXX_HAVE_POWL -+_GLIBCXX_MATHL_WRAPPER2 (pow, GLIBCXX_3.4); -+#endif -+#ifdef _GLIBCXX_HAVE_SINHL -+_GLIBCXX_MATHL_WRAPPER1 (sinh, GLIBCXX_3.4); -+#endif -+#ifdef _GLIBCXX_HAVE_SINL -+_GLIBCXX_MATHL_WRAPPER1 (sin, GLIBCXX_3.4); -+#endif -+#ifdef _GLIBCXX_HAVE_SQRTL -+_GLIBCXX_MATHL_WRAPPER1 (sqrt, GLIBCXX_3.4); -+#endif -+#ifdef _GLIBCXX_HAVE_TANHL -+_GLIBCXX_MATHL_WRAPPER1 (tanh, GLIBCXX_3.4); -+#endif -+#ifdef _GLIBCXX_HAVE_TANL -+_GLIBCXX_MATHL_WRAPPER1 (tan, GLIBCXX_3.4); -+#endif -+#endif // _GLIBCXX_LONG_DOUBLE_COMPAT -+ -+#ifdef _GLIBCXX_LONG_DOUBLE_COMPAT -+extern void *_ZTVN10__cxxabiv123__fundamental_type_infoE[]; -+extern void *_ZTVN10__cxxabiv119__pointer_type_infoE[]; -+extern __attribute__((used, weak)) const char _ZTSe[2] = "e"; -+extern __attribute__((used, weak)) const char _ZTSPe[3] = "Pe"; -+extern __attribute__((used, weak)) const char _ZTSPKe[4] = "PKe"; -+extern __attribute__((used, weak)) const void *_ZTIe[2] -+ = { (void *) &_ZTVN10__cxxabiv123__fundamental_type_infoE[2], -+ (void *) _ZTSe }; -+extern __attribute__((used, weak)) const void *_ZTIPe[4] -+ = { (void *) &_ZTVN10__cxxabiv119__pointer_type_infoE[2], -+ (void *) _ZTSPe, (void *) 0L, (void *) _ZTIe }; -+extern __attribute__((used, weak)) const void *_ZTIPKe[4] -+ = { (void *) &_ZTVN10__cxxabiv119__pointer_type_infoE[2], -+ (void *) _ZTSPKe, (void *) 1L, (void *) _ZTIe }; -+#endif // _GLIBCXX_LONG_DOUBLE_COMPAT -+ - #ifdef __APPLE__ - #if (defined(__ppc__) || defined (__ppc64__)) && defined (PIC) - /* __eprintf shouldn't have been made visible from libstdc++, or -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/src/compatibility-ldbl.cc gcc-41-20060515/libstdc++-v3/src/compatibility-ldbl.cc ---- gcc-41-20060515.orig/libstdc++-v3/src/compatibility-ldbl.cc 1969-12-31 18:00:00.000000000 -0600 -+++ gcc-41-20060515/libstdc++-v3/src/compatibility-ldbl.cc 2006-05-15 13:47:27.680387227 -0500 -@@ -0,0 +1,73 @@ -+// Compatibility symbols for -mlong-double-64 compatibility -*- C++ -*- -+ -+// Copyright (C) 2006 -+// Free Software Foundation, Inc. -+// -+// This file is part of the GNU ISO C++ Library. This library 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 2, or (at your option) -+// any later version. -+ -+// This library 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 this library; see the file COPYING. If not, write to the Free -+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, -+// USA. -+ -+// As a special exception, you may use this file as part of a free software -+// library without restriction. Specifically, if other files instantiate -+// templates or use macros or inline functions from this file, or you compile -+// this file and link it with other files to produce an executable, this -+// file does not by itself cause the resulting executable to be covered by -+// the GNU General Public License. This exception does not however -+// invalidate any other reasons why the executable file might be covered by -+// the GNU General Public License. -+ -+#include -+ -+#ifdef _GLIBCXX_LONG_DOUBLE_COMPAT -+ -+#ifdef __LONG_DOUBLE_128__ -+#error "compatibility-ldbl.cc must be compiled with -mlong-double-64" -+#endif -+ -+namespace std -+{ -+#define C char -+ template class num_get >; -+ template class num_put >; -+ template class money_get >; -+ template class money_put >; -+ template const num_put& use_facet >(const locale&); -+ template const num_get& use_facet >(const locale&); -+ template const money_put& use_facet >(const locale&); -+ template const money_get& use_facet >(const locale&); -+ template bool has_facet >(const locale&); -+ template bool has_facet >(const locale&); -+ template bool has_facet >(const locale&); -+ template bool has_facet >(const locale&); -+#undef C -+#ifdef _GLIBCXX_USE_WCHAR_T -+#define C wchar_t -+ template class num_get >; -+ template class num_put >; -+ template class money_get >; -+ template class money_put >; -+ template const num_put& use_facet >(const locale&); -+ template const num_get& use_facet >(const locale&); -+ template const money_put& use_facet >(const locale&); -+ template const money_get& use_facet >(const locale&); -+ template bool has_facet >(const locale&); -+ template bool has_facet >(const locale&); -+ template bool has_facet >(const locale&); -+ template bool has_facet >(const locale&); -+#undef C -+#endif -+} -+ -+#endif -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/src/complex_io.cc gcc-41-20060515/libstdc++-v3/src/complex_io.cc ---- gcc-41-20060515.orig/libstdc++-v3/src/complex_io.cc 2006-05-15 11:14:42.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/src/complex_io.cc 2006-05-15 13:47:27.681387073 -0500 -@@ -1,6 +1,6 @@ - // The template and inlines for the -*- C++ -*- complex number classes. - --// Copyright (C) 2000, 2001 Free Software Foundation, Inc. -+// Copyright (C) 2000, 2001, 2006 Free Software Foundation, Inc. - // - // This file is part of the GNU ISO C++ Library. This library is free - // software; you can redistribute it and/or modify it under the -@@ -91,3 +91,20 @@ namespace std - const complex&); - #endif //_GLIBCXX_USE_WCHAR_T - } // namespace std -+ -+// XXX GLIBCXX_ABI Deprecated -+#ifdef _GLIBCXX_LONG_DOUBLE_COMPAT -+ -+#define _GLIBCXX_LDBL_COMPAT(dbl, ldbl) \ -+ extern "C" void ldbl (void) __attribute__ ((alias (#dbl), weak)) -+ -+_GLIBCXX_LDBL_COMPAT (_ZStlsIdcSt11char_traitsIcEERSt13basic_ostreamIT0_T1_ES6_RKSt7complexIT_E, -+ _ZStlsIecSt11char_traitsIcEERSt13basic_ostreamIT0_T1_ES6_RKSt7complexIT_E); -+_GLIBCXX_LDBL_COMPAT (_ZStlsIdwSt11char_traitsIwEERSt13basic_ostreamIT0_T1_ES6_RKSt7complexIT_E, -+ _ZStlsIewSt11char_traitsIwEERSt13basic_ostreamIT0_T1_ES6_RKSt7complexIT_E); -+_GLIBCXX_LDBL_COMPAT (_ZStrsIdcSt11char_traitsIcEERSt13basic_istreamIT0_T1_ES6_RSt7complexIT_E, -+ _ZStrsIecSt11char_traitsIcEERSt13basic_istreamIT0_T1_ES6_RSt7complexIT_E); -+_GLIBCXX_LDBL_COMPAT (_ZStrsIdwSt11char_traitsIwEERSt13basic_istreamIT0_T1_ES6_RSt7complexIT_E, -+ _ZStrsIewSt11char_traitsIwEERSt13basic_istreamIT0_T1_ES6_RSt7complexIT_E); -+ -+#endif // _GLIBCXX_LONG_DOUBLE_COMPAT -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/src/istream-inst.cc gcc-41-20060515/libstdc++-v3/src/istream-inst.cc ---- gcc-41-20060515.orig/libstdc++-v3/src/istream-inst.cc 2006-05-15 11:14:42.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/src/istream-inst.cc 2006-05-15 13:47:27.682386919 -0500 -@@ -1,6 +1,6 @@ - // Explicit instantiation file. - --// Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002 -+// Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2006 - // Free Software Foundation, Inc. - // - // This file is part of the GNU ISO C++ Library. This library is free -@@ -68,3 +68,19 @@ namespace std - template wistream& operator>>(wistream&, _Setw); - #endif - } // namespace std -+ -+// XXX GLIBCXX_ABI Deprecated -+#ifdef _GLIBCXX_LONG_DOUBLE_COMPAT -+ -+#define _GLIBCXX_LDBL_COMPAT(dbl, ldbl) \ -+ extern "C" void ldbl (void) __attribute__ ((alias (#dbl), weak)) -+_GLIBCXX_LDBL_COMPAT (_ZNSirsERd, _ZNSirsERe); -+_GLIBCXX_LDBL_COMPAT (_ZNSt13basic_istreamIwSt11char_traitsIwEErsERd, -+ _ZNSt13basic_istreamIwSt11char_traitsIwEErsERe); -+// These 2 are in GCC 4.2+ only so far -+// _GLIBCXX_LDBL_COMPAT (_ZNSi10_M_extractIdEERSiRT_, -+// _ZNSi10_M_extractIeEERSiRT_); -+// _GLIBCXX_LDBL_COMPAT (_ZNSt13basic_istreamIwSt11char_traitsIwEE10_M_extractIdEERS2_RT_, -+// _ZNSt13basic_istreamIwSt11char_traitsIwEE10_M_extractIeEERS2_RT_); -+ -+#endif // _GLIBCXX_LONG_DOUBLE_COMPAT -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/src/limits.cc gcc-41-20060515/libstdc++-v3/src/limits.cc ---- gcc-41-20060515.orig/libstdc++-v3/src/limits.cc 2006-05-15 11:14:42.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/src/limits.cc 2006-05-15 13:47:27.683386765 -0500 -@@ -1,6 +1,6 @@ - // Static data members of -*- C++ -*- numeric_limits classes - --// Copyright (C) 1999, 2001, 2002 Free Software Foundation, Inc. -+// Copyright (C) 1999, 2001, 2002, 2006 Free Software Foundation, Inc. - // - // This file is part of the GNU ISO C++ Library. This library is free - // software; you can redistribute it and/or modify it under the -@@ -447,3 +447,34 @@ namespace std - const bool numeric_limits::tinyness_before; - const float_round_style numeric_limits::round_style; - } // namespace std -+ -+// XXX GLIBCXX_ABI Deprecated -+#ifdef _GLIBCXX_LONG_DOUBLE_COMPAT -+ -+#define _GLIBCXX_NUM_LIM_COMPAT(type, member, len) \ -+ extern "C" type _ZNSt14numeric_limitsIeE ## len ## member ## E \ -+ __attribute__ ((alias ("_ZNSt14numeric_limitsIdE" #len #member "E"))) -+_GLIBCXX_NUM_LIM_COMPAT (bool, is_specialized, 14); -+_GLIBCXX_NUM_LIM_COMPAT (int, digits, 6); -+_GLIBCXX_NUM_LIM_COMPAT (int, digits10, 8); -+_GLIBCXX_NUM_LIM_COMPAT (bool, is_signed, 9); -+_GLIBCXX_NUM_LIM_COMPAT (bool, is_integer, 10); -+_GLIBCXX_NUM_LIM_COMPAT (bool, is_exact, 8); -+_GLIBCXX_NUM_LIM_COMPAT (int, radix, 5); -+_GLIBCXX_NUM_LIM_COMPAT (int, min_exponent, 12); -+_GLIBCXX_NUM_LIM_COMPAT (int, min_exponent10, 14); -+_GLIBCXX_NUM_LIM_COMPAT (int, max_exponent, 12); -+_GLIBCXX_NUM_LIM_COMPAT (int, max_exponent10, 14); -+_GLIBCXX_NUM_LIM_COMPAT (bool, has_infinity, 12); -+_GLIBCXX_NUM_LIM_COMPAT (bool, has_quiet_NaN, 13); -+_GLIBCXX_NUM_LIM_COMPAT (bool, has_signaling_NaN, 17); -+_GLIBCXX_NUM_LIM_COMPAT (std::float_denorm_style, has_denorm, 10); -+_GLIBCXX_NUM_LIM_COMPAT (bool, has_denorm_loss, 15); -+_GLIBCXX_NUM_LIM_COMPAT (bool, is_iec559, 9); -+_GLIBCXX_NUM_LIM_COMPAT (bool, is_bounded, 10); -+_GLIBCXX_NUM_LIM_COMPAT (bool, is_modulo, 9); -+_GLIBCXX_NUM_LIM_COMPAT (bool, traps, 5); -+_GLIBCXX_NUM_LIM_COMPAT (bool, tinyness_before, 15); -+_GLIBCXX_NUM_LIM_COMPAT (std::float_round_style, round_style, 11); -+ -+#endif // _GLIBCXX_LONG_DOUBLE_COMPAT -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/src/locale.cc gcc-41-20060515/libstdc++-v3/src/locale.cc ---- gcc-41-20060515.orig/libstdc++-v3/src/locale.cc 2006-05-15 11:14:42.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/src/locale.cc 2006-05-15 14:06:44.932155273 -0500 -@@ -41,6 +41,21 @@ namespace __gnu_internal - static __glibcxx_mutex_define_initialized(locale_cache_mutex); - } - -+// XXX GLIBCXX_ABI Deprecated -+#ifdef _GLIBCXX_LONG_DOUBLE_COMPAT -+# define _GLIBCXX_LOC_ID(mangled) extern std::locale::id mangled -+_GLIBCXX_LOC_ID (_ZNSt7num_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE2idE); -+_GLIBCXX_LOC_ID (_ZNSt7num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE2idE); -+_GLIBCXX_LOC_ID (_ZNSt9money_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE2idE); -+_GLIBCXX_LOC_ID (_ZNSt9money_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE2idE); -+# ifdef _GLIBCXX_USE_WCHAR_T -+_GLIBCXX_LOC_ID (_ZNSt7num_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE2idE); -+_GLIBCXX_LOC_ID (_ZNSt7num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE2idE); -+_GLIBCXX_LOC_ID (_ZNSt9money_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE2idE); -+_GLIBCXX_LOC_ID (_ZNSt9money_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE2idE); -+# endif -+#endif -+ - namespace std - { - // Definitions for static const data members of locale. -@@ -397,9 +412,29 @@ namespace std - locale::id::_M_id() const - { - if (!_M_index) -- _M_index = 1 + __gnu_cxx::__exchange_and_add(&_S_refcount, 1); -+ { -+ // XXX GLIBCXX_ABI Deprecated -+#ifdef _GLIBCXX_LONG_DOUBLE_COMPAT -+ locale::id *f = 0; -+# define _GLIBCXX_SYNC_ID(facet, mangled) \ -+ if (this == &::mangled) \ -+ f = &facet::id -+ _GLIBCXX_SYNC_ID (num_get, _ZNSt7num_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE2idE); -+ _GLIBCXX_SYNC_ID (num_put, _ZNSt7num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE2idE); -+ _GLIBCXX_SYNC_ID (money_get, _ZNSt9money_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE2idE); -+ _GLIBCXX_SYNC_ID (money_put, _ZNSt9money_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE2idE); -+# ifdef _GLIBCXX_USE_WCHAR_T -+ _GLIBCXX_SYNC_ID (num_get, _ZNSt7num_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE2idE); -+ _GLIBCXX_SYNC_ID (num_put, _ZNSt7num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE2idE); -+ _GLIBCXX_SYNC_ID (money_get, _ZNSt9money_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE2idE); -+ _GLIBCXX_SYNC_ID (money_put, _ZNSt9money_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE2idE); -+# endif -+ if (f) -+ _M_index = 1 + f->_M_id(); -+ else -+#endif -+ _M_index = 1 + __gnu_cxx::__exchange_and_add(&_S_refcount, 1); -+ } - return _M_index - 1; - } - } // namespace std -- -- -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/src/locale-inst.cc gcc-41-20060515/libstdc++-v3/src/locale-inst.cc ---- gcc-41-20060515.orig/libstdc++-v3/src/locale-inst.cc 2006-05-15 11:14:42.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/src/locale-inst.cc 2006-05-15 13:47:27.684386611 -0500 -@@ -1,6 +1,6 @@ - // Locale support -*- C++ -*- - --// Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004 -+// Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2006 - // Free Software Foundation, Inc. - // - // This file is part of the GNU ISO C++ Library. This library is free -@@ -37,6 +37,7 @@ - // Instantiation configuration. - #ifndef C - # define C char -+# define C_is_char - #endif - - namespace std -@@ -48,6 +49,7 @@ namespace std - template struct __moneypunct_cache; - template class moneypunct_byname; - template class moneypunct_byname; -+_GLIBCXX_BEGIN_LDBL_NAMESPACE - template class money_get >; - template class money_put >; - template -@@ -73,11 +75,13 @@ namespace std - money_put >:: - _M_insert(ostreambuf_iterator, ios_base&, C, - const string_type&) const; -+_GLIBCXX_END_LDBL_NAMESPACE - - // numpunct, numpunct_byname, num_get, and num_put - template class numpunct; - template struct __numpunct_cache; - template class numpunct_byname; -+_GLIBCXX_BEGIN_LDBL_NAMESPACE - template class num_get >; - template class num_put >; - template -@@ -161,7 +165,8 @@ namespace std - num_put >:: - _M_insert_float(ostreambuf_iterator, ios_base&, C, char, - long double) const; -- -+_GLIBCXX_END_LDBL_NAMESPACE -+ - // time_get and time_put - template class __timepunct; - template struct __timepunct_cache; -@@ -314,3 +319,44 @@ namespace std - ios_base::fmtflags, bool); - #endif - } // namespace std -+ -+// XXX GLIBCXX_ABI Deprecated -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined C_is_char -+ -+#define _GLIBCXX_LDBL_COMPAT(dbl, ldbl) \ -+ extern "C" void ldbl (void) __attribute__ ((alias (#dbl), weak)) -+ -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE14_M_extract_intIjEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRT_, -+ _ZNKSt7num_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE14_M_extract_intIjEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE14_M_extract_intIlEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRT_, -+ _ZNKSt7num_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE14_M_extract_intIlEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE14_M_extract_intImEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRT_, -+ _ZNKSt7num_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE14_M_extract_intImEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE14_M_extract_intItEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRT_, -+ _ZNKSt7num_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE14_M_extract_intItEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE14_M_extract_intIxEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRT_, -+ _ZNKSt7num_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE14_M_extract_intIxEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE14_M_extract_intIyEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRT_, -+ _ZNKSt7num_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE14_M_extract_intIyEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE13_M_insert_intIlEES4_S4_RSt8ios_basecT_, -+ _ZNKSt7num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE13_M_insert_intIlEES3_S3_RSt8ios_basecT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE13_M_insert_intImEES4_S4_RSt8ios_basecT_, -+ _ZNKSt7num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE13_M_insert_intImEES3_S3_RSt8ios_basecT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE13_M_insert_intIxEES4_S4_RSt8ios_basecT_, -+ _ZNKSt7num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE13_M_insert_intIxEES3_S3_RSt8ios_basecT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE13_M_insert_intIyEES4_S4_RSt8ios_basecT_, -+ _ZNKSt7num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE13_M_insert_intIyEES3_S3_RSt8ios_basecT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE15_M_insert_floatIdEES4_S4_RSt8ios_baseccT_, -+ _ZNKSt7num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE15_M_insert_floatIdEES3_S3_RSt8ios_baseccT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt7num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE15_M_insert_floatIdEES3_S3_RSt8ios_baseccT_, -+ _ZNKSt7num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE15_M_insert_floatIeEES3_S3_RSt8ios_baseccT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1289money_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE10_M_extractILb0EEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRSs, -+ _ZNKSt9money_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE10_M_extractILb0EEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRSs); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1289money_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE10_M_extractILb1EEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRSs, -+ _ZNKSt9money_getIcSt19istreambuf_iteratorIcSt11char_traitsIcEEE10_M_extractILb1EEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRSs); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1289money_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE9_M_insertILb0EEES4_S4_RSt8ios_basecRKSs, -+ _ZNKSt9money_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE9_M_insertILb0EEES3_S3_RSt8ios_basecRKSs); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1289money_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE9_M_insertILb1EEES4_S4_RSt8ios_basecRKSs, -+ _ZNKSt9money_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE9_M_insertILb1EEES3_S3_RSt8ios_basecRKSs); -+ -+#endif // _GLIBCXX_LONG_DOUBLE_COMPAT -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/src/locale-misc-inst.cc gcc-41-20060515/libstdc++-v3/src/locale-misc-inst.cc ---- gcc-41-20060515.orig/libstdc++-v3/src/locale-misc-inst.cc 2006-05-15 11:14:42.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/src/locale-misc-inst.cc 2006-05-15 13:47:27.685386457 -0500 -@@ -1,6 +1,7 @@ - // Locale support -*- C++ -*- - --// Copyright (C) 1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc. -+// Copyright (C) 1999, 2000, 2001, 2002, 2003, 2006 -+// Free Software Foundation, Inc. - // - // This file is part of the GNU ISO C++ Library. This library is free - // software; you can redistribute it and/or modify it under the -@@ -45,3 +46,19 @@ namespace std - __convert_from_v(char*, const int, const char*, long double, - const __c_locale&, int); - } // namespace std -+ -+// XXX GLIBCXX_ABI Deprecated -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT -+ -+#define _GLIBCXX_LDBL_COMPAT(dbl, ldbl) \ -+ extern "C" void ldbl (void) __attribute__ ((alias (#dbl), weak)) -+ -+# if _GLIBCXX_C_LOCALE_GNU -+_GLIBCXX_LDBL_COMPAT(_ZSt16__convert_from_vIdEiPciPKcT_RKP15__locale_structi, -+ _ZSt16__convert_from_vIeEiPciPKcT_RKP15__locale_structi); -+# else -+_GLIBCXX_LDBL_COMPAT(_ZSt16__convert_from_vIdEiPciPKcT_RKPii, -+ _ZSt16__convert_from_vIeEiPciPKcT_RKPii); -+# endif -+ -+#endif // _GLIBCXX_LONG_DOUBLE_COMPAT -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/src/Makefile.am gcc-41-20060515/libstdc++-v3/src/Makefile.am ---- gcc-41-20060515.orig/libstdc++-v3/src/Makefile.am 2006-05-15 11:14:42.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/src/Makefile.am 2006-05-15 13:47:27.677387688 -0500 -@@ -35,10 +35,15 @@ libstdc++-symbol.ver: ${glibcxx_srcdir} - $(port_specific_symbol_files) - cp ${glibcxx_srcdir}/$(SYMVER_MAP) ./libstdc++-symbol.ver - if test "x$(port_specific_symbol_files)" != x; then \ -- sed -n '1,/DO NOT DELETE/p' $@ > tmp.top; \ -- sed -n '/DO NOT DELETE/,$$p' $@ > tmp.bottom; \ -- cat tmp.top $(port_specific_symbol_files) tmp.bottom > $@; \ -- rm tmp.top tmp.bottom; \ -+ if grep '^# Appended to version file.' \ -+ $(port_specific_symbol_files) /dev/null > /dev/null 2>&1; then \ -+ cat $(port_specific_symbol_files) >> $@; \ -+ else \ -+ sed -n '1,/DO NOT DELETE/p' $@ > tmp.top; \ -+ sed -n '/DO NOT DELETE/,$$p' $@ > tmp.bottom; \ -+ cat tmp.top $(port_specific_symbol_files) tmp.bottom > $@; \ -+ rm tmp.top tmp.bottom; \ -+ fi; \ - fi - - if ENABLE_SYMVERS_GNU -@@ -113,6 +118,12 @@ c++locale.cc: ${glibcxx_srcdir}/$(CLOCAL - basic_file.cc: ${glibcxx_srcdir}/$(BASIC_FILE_CC) - $(LN_S) ${glibcxx_srcdir}/$(BASIC_FILE_CC) ./$@ || true - -+if GLIBCXX_LDBL_COMPAT -+ldbl_compat_sources = compatibility-ldbl.cc -+else -+ldbl_compat_sources = -+endif -+ - # Sources present in the src directory. - sources = \ - bitmap_allocator.cc \ -@@ -160,7 +171,8 @@ sources = \ - wlocale-inst.cc \ - wstring-inst.cc \ - ${host_sources} \ -- ${host_sources_extra} -+ ${host_sources_extra} \ -+ ${ldbl_compat_sources} - - VPATH = $(top_srcdir)/src:$(top_srcdir) - -@@ -191,6 +203,15 @@ concept-inst.lo: concept-inst.cc - concept-inst.o: concept-inst.cc - $(CXXCOMPILE) -D_GLIBCXX_CONCEPT_CHECKS -fimplicit-templates -c $< - -+if GLIBCXX_LDBL_COMPAT -+# Use special rules for compatibility-ldbl.cc compilation, as we need to -+# pass -mlong-double-64. -+compatibility-ldbl.lo: compatibility-ldbl.cc -+ $(LTCXXCOMPILE) -mlong-double-64 -c $< -+compatibility-ldbl.o: compatibility-ldbl.cc -+ $(CXXCOMPILE) -mlong-double-64 -c $< -+endif -+ - # AM_CXXFLAGS needs to be in each subdirectory so that it can be - # modified in a per-library or per-sub-library way. Need to manually - # set this option because CONFIG_CXXFLAGS has to be after -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/src/Makefile.in gcc-41-20060515/libstdc++-v3/src/Makefile.in ---- gcc-41-20060515.orig/libstdc++-v3/src/Makefile.in 2006-05-15 11:14:42.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/src/Makefile.in 2006-05-15 13:47:27.679387380 -0500 -@@ -59,11 +59,27 @@ am__strip_dir = `echo $$p | sed -e 's|^. - am__installdirs = "$(DESTDIR)$(toolexeclibdir)" - toolexeclibLTLIBRARIES_INSTALL = $(INSTALL) - LTLIBRARIES = $(toolexeclib_LTLIBRARIES) -+am__libstdc___la_SOURCES_DIST = bitmap_allocator.cc pool_allocator.cc \ -+ mt_allocator.cc codecvt.cc compatibility.cc complex_io.cc \ -+ ctype.cc debug.cc debug_list.cc functexcept.cc \ -+ globals_locale.cc globals_io.cc ios.cc ios_failure.cc \ -+ ios_init.cc ios_locale.cc limits.cc list.cc locale.cc \ -+ locale_init.cc locale_facets.cc localename.cc stdexcept.cc \ -+ strstream.cc tree.cc allocator-inst.cc concept-inst.cc \ -+ fstream-inst.cc ext-inst.cc ios-inst.cc iostream-inst.cc \ -+ istream-inst.cc istream.cc locale-inst.cc locale-misc-inst.cc \ -+ misc-inst.cc ostream-inst.cc sstream-inst.cc streambuf-inst.cc \ -+ streambuf.cc string-inst.cc valarray-inst.cc wlocale-inst.cc \ -+ wstring-inst.cc atomicity.cc codecvt_members.cc \ -+ collate_members.cc ctype_members.cc messages_members.cc \ -+ monetary_members.cc numeric_members.cc time_members.cc \ -+ basic_file.cc c++locale.cc compatibility-ldbl.cc - am__objects_1 = atomicity.lo codecvt_members.lo collate_members.lo \ - ctype_members.lo messages_members.lo monetary_members.lo \ - numeric_members.lo time_members.lo - am__objects_2 = basic_file.lo c++locale.lo --am__objects_3 = bitmap_allocator.lo pool_allocator.lo mt_allocator.lo \ -+@GLIBCXX_LDBL_COMPAT_TRUE@am__objects_3 = compatibility-ldbl.lo -+am__objects_4 = bitmap_allocator.lo pool_allocator.lo mt_allocator.lo \ - codecvt.lo compatibility.lo complex_io.lo ctype.lo debug.lo \ - debug_list.lo functexcept.lo globals_locale.lo globals_io.lo \ - ios.lo ios_failure.lo ios_init.lo ios_locale.lo limits.lo \ -@@ -74,8 +90,9 @@ am__objects_3 = bitmap_allocator.lo pool - locale-inst.lo locale-misc-inst.lo misc-inst.lo \ - ostream-inst.lo sstream-inst.lo streambuf-inst.lo streambuf.lo \ - string-inst.lo valarray-inst.lo wlocale-inst.lo \ -- wstring-inst.lo $(am__objects_1) $(am__objects_2) --am_libstdc___la_OBJECTS = $(am__objects_3) -+ wstring-inst.lo $(am__objects_1) $(am__objects_2) \ -+ $(am__objects_3) -+am_libstdc___la_OBJECTS = $(am__objects_4) - libstdc___la_OBJECTS = $(am_libstdc___la_OBJECTS) - DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) - depcomp = -@@ -84,7 +101,7 @@ CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_IN - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) - CXXLD = $(CXX) - SOURCES = $(libstdc___la_SOURCES) --DIST_SOURCES = $(libstdc___la_SOURCES) -+DIST_SOURCES = $(am__libstdc___la_SOURCES_DIST) - ETAGS = etags - CTAGS = ctags - DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -@@ -152,6 +169,8 @@ GLIBCXX_C_HEADERS_C_TRUE = @GLIBCXX_C_HE - GLIBCXX_HOSTED_FALSE = @GLIBCXX_HOSTED_FALSE@ - GLIBCXX_HOSTED_TRUE = @GLIBCXX_HOSTED_TRUE@ - GLIBCXX_INCLUDES = @GLIBCXX_INCLUDES@ -+GLIBCXX_LDBL_COMPAT_FALSE = @GLIBCXX_LDBL_COMPAT_FALSE@ -+GLIBCXX_LDBL_COMPAT_TRUE = @GLIBCXX_LDBL_COMPAT_TRUE@ - INSTALL_DATA = @INSTALL_DATA@ - INSTALL_PROGRAM = @INSTALL_PROGRAM@ - INSTALL_SCRIPT = @INSTALL_SCRIPT@ -@@ -302,6 +321,8 @@ host_sources_extra = \ - basic_file.cc \ - c++locale.cc - -+@GLIBCXX_LDBL_COMPAT_FALSE@ldbl_compat_sources = -+@GLIBCXX_LDBL_COMPAT_TRUE@ldbl_compat_sources = compatibility-ldbl.cc - - # Sources present in the src directory. - sources = \ -@@ -350,7 +371,8 @@ sources = \ - wlocale-inst.cc \ - wstring-inst.cc \ - ${host_sources} \ -- ${host_sources_extra} -+ ${host_sources_extra} \ -+ ${ldbl_compat_sources} - - libstdc___la_SOURCES = $(sources) - libstdc___la_LIBADD = \ -@@ -677,10 +699,15 @@ libstdc++-symbol.ver: ${glibcxx_srcdir} - $(port_specific_symbol_files) - cp ${glibcxx_srcdir}/$(SYMVER_MAP) ./libstdc++-symbol.ver - if test "x$(port_specific_symbol_files)" != x; then \ -- sed -n '1,/DO NOT DELETE/p' $@ > tmp.top; \ -- sed -n '/DO NOT DELETE/,$$p' $@ > tmp.bottom; \ -- cat tmp.top $(port_specific_symbol_files) tmp.bottom > $@; \ -- rm tmp.top tmp.bottom; \ -+ if grep '^# Appended to version file.' \ -+ $(port_specific_symbol_files) /dev/null > /dev/null 2>&1; then \ -+ cat $(port_specific_symbol_files) >> $@; \ -+ else \ -+ sed -n '1,/DO NOT DELETE/p' $@ > tmp.top; \ -+ sed -n '/DO NOT DELETE/,$$p' $@ > tmp.bottom; \ -+ cat tmp.top $(port_specific_symbol_files) tmp.bottom > $@; \ -+ rm tmp.top tmp.bottom; \ -+ fi; \ - fi - @ENABLE_SYMVERS_DARWIN_EXPORT_TRUE@@ENABLE_SYMVERS_GNU_FALSE@libstdc++-symbol.explist : libstdc++-symbol.ver \ - @ENABLE_SYMVERS_DARWIN_EXPORT_TRUE@@ENABLE_SYMVERS_GNU_FALSE@ ${glibcxx_srcdir}/scripts/make_exports.pl \ -@@ -733,6 +760,13 @@ concept-inst.lo: concept-inst.cc - concept-inst.o: concept-inst.cc - $(CXXCOMPILE) -D_GLIBCXX_CONCEPT_CHECKS -fimplicit-templates -c $< - -+# Use special rules for compatibility-ldbl.cc compilation, as we need to -+# pass -mlong-double-64. -+@GLIBCXX_LDBL_COMPAT_TRUE@compatibility-ldbl.lo: compatibility-ldbl.cc -+@GLIBCXX_LDBL_COMPAT_TRUE@ $(LTCXXCOMPILE) -mlong-double-64 -c $< -+@GLIBCXX_LDBL_COMPAT_TRUE@compatibility-ldbl.o: compatibility-ldbl.cc -+@GLIBCXX_LDBL_COMPAT_TRUE@ $(CXXCOMPILE) -mlong-double-64 -c $< -+ - # Added bits to build debug library. - @GLIBCXX_BUILD_DEBUG_TRUE@all-local: build_debug - @GLIBCXX_BUILD_DEBUG_TRUE@install-data-local: install_debug -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/src/ostream-inst.cc gcc-41-20060515/libstdc++-v3/src/ostream-inst.cc ---- gcc-41-20060515.orig/libstdc++-v3/src/ostream-inst.cc 2006-05-15 11:14:42.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/src/ostream-inst.cc 2006-05-15 13:47:27.685386457 -0500 -@@ -1,6 +1,6 @@ - // Explicit instantiation file. - --// Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002 -+// Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2006 - // Free Software Foundation, Inc. - // - // This file is part of the GNU ISO C++ Library. This library is free -@@ -74,3 +74,19 @@ namespace std - template wostream& operator<<(wostream&, _Setw); - #endif - } // namespace std -+ -+// XXX GLIBCXX_ABI Deprecated -+#ifdef _GLIBCXX_LONG_DOUBLE_COMPAT -+ -+#define _GLIBCXX_LDBL_COMPAT(dbl, ldbl) \ -+ extern "C" void ldbl (void) __attribute__ ((alias (#dbl), weak)) -+_GLIBCXX_LDBL_COMPAT (_ZNSolsEd, _ZNSolsEe); -+_GLIBCXX_LDBL_COMPAT (_ZNSt13basic_ostreamIwSt11char_traitsIwEElsEd, -+ _ZNSt13basic_ostreamIwSt11char_traitsIwEElsEe); -+// These 2 are in GCC 4.2+ only so far -+// _GLIBCXX_LDBL_COMPAT (_ZNSo9_M_insertIdEERSoT_, -+// _ZNSo9_M_insertIeEERSoT_); -+// _GLIBCXX_LDBL_COMPAT (_ZNSt13basic_ostreamIwSt11char_traitsIwEE9_M_insertIdEERS2_T_, -+// _ZNSt13basic_ostreamIwSt11char_traitsIwEE9_M_insertIeEERS2_T_); -+ -+#endif // _GLIBCXX_LONG_DOUBLE_COMPAT -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/src/wlocale-inst.cc gcc-41-20060515/libstdc++-v3/src/wlocale-inst.cc ---- gcc-41-20060515.orig/libstdc++-v3/src/wlocale-inst.cc 2006-05-15 11:14:42.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/src/wlocale-inst.cc 2006-05-15 13:47:27.686386303 -0500 -@@ -1,6 +1,7 @@ - // Locale support -*- C++ -*- - --// Copyright (C) 1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc. -+// Copyright (C) 1999, 2000, 2001, 2002, 2003, 2006 -+// Free Software Foundation, Inc. - // - // This file is part of the GNU ISO C++ Library. This library is free - // software; you can redistribute it and/or modify it under the -@@ -36,4 +37,45 @@ - #ifdef _GLIBCXX_USE_WCHAR_T - #define C wchar_t - #include "locale-inst.cc" -+ -+// XXX GLIBCXX_ABI Deprecated -+#if defined _GLIBCXX_LONG_DOUBLE_COMPAT -+ -+#define _GLIBCXX_LDBL_COMPAT(dbl, ldbl) \ -+ extern "C" void ldbl (void) __attribute__ ((alias (#dbl), weak)) -+ -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE14_M_extract_intIjEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRT_, -+ _ZNKSt7num_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE14_M_extract_intIjEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE14_M_extract_intIlEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRT_, -+ _ZNKSt7num_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE14_M_extract_intIlEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE14_M_extract_intImEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRT_, -+ _ZNKSt7num_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE14_M_extract_intImEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE14_M_extract_intItEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRT_, -+ _ZNKSt7num_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE14_M_extract_intItEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE14_M_extract_intIxEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRT_, -+ _ZNKSt7num_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE14_M_extract_intIxEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE14_M_extract_intIyEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRT_, -+ _ZNKSt7num_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE14_M_extract_intIyEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE13_M_insert_intIlEES4_S4_RSt8ios_basewT_, -+ _ZNKSt7num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE13_M_insert_intIlEES3_S3_RSt8ios_basewT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE13_M_insert_intImEES4_S4_RSt8ios_basewT_, -+ _ZNKSt7num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE13_M_insert_intImEES3_S3_RSt8ios_basewT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE13_M_insert_intIxEES4_S4_RSt8ios_basewT_, -+ _ZNKSt7num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE13_M_insert_intIxEES3_S3_RSt8ios_basewT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE13_M_insert_intIyEES4_S4_RSt8ios_basewT_, -+ _ZNKSt7num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE13_M_insert_intIyEES3_S3_RSt8ios_basewT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1287num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE15_M_insert_floatIdEES4_S4_RSt8ios_basewcT_, -+ _ZNKSt7num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE15_M_insert_floatIdEES3_S3_RSt8ios_basewcT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt7num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE15_M_insert_floatIdEES3_S3_RSt8ios_basewcT_, -+ _ZNKSt7num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE15_M_insert_floatIeEES3_S3_RSt8ios_basewcT_); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1289money_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE10_M_extractILb0EEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRSs, -+ _ZNKSt9money_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE10_M_extractILb0EEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRSs); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1289money_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE10_M_extractILb1EEES4_S4_S4_RSt8ios_baseRSt12_Ios_IostateRSs, -+ _ZNKSt9money_getIwSt19istreambuf_iteratorIwSt11char_traitsIwEEE10_M_extractILb1EEES3_S3_S3_RSt8ios_baseRSt12_Ios_IostateRSs); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1289money_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE9_M_insertILb0EEES4_S4_RSt8ios_basewRKSbIwS3_SaIwEE, -+ _ZNKSt9money_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE9_M_insertILb0EEES3_S3_RSt8ios_basewRKSbIwS2_SaIwEE); -+_GLIBCXX_LDBL_COMPAT(_ZNKSt17__gnu_cxx_ldbl1289money_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE9_M_insertILb1EEES4_S4_RSt8ios_basewRKSbIwS3_SaIwEE, -+ _ZNKSt9money_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE9_M_insertILb1EEES3_S3_RSt8ios_basewRKSbIwS2_SaIwEE); -+ -+#endif // _GLIBCXX_LONG_DOUBLE_COMPAT - #endif -diff -urpN -X /home/bergner/cvs/dontdiff gcc-41-20060515.orig/libstdc++-v3/testsuite/testsuite_abi.cc gcc-41-20060515/libstdc++-v3/testsuite/testsuite_abi.cc ---- gcc-41-20060515.orig/libstdc++-v3/testsuite/testsuite_abi.cc 2006-05-15 11:15:38.000000000 -0500 -+++ gcc-41-20060515/libstdc++-v3/testsuite/testsuite_abi.cc 2006-05-15 14:14:57.231341148 -0500 -@@ -187,8 +187,11 @@ check_version(symbol& test, bool added) - known_versions.push_back("GLIBCXX_3.4.6"); - known_versions.push_back("GLIBCXX_3.4.7"); - known_versions.push_back("GLIBCXX_3.4.8"); -+ known_versions.push_back("GLIBCXX_LDBL_3.4"); -+ known_versions.push_back("GLIBCXX_LDBL_3.4.7"); - known_versions.push_back("CXXABI_1.3"); - known_versions.push_back("CXXABI_1.3.1"); -+ known_versions.push_back("CXXABI_LDBL_1.3"); - } - compat_list::iterator begin = known_versions.begin(); - compat_list::iterator end = known_versions.end(); -@@ -224,9 +227,7 @@ check_version(symbol& test, bool added) - // New version labels are ok. The rest are not. - compat_list::iterator it2 = find(begin, end, test.name); - if (it2 != end) -- { -- test.version_status = symbol::compatible; -- } -+ test.version_status = symbol::compatible; - else - test.version_status = symbol::incompatible; - } -@@ -370,7 +371,7 @@ compare_symbols(const char* baseline_fil - added_names.erase(it); - } - else -- missing_names.push_back(what); -+ missing_names.push_back(what); - } - - // Check missing names for compatibility. -- cgit v1.2.3-54-g00ecf