Keep tm, div_t, ldiv_t, lconv mangling on Solaris (PR libstdc++-v3/1773)
Co-Authored-By: Marc Glisse <marc.glisse@normalesup.org> From-SVN: r177863
This commit is contained in:
parent
901ebcdf97
commit
5b880ea61c
11 changed files with 161 additions and 10 deletions
|
@ -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
|
||||
|
|
|
@ -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:* )
|
||||
|
|
64
gcc/config/sol2-cxx.c
Normal file
64
gcc/config/sol2-cxx.c
Normal file
|
@ -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;
|
||||
}
|
|
@ -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);
|
||||
|
|
33
gcc/config/sol2-stubs.c
Normal file
33
gcc/config/sol2-stubs.c
Normal file
|
@ -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;
|
||||
}
|
|
@ -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"
|
||||
|
||||
|
|
|
@ -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
|
||||
|
|
|
@ -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
|
||||
|
|
|
@ -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);
|
||||
|
||||
|
|
|
@ -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
|
||||
|
|
|
@ -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. */
|
||||
|
|
Loading…
Add table
Reference in a new issue