summaryrefslogtreecommitdiff
path: root/gcc/cp
diff options
context:
space:
mode:
authorrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>2001-08-07 00:13:35 +0000
committerrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>2001-08-07 00:13:35 +0000
commit14cd71feb3713a48b99a39292f3a90980890032e (patch)
treefe1d06a13ef40c7bd7f7953e66a94a01e57f7d54 /gcc/cp
parent367a6c4cc42251aca1ffffd2f4ce50bc944633f4 (diff)
downloadgcc-14cd71feb3713a48b99a39292f3a90980890032e.tar.gz
* varasm.c (assemble_constructor): Take a symbol_ref and a
priority instead of a bare string. Move priority handling here from cp/decl2.c. * output.h: Update decls. * c-decl.c (c_expand_body): Update calls to assemble_constructor and assemble_destructor. * profile.c (output_func_start_profiler): Likewise. * objc/objc-act.c (finish_objc): Likewise. (build_module_descriptor): Return the symbol not the symbol name. * ch/grant.c (chill_finish_compile): Pass a symbol_ref and priority to assemble_constructor. * cp/decl2.c (finish_objects): Pass a symbol_ref and priority to assemble_{constructor,destructor}. Remove priority handling. * java/class.c (emit_register_classes): Pass a symbol_ref and priority to assemble_constructor. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@44678 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/cp')
-rw-r--r--gcc/cp/ChangeLog5
-rw-r--r--gcc/cp/decl2.c32
2 files changed, 11 insertions, 26 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index 470fd821188..1b3cceb3015 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,8 @@
+2001-08-06 Richard Henderson <rth@redhat.com>
+
+ * decl2.c (finish_objects): Pass a symbol_ref and priority to
+ assemble_{constructor,destructor}. Remove priority handling.
+
2001-08-05 Gabriel Dos Reis <gdr@merlin.codesourcery.com>
Don't allow template-id in using-declaration.
diff --git a/gcc/cp/decl2.c b/gcc/cp/decl2.c
index d35ab7195d2..be02224557f 100644
--- a/gcc/cp/decl2.c
+++ b/gcc/cp/decl2.c
@@ -2839,8 +2839,8 @@ finish_objects (method_type, initp, body)
int method_type, initp;
tree body;
{
- const char *fnname;
tree fn;
+ rtx fnsym;
/* Finish up. */
finish_compound_stmt (/*has_no_scope=*/0, body);
@@ -2853,31 +2853,11 @@ finish_objects (method_type, initp, body)
if (flag_syntax_only)
return;
- fnname = XSTR (XEXP (DECL_RTL (fn), 0), 0);
- if (initp == DEFAULT_INIT_PRIORITY)
- {
- if (method_type == 'I')
- assemble_constructor (fnname);
- else
- assemble_destructor (fnname);
- }
-#if defined (ASM_OUTPUT_CONSTRUCTOR)
- /* If we're using init priority we can't use assemble_*tor, but on ELF
- targets we can stick the references into named sections for GNU ld
- to collect. */
- else if (targetm.have_named_sections)
- {
- char buf[15];
- sprintf (buf, ".%ctors.%.5u", method_type == 'I' ? 'c' : 'd',
- /* invert the numbering so the linker puts us in the proper
- order; constructors are run from right to left, and the
- linker sorts in increasing order. */
- MAX_INIT_PRIORITY - initp);
- named_section (NULL_TREE, buf, 0);
- assemble_integer (XEXP (DECL_RTL (fn), 0),
- POINTER_SIZE / BITS_PER_UNIT, 1);
- }
-#endif
+ fnsym = XEXP (DECL_RTL (fn), 0);
+ if (method_type == 'I')
+ assemble_constructor (fnsym, initp);
+ else
+ assemble_destructor (fnsym, initp);
}
/* The names of the parameters to the function created to handle