From: Richard Sandiford Date: Sat, 14 Mar 2009 09:36:38 +0000 (+0000) Subject: bfd/ X-Git-Url: http://git.efficios.com/?a=commitdiff_plain;h=f95942a33e236084c7f39d6af199e6b46f6bdbea;p=deliverable%2Fbinutils-gdb.git bfd/ * xcofflink.c (xcoff_link_check_archive_element): Only free the symbol table if it was created by the current call. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 25fce9fea3..77be5da7cc 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2009-03-14 Richard Sandiford + + * xcofflink.c (xcoff_link_check_archive_element): Only free the + symbol table if it was created by the current call. + 2009-03-14 Richard Sandiford * xcofflink.c (xcoff_build_ldsyms): Give imported descriptors diff --git a/bfd/xcofflink.c b/bfd/xcofflink.c index f02f66862f..3752f7c867 100644 --- a/bfd/xcofflink.c +++ b/bfd/xcofflink.c @@ -2149,6 +2149,9 @@ xcoff_link_check_archive_element (bfd *abfd, struct bfd_link_info *info, bfd_boolean *pneeded) { + bfd_boolean keep_syms_p; + + keep_syms_p = (obj_coff_external_syms (abfd) != NULL); if (! _bfd_coff_get_external_symbols (abfd)) return FALSE; @@ -2159,9 +2162,11 @@ xcoff_link_check_archive_element (bfd *abfd, { if (! xcoff_link_add_symbols (abfd, info)) return FALSE; + if (info->keep_memory) + keep_syms_p = TRUE; } - if (! info->keep_memory || ! *pneeded) + if (!keep_syms_p) { if (! _bfd_coff_free_symbols (abfd)) return FALSE;