components/gcc53/patches/002-libc-values.patch
changeset 5342 e55d87e99ecd
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/components/gcc53/patches/002-libc-values.patch	Tue Jan 26 12:01:07 2016 -0600
@@ -0,0 +1,42 @@
+#
+# As the comment mentions below, match the values-*.o that selects the libc
+# behaviour for the C/C++ standard selected on the command line.
+# https://gcc.gnu.org/bugzilla/show_bug.cgi?id=40411
+#
+--- gcc-5.3.0.orig/gcc/config/sol2.h	Thu Oct  1 05:01:18 2015
++++ gcc-5.3.0/gcc/config/sol2.h	Tue Jan 12 17:39:43 2016
+@@ -150,9 +150,32 @@
+ #define MD_EXEC_PREFIX "/usr/ccs/bin/"
+ #endif
+ 
++/* Solaris libc and libm implement multiple behaviours for various interfaces
++   that have changed over the years in different versions of the standards.
++   The behaviour is controlled by linking corresponding values-*.o objects.
++   Each of these objects contain alternate defintions of one or more variables
++   that libc uses to select which conflicting behaviour it should exhibit.
++   There are two sets of these objects, values-X*.o and values-xpg*.o.
++
++   The values-X*.o objects set the variable _lib_version to one of strict_ansi,
++   ansi_1, or c_issue_4.  Ignoring '-Xt' and '-Xs', unless '-Xc' is used with
++   the Solaris Studio C/C++ compilers, it appears that values-Xa.o is linked
++   into resulting executables regardless of which '-std=' setting is selected.
++
++   The values-xpg*.o objects define one or more __xpg* variables.  No
++   values-xpg*.o object is linked in unless the equivalent of '-std=c99|c11'
++   is used during the linking of C code.  In either of those cases,
++   values-xpg6.o is linked.
++
++   The below spec string is reasonably consistent with that behaviour. */
+ #undef STARTFILE_ARCH_SPEC
+-#define STARTFILE_ARCH_SPEC "%{ansi:values-Xc.o%s} \
+-			    %{!ansi:values-Xa.o%s}"
++#define STARTFILE_ARCH_SPEC \
++    "%{ansi:values-Xc.o%s; :values-Xa.o%s} \
++     %{std=c99|std=c9x|std=gnu99|std=gnu9x:values-xpg6.o%s} \
++     %{std=c11|std=c1x|std=gnu11|std=gnu1x:values-xpg6.o%s} \
++     %{std=c++11|std=c++0x|std=gnu++11|std=gnu++0x:values-xpg6.o%s} \
++     %{std=c++14|std=c++1y|std=gnu++14|std=gnu++1y:values-xpg6.o%s} \
++     %{std=c++1z|std=gnu++1z:values-xpg6.o%s}"
+ 
+ #if defined(HAVE_LD_PIE) && defined(HAVE_SOLARIS_CRTS)
+ #define STARTFILE_CRTBEGIN_SPEC "%{shared|pie:crtbeginS.o%s;:crtbegin.o%s}"