From f95942a33e236084c7f39d6af199e6b46f6bdbea Mon Sep 17 00:00:00 2001 From: Richard Sandiford Date: Sat, 14 Mar 2009 09:36:38 +0000 Subject: [PATCH] bfd/ * xcofflink.c (xcoff_link_check_archive_element): Only free the symbol table if it was created by the current call. --- bfd/ChangeLog | 5 +++++ bfd/xcofflink.c | 7 ++++++- 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 25fce9fea38..77be5da7cc5 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 f02f66862f0..3752f7c8678 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; -- 2.30.2