From f410e1b3d2646dd13dca05e09c819c32a46299e0 Mon Sep 17 00:00:00 2001 From: Rafael Avila de Espindola Date: Wed, 30 Jul 2008 13:59:58 +0000 Subject: [PATCH] final.c (call_from_call_insn): New. 2008-07-30 Rafael Avila de Espindola * final.c (call_from_call_insn): New. (final_scan_insn): Call assemble_external on FUNCTION_DECLs. 2008-07-30 Rafael Avila de Espindola * gcc.dg/visibility-14.c: New test. * gcc.dg/visibility-15.c: New test. * gcc.dg/visibility-16.c: New test. * gcc.dg/visibility-17.c: New test. * gcc.dg/visibility-18.c: New test. * gcc.dg/visibility-19.c: New test. From-SVN: r138310 --- gcc/ChangeLog | 5 +++++ gcc/final.c | 39 +++++++++++++++++++++++++++++++++++++++ gcc/testsuite/ChangeLog | 9 +++++++++ 3 files changed, 53 insertions(+) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index ef8fdb0e6c2..423ac34d678 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2008-07-30 Rafael Avila de Espindola + + * final.c (call_from_call_insn): New. + (final_scan_insn): Call assemble_external on FUNCTION_DECLs. + 2008-07-30 Paolo Bonzini * configure.ac: Substitute ADA_CFLAGS. diff --git a/gcc/final.c b/gcc/final.c index 787c43abad5..2a9d40ba754 100644 --- a/gcc/final.c +++ b/gcc/final.c @@ -1744,6 +1744,31 @@ output_alternate_entry_point (FILE *file, rtx insn) } } +/* Given a CALL_INSN, find and return the nested CALL. */ +static rtx +call_from_call_insn (rtx insn) +{ + rtx x; + gcc_assert (CALL_P (insn)); + x = PATTERN (insn); + + while (GET_CODE (x) != CALL) + { + switch (GET_CODE (x)) + { + default: + gcc_unreachable (); + case PARALLEL: + x = XVECEXP (x, 0, 0); + break; + case SET: + x = XEXP (x, 1); + break; + } + } + return x; +} + /* The final scan for one insn, INSN. Args are same as in `final', except that INSN is the insn being scanned. @@ -2609,6 +2634,20 @@ final_scan_insn (rtx insn, FILE *file, int optimize ATTRIBUTE_UNUSED, targetm.asm_out.unwind_emit (asm_out_file, insn); #endif + if (CALL_P (insn)) + { + rtx x = call_from_call_insn (insn); + x = XEXP (x, 0); + if (x && MEM_P (x) && GET_CODE (XEXP (x, 0)) == SYMBOL_REF) + { + tree t; + x = XEXP (x, 0); + t = SYMBOL_REF_DECL (x); + if (t) + assemble_external (t); + } + } + /* Output assembler code from the template. */ output_asm_insn (templ, recog_data.operand); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 95f4d4e9bc7..c53755b4db0 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,12 @@ +2008-07-30 Rafael Avila de Espindola + + * gcc.dg/visibility-14.c: New test. + * gcc.dg/visibility-15.c: New test. + * gcc.dg/visibility-16.c: New test. + * gcc.dg/visibility-17.c: New test. + * gcc.dg/visibility-18.c: New test. + * gcc.dg/visibility-19.c: New test. + 2008-07-30 Dodji Seketeli PR c++/36767