[cross-binutils-2.15.91.0.2] assertion fail linker.c:619

Alan Modra amodra@bigpond.net.au
Wed Aug 18 01:57:00 GMT 2004


On Tue, Aug 17, 2004 at 03:16:10PM -0700, H. J. Lu wrote:
> The problem is bfd_link_add_undef assumes h->und_next == NULL. But it
> may not be true in all cases, depending on how lucky/unlucky you are.
> This patch seems to fix the testcase. But I am not sure if it is 100%
> correct.

I don't think it's right.  und_next should be NULL at the tail of the
list.  You need to fix some place where an undefined symbol finds
a definition.

Hmm, it so happens that the ELF linker doesn't traverse the list (except
for ppc64 with a recent patch of mine), so und_next is effectively just
a flag.  Neither are entries removed from the list (except again for
ppc64).  So I'm not certain what we should do here.  Obviously, I need
to ensure that the ppc64 list traversal doesn't fall off the end of the
list, or loop..

> --- linker.c.undef	2004-08-13 08:00:10.000000000 -0700
> +++ linker.c	2004-08-17 15:14:00.595475841 -0700
> @@ -616,7 +616,7 @@ void
>  bfd_link_add_undef (struct bfd_link_hash_table *table,
>  		    struct bfd_link_hash_entry *h)
>  {
> -  BFD_ASSERT (h->und_next == NULL);
> +  BFD_ASSERT (h->und_next == NULL || h->und_next == table->undefs_tail);
>    if (table->undefs_tail != NULL)
>      table->undefs_tail->und_next = h;
>    if (table->undefs == NULL)

-- 
Alan Modra
IBM OzLabs - Linux Technology Centre



More information about the Binutils mailing list