diff options
author | H.J. Lu <hjl.tools@gmail.com> | 2011-08-04 20:53:57 +0000 |
---|---|---|
committer | H.J. Lu <hjl.tools@gmail.com> | 2011-08-04 20:53:57 +0000 |
commit | a04e900e42589ad51ab82286b31f08e77ef86d72 (patch) | |
tree | 648b7954b1051a938309d715729398a10d9f0d06 /gas/output-file.c | |
parent | 316ac3fdde0c90b88847ac4c8afc02039d5a1510 (diff) | |
download | binutils-redhat-a04e900e42589ad51ab82286b31f08e77ef86d72.tar.gz |
Call bfd_cache_close_all on error
2011-08-04 H.J. Lu <hongjiu.lu@intel.com>
PR gas/13056
* output-file.c (output_file_close): Call bfd_cache_close_all
on error.
* write.c (write_object_file): Revert the last change.
Diffstat (limited to 'gas/output-file.c')
-rw-r--r-- | gas/output-file.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/gas/output-file.c b/gas/output-file.c index e993033f48..3e871f0db7 100644 --- a/gas/output-file.c +++ b/gas/output-file.c @@ -59,7 +59,10 @@ output_file_close (char *filename) return; /* Close the bfd. */ - res = bfd_close (stdoutput); + if (had_errors ()) + res = bfd_cache_close_all (); + else + res = bfd_close (stdoutput); /* Prevent an infinite loop - if the close failed we will call as_fatal which will call xexit() which may call this function again... */ |