diff options
author | Rafael Avila de Espindola <espindola@google.com> | 2008-07-22 13:29:31 +0000 |
---|---|---|
committer | Rafael Espindola <espindola@gcc.gnu.org> | 2008-07-22 13:29:31 +0000 |
commit | 3571ae2e08289a7f84999a095a40923c2365259e (patch) | |
tree | 4f5e14aa862d2a03cd920142d392ac2c21a6b6a5 | |
parent | 4a799ae7a6714d267309dd89fbd291d51ed02b7d (diff) | |
download | gcc-3571ae2e08289a7f84999a095a40923c2365259e.zip gcc-3571ae2e08289a7f84999a095a40923c2365259e.tar.gz gcc-3571ae2e08289a7f84999a095a40923c2365259e.tar.bz2 |
c-typeck.c (build_external_ref): Don't call assemble_external.
2008-07-22 Rafael Avila de Espindola <espindola@google.com>
* c-typeck.c (build_external_ref): Don't call assemble_external.
* final.c (output_operand): Call assemble_external.
From-SVN: r138057
-rw-r--r-- | gcc/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/c-typeck.c | 2 | ||||
-rw-r--r-- | gcc/final.c | 8 |
3 files changed, 13 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 951d263..4d05bef 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2008-07-22 Rafael Avila de Espindola <espindola@google.com> + + * c-typeck.c (build_external_ref): Don't call assemble_external. + * final.c (output_operand): Call assemble_external. + 2008-07-21 DJ Delorie <dj@redhat.com> * config/h8300/h8300.c (h8300_hard_regno_scratch_ok): New. diff --git a/gcc/c-typeck.c b/gcc/c-typeck.c index dafce2a..a47d632 100644 --- a/gcc/c-typeck.c +++ b/gcc/c-typeck.c @@ -2191,8 +2191,6 @@ build_external_ref (tree id, int fun, location_t loc) /* Recursive call does not count as usage. */ if (ref != current_function_decl) { - if (!skip_evaluation) - assemble_external (ref); TREE_USED (ref) = 1; } diff --git a/gcc/final.c b/gcc/final.c index f27e430..787c43a 100644 --- a/gcc/final.c +++ b/gcc/final.c @@ -3344,6 +3344,14 @@ output_operand (rtx x, int code ATTRIBUTE_UNUSED) gcc_assert (!x || !REG_P (x) || REGNO (x) < FIRST_PSEUDO_REGISTER); PRINT_OPERAND (asm_out_file, x, code); + 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); + } } /* Print a memory reference operand for address X |