From: ebotcazou Date: Fri, 22 Oct 2004 14:30:37 +0000 (+0000) Subject: PR java/17265 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=19449fea116a8bfc9475f31997040dccf59b809a;p=thirdparty%2Fgcc.git PR java/17265 * class.c (make_local_function_alias): Revert 2004-08-18 change. (make_method_value): Likewise. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@89443 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog index 5863fec557dc..3691c4b68697 100644 --- a/gcc/java/ChangeLog +++ b/gcc/java/ChangeLog @@ -1,3 +1,9 @@ +2004-10-22 Eric Botcazou + + PR java/17265 + * class.c (make_local_function_alias): Revert 2004-08-18 change. + (make_method_value): Likewise. + 2004-10-21 Andrew Haley PR java/18091: diff --git a/gcc/java/class.c b/gcc/java/class.c index b90513f1acce..70a3b2b27701 100644 --- a/gcc/java/class.c +++ b/gcc/java/class.c @@ -1198,48 +1198,6 @@ get_access_flags_from_decl (tree decl) abort (); } -static GTY (()) int alias_labelno = 0; - -/* Create a private alias for METHOD. Using this alias instead of the method - decl ensures that ncode entries in the method table point to the real function - at runtime, not a PLT entry. */ - -static tree -make_local_function_alias (tree method) -{ -#ifdef ASM_OUTPUT_DEF - tree alias; - const char *method_name = IDENTIFIER_POINTER (DECL_ASSEMBLER_NAME (method)); - char *name = alloca (strlen (method_name) + 2); - char *buf = alloca (strlen (method_name) + 128); - - /* Prefix method_name with 'L' for the alias label. */ - *name = 'L'; - strcpy (name + 1, method_name); - - ASM_GENERATE_INTERNAL_LABEL (buf, name, alias_labelno++); - alias = build_decl (FUNCTION_DECL, get_identifier (buf), - TREE_TYPE (method)); - DECL_CONTEXT (alias) = NULL; - TREE_READONLY (alias) = TREE_READONLY (method); - TREE_THIS_VOLATILE (alias) = TREE_THIS_VOLATILE (method); - TREE_PUBLIC (alias) = 0; - DECL_EXTERNAL (alias) = 0; - DECL_ARTIFICIAL (alias) = 1; - DECL_INLINE (alias) = 0; - DECL_INITIAL (alias) = error_mark_node; - TREE_ADDRESSABLE (alias) = 1; - TREE_USED (alias) = 1; - SET_DECL_ASSEMBLER_NAME (alias, DECL_NAME (alias)); - TREE_SYMBOL_REFERENCED (DECL_ASSEMBLER_NAME (alias)) = 1; - if (!flag_syntax_only) - assemble_alias (alias, DECL_ASSEMBLER_NAME (method)); - return alias; -#else - return method; -#endif -} - /** Make reflection data (_Jv_Field) for field FDECL. */ static tree @@ -1311,8 +1269,7 @@ make_method_value (tree mdecl) code = null_pointer_node; if (DECL_RTL_SET_P (mdecl)) - code = build1 (ADDR_EXPR, nativecode_ptr_type_node, - make_local_function_alias (mdecl)); + code = build1 (ADDR_EXPR, nativecode_ptr_type_node, mdecl); START_RECORD_CONSTRUCTOR (minit, method_type_node); PUSH_FIELD_VALUE (minit, "name", build_utf8_ref (DECL_CONSTRUCTOR_P (mdecl) ?