diff options
-rw-r--r-- | gcc/ChangeLog | 15 | ||||
-rw-r--r-- | gcc/config.gcc | 4 | ||||
-rw-r--r-- | gcc/config/sol2-cxx.c | 64 | ||||
-rw-r--r-- | gcc/config/sol2-protos.h | 12 | ||||
-rw-r--r-- | gcc/config/sol2-stubs.c | 33 | ||||
-rw-r--r-- | gcc/config/sol2.h | 2 | ||||
-rw-r--r-- | gcc/config/t-sol2 | 16 | ||||
-rw-r--r-- | gcc/cp/ChangeLog | 8 | ||||
-rw-r--r-- | gcc/cp/mangle.c | 7 | ||||
-rw-r--r-- | gcc/doc/tm.texi | 4 | ||||
-rw-r--r-- | gcc/target.def | 6 |
11 files changed, 161 insertions, 10 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 0c3c5af5c3e..3f07787cf91 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,18 @@ +2011-08-18 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE> + Marc Glisse <marc.glisse@normalesup.org> + + PR libstdc++-v3/1773 + * target.def (decl_mangling_context): New C++ hook. + * doc/tm.texi: Regenerate. + * config/sol2-cxx.c, config/sol2-stubs.c: New files. + * config/sol2-protos.h: Group by source file. + (solaris_cxx_decl_mangling_context): Declare. + * config/sol2.h (TARGET_CXX_DECL_MANGLING_CONTEXT): Define. + * config/t-sol2 (sol2-cxx.o, sol2-stubs.o): New targets. + Use $<. + * config.gcc (*-*-solaris2*): Add sol2-cxx.o to cxx_target_objs. + Add sol2-stubs.o to extra_objs. + 2011-08-18 Jakub Jelinek <jakub@redhat.com> PR target/50009 diff --git a/gcc/config.gcc b/gcc/config.gcc index ec13d93b3d5..b92ce3d4fb6 100644 --- a/gcc/config.gcc +++ b/gcc/config.gcc @@ -718,8 +718,8 @@ case ${target} in tm_p_file="${tm_p_file} sol2-protos.h" tmake_file="${tmake_file} t-sol2 t-slibgcc-dummy" c_target_objs="${c_target_objs} sol2-c.o" - cxx_target_objs="${cxx_target_objs} sol2-c.o" - extra_objs="sol2.o" + cxx_target_objs="${cxx_target_objs} sol2-c.o sol2-cxx.o" + extra_objs="sol2.o sol2-stubs.o" extra_options="${extra_options} sol2.opt" case ${enable_threads}:${have_pthread_h}:${have_thread_h} in "":yes:* | yes:yes:* ) diff --git a/gcc/config/sol2-cxx.c b/gcc/config/sol2-cxx.c new file mode 100644 index 00000000000..4c89d0d3607 --- /dev/null +++ b/gcc/config/sol2-cxx.c @@ -0,0 +1,64 @@ +/* C++ specific Solaris system support. + Copyright (C) 2011 Free Software Foundation, Inc. + +This file is part of GCC. + +GCC is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 3, or (at your option) +any later version. + +GCC is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU General Public License for more details. + +You should have received a copy of the GNU General Public License +along with GCC; see the file COPYING3. If not see +<http://www.gnu.org/licenses/>. */ + +#include "config.h" +#include "system.h" +#include "coretypes.h" +#include "tree.h" +#include "cp/cp-tree.h" +#include "tm.h" +#include "tm_p.h" + +/* Before GCC 4.7, g++ defined __cplusplus 1 to avoid coping with the C++98 + overloads in Solaris system headers. Since this was fixed, 4 structure + types would move to namespace std, breaking the Solaris libstdc++ ABI. + To avoid this, we forcefully keep those types in the global namespace. + This can be removed once the next major version of libstdc++ is + released. */ + +/* Cache the identifiers of the affected types to speed up lookup. */ +#define NUM_FGID 4 +static GTY(()) tree force_global_identifiers[NUM_FGID]; + +/* Check if DECL is one of the affected types and move it to the global + namespace if so. */ +tree +solaris_cxx_decl_mangling_context (const_tree decl) +{ + static bool init = false; + int i = 0; + + if (!init) + { + force_global_identifiers[i++] = get_identifier ("div_t"); + force_global_identifiers[i++] = get_identifier ("ldiv_t"); + force_global_identifiers[i++] = get_identifier ("lconv"); + force_global_identifiers[i++] = get_identifier ("tm"); + init = true; + } + + if (!(DECL_P (decl) && DECL_NAMESPACE_STD_P (CP_DECL_CONTEXT (decl)))) + return NULL_TREE; + + for (i = 0; i < NUM_FGID; i++) + if (DECL_NAME (decl) == force_global_identifiers[i]) + return global_namespace; + + return NULL_TREE; +} diff --git a/gcc/config/sol2-protos.h b/gcc/config/sol2-protos.h index dae3e137b63..9f31ce34aff 100644 --- a/gcc/config/sol2-protos.h +++ b/gcc/config/sol2-protos.h @@ -18,9 +18,15 @@ You should have received a copy of the GNU General Public License along with GCC; see the file COPYING3. If not see <http://www.gnu.org/licenses/>. */ -extern void solaris_insert_attributes (tree, tree *); -extern void solaris_register_pragmas (void); -extern void solaris_output_init_fini (FILE *, tree); +/* In sol2.c. */ extern void solaris_assemble_visibility (tree, int); extern void solaris_elf_asm_comdat_section (const char *, unsigned int, tree); extern void solaris_file_end (void); +extern void solaris_insert_attributes (tree, tree *); +extern void solaris_output_init_fini (FILE *, tree); + +/* In sol2-c.c. */ +extern void solaris_register_pragmas (void); + +/* In sol2-cxx.c. */ +extern tree solaris_cxx_decl_mangling_context (const_tree); diff --git a/gcc/config/sol2-stubs.c b/gcc/config/sol2-stubs.c new file mode 100644 index 00000000000..94cab490c1a --- /dev/null +++ b/gcc/config/sol2-stubs.c @@ -0,0 +1,33 @@ +/* Stubs for C++ specific Solaris system support. + Copyright (C) 2011 Free Software Foundation, Inc. + +This file is part of GCC. + +GCC is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 3, or (at your option) +any later version. + +GCC is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU General Public License for more details. + +You should have received a copy of the GNU General Public License +along with GCC; see the file COPYING3. If not see +<http://www.gnu.org/licenses/>. */ + +#include "config.h" +#include "system.h" +#include "coretypes.h" +#include "tree.h" +#include "tm.h" +#include "tm_p.h" + +/* Stub implemenation of TARGET_CXX_DECL_MANGLING_CONTEXT for non-C++ + frontends. */ +tree +solaris_cxx_decl_mangling_context (const_tree decl ATTRIBUTE_UNUSED) +{ + return NULL_TREE; +} diff --git a/gcc/config/sol2.h b/gcc/config/sol2.h index 99f0382b644..b265f15ad39 100644 --- a/gcc/config/sol2.h +++ b/gcc/config/sol2.h @@ -217,6 +217,8 @@ along with GCC; see the file COPYING3. If not see /* Allow macro expansion in #pragma pack. */ #define HANDLE_PRAGMA_PACK_WITH_EXPANSION +#define TARGET_CXX_DECL_MANGLING_CONTEXT solaris_cxx_decl_mangling_context + /* Solaris/x86 as and gas support unquoted section names. */ #define SECTION_NAME_FORMAT "%s" diff --git a/gcc/config/t-sol2 b/gcc/config/t-sol2 index f53da4d3ca6..f9156223593 100644 --- a/gcc/config/t-sol2 +++ b/gcc/config/t-sol2 @@ -20,14 +20,22 @@ sol2-c.o: $(srcdir)/config/sol2-c.c $(CONFIG_H) $(SYSTEM_H) coretypes.h \ tree.h c-family/c-format.h $(C_PRAGMA_H) $(C_COMMON_H) $(CPPLIB_H) \ intl.h $(TM_H) $(TM_P_H) - $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \ - $(srcdir)/config/sol2-c.c + $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) $< + +# Solaris-specific C++ mangling. +sol2-cxx.o: $(srcdir)/config/sol2-cxx.c $(CONFIG_H) $(SYSTEM_H) coretypes.h \ + tree.h cp/cp-tree.h $(TM_H) $(TM_P_H) + $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) $< + +# Corresponding stub routines. +sol2-stubs.o: $(srcdir)/config/sol2-stubs.c $(CONFIG_H) $(SYSTEM_H) coretypes.h \ + tree.h $(TM_H) $(TM_P_H) + $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) $< # Solaris-specific attributes sol2.o: $(srcdir)/config/sol2.c $(CONFIG_H) $(SYSTEM_H) coretypes.h \ tree.h output.h $(TM_H) $(TARGET_H) $(TM_P_H) $(GGC_H) - $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \ - $(srcdir)/config/sol2.c + $(COMPILER) -c $(ALL_COMPILERFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) $< # This is required by gcc/ada/gcc-interface/Makefile.in. TARGET_LIBGCC2_CFLAGS = -fPIC diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index f95040f86a1..f0c0193a388 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,11 @@ +2011-08-18 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE> + Marc Glisse <marc.glisse@normalesup.org> + + PR libstdc++-v3/1773 + * mangle.c (decl_mangling_context): Call + targetm.cxx.decl_mangling_context. + (write_unscoped_name): Use decl_mangling_context. + 2011-08-18 Dodji Seketeli <dodji@redhat.com> PR c++/45625 diff --git a/gcc/cp/mangle.c b/gcc/cp/mangle.c index eb3f144b561..53d4bc648ae 100644 --- a/gcc/cp/mangle.c +++ b/gcc/cp/mangle.c @@ -747,6 +747,11 @@ write_encoding (const tree decl) static tree decl_mangling_context (tree decl) { + tree tcontext = targetm.cxx.decl_mangling_context (decl); + + if (tcontext != NULL_TREE) + return tcontext; + if (TREE_CODE (decl) == TYPE_DECL && LAMBDA_TYPE_P (TREE_TYPE (decl))) { @@ -857,7 +862,7 @@ write_name (tree decl, const int ignore_local_scope) static void write_unscoped_name (const tree decl) { - tree context = CP_DECL_CONTEXT (decl); + tree context = decl_mangling_context (decl); MANGLE_TRACE_TREE ("unscoped-name", decl); diff --git a/gcc/doc/tm.texi b/gcc/doc/tm.texi index 832aefef4f1..0a2f120cd58 100644 --- a/gcc/doc/tm.texi +++ b/gcc/doc/tm.texi @@ -10178,6 +10178,10 @@ unloaded. The default is to return false. @var{type} is a C++ class (i.e., RECORD_TYPE or UNION_TYPE) that has just been defined. Use this hook to make adjustments to the class (eg, tweak visibility or perform any other required target modifications). @end deftypefn +@deftypefn {Target Hook} tree TARGET_CXX_DECL_MANGLING_CONTEXT (const_tree @var{decl}) +Return target-specific mangling context of @var{decl} or @code{NULL_TREE}. +@end deftypefn + @node Named Address Spaces @section Adding support for named address spaces @cindex named address spaces diff --git a/gcc/target.def b/gcc/target.def index 479e1a111fc..857f463217f 100644 --- a/gcc/target.def +++ b/gcc/target.def @@ -2451,6 +2451,12 @@ DEFHOOK void, (tree type), hook_void_tree) +DEFHOOK +(decl_mangling_context, + "Return target-specific mangling context of @var{decl} or @code{NULL_TREE}.", + tree, (const_tree decl), + hook_tree_const_tree_null) + HOOK_VECTOR_END (cxx) /* Functions and data for emulated TLS support. */ |