From: Andi Kleen Date: Mon, 12 Jul 2010 08:35:08 +0000 (+0000) Subject: lto-symtab.c (lto_symtab_merge_decls_1): Use fatal_error instead of gcc_assert to... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=e56d9a76ea0f45715f69c74754050428ff9761bb;p=gcc.git lto-symtab.c (lto_symtab_merge_decls_1): Use fatal_error instead of gcc_assert to print better error message for... 2010-07-12 Andi Kleen * lto-symtab.c (lto_symtab_merge_decls_1): Use fatal_error instead of gcc_assert to print better error message for multiple prevailing defs. From-SVN: r162070 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 14527ac03ea..e1322b19116 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2010-07-12 Andi Kleen + + * lto-symtab.c (lto_symtab_merge_decls_1): Use fatal_error + instead of gcc_assert to print better error message for multiple + prevailing defs. + 2010-07-12 Uros Bizjak * config/i386/i386.c (ix86_asm_output_function_label): Change format diff --git a/gcc/lto-symtab.c b/gcc/lto-symtab.c index d1014497a54..7d4235053d3 100644 --- a/gcc/lto-symtab.c +++ b/gcc/lto-symtab.c @@ -649,8 +649,12 @@ lto_symtab_merge_decls_1 (void **slot, void *data ATTRIBUTE_UNUSED) /* Assert it's the only one. */ if (prevailing) for (e = prevailing->next; e; e = e->next) - gcc_assert (e->resolution != LDPR_PREVAILING_DEF_IRONLY - && e->resolution != LDPR_PREVAILING_DEF); + { + if (e->resolution == LDPR_PREVAILING_DEF_IRONLY + || e->resolution == LDPR_PREVAILING_DEF) + fatal_error ("multiple prevailing defs for %qE", + DECL_NAME (prevailing->decl)); + } /* If there's not a prevailing symbol yet it's an external reference. Happens a lot during ltrans. Choose the first symbol with a