diff options
author | Mark Mitchell <mark@codesourcery.com> | 2005-06-09 07:30:19 +0000 |
---|---|---|
committer | Mark Mitchell <mark@codesourcery.com> | 2005-06-09 07:30:19 +0000 |
commit | abaff2fa1735c9d84c39335abe5306d7d9c0bfe6 (patch) | |
tree | 2f0e7f0928e0da4c96ad05ae70f20ecaf32c3931 /bfd/opncls.c | |
parent | c0779e3875e4668cc69788f3d24dce1687cfb764 (diff) | |
download | binutils-redhat-abaff2fa1735c9d84c39335abe5306d7d9c0bfe6.tar.gz |
* opncls.c (bfd_fopen): Mark returned BFD as cacheable if FD == -1.
Diffstat (limited to 'bfd/opncls.c')
-rw-r--r-- | bfd/opncls.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/bfd/opncls.c b/bfd/opncls.c index df2cf6d3ea..56b5925cd6 100644 --- a/bfd/opncls.c +++ b/bfd/opncls.c @@ -144,6 +144,8 @@ DESCRIPTION Calls <<bfd_find_target>>, so @var{target} is interpreted as by that function. + The new BFD is marked as cacheable iff @var{fd} is -1. + If <<NULL>> is returned then an error has occured. Possible errors are <<bfd_error_no_memory>>, <<bfd_error_invalid_target>> or <<system_call>> error. @@ -198,6 +200,12 @@ bfd_fopen (const char *filename, const char *target, const char *mode, int fd) return NULL; } nbfd->opened_once = TRUE; + /* If we opened the file by name, mark it cacheable; we can close it + and reopen it later. However, if a file descriptor was provided, + then it may have been opened with special flags that make it + unsafe to close and reopen the file. */ + if (fd == -1) + bfd_set_cacheable (nbfd, TRUE); return nbfd; } |