diff options
author | Jim Kingdon <jkingdon@engr.sgi.com> | 1993-09-30 21:27:16 +0000 |
---|---|---|
committer | Jim Kingdon <jkingdon@engr.sgi.com> | 1993-09-30 21:27:16 +0000 |
commit | c5198d937809755e1893f84a78d795b49aaaca56 (patch) | |
tree | ca3f822589b413bcba8ba9a792a102866ed80acf /gdb/objfiles.c | |
parent | 01dfd415135645a6703f8d3bb2d591bdf89b51ef (diff) | |
download | gdb-c5198d937809755e1893f84a78d795b49aaaca56.zip gdb-c5198d937809755e1893f84a78d795b49aaaca56.tar.gz gdb-c5198d937809755e1893f84a78d795b49aaaca56.tar.bz2 |
* corelow.c (core_detach): Call reinit_frame_cache.
* target.c (target_detach): Don't call generic_mourn_inferior
(revert yesterday's change, now handled by core_detach).
* objfiles.c (free_objfile): Detach any core file if we call
SOLIB_CLEAR. #include target.h.
Diffstat (limited to 'gdb/objfiles.c')
-rw-r--r-- | gdb/objfiles.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/gdb/objfiles.c b/gdb/objfiles.c index 903b9bd..7b55084 100644 --- a/gdb/objfiles.c +++ b/gdb/objfiles.c @@ -27,6 +27,7 @@ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include "symfile.h" #include "objfiles.h" #include "gdb-stabs.h" +#include "target.h" #include <sys/types.h> #include <sys/stat.h> @@ -339,6 +340,14 @@ free_objfile (objfile) #if defined (CLEAR_SOLIB) CLEAR_SOLIB (); + /* CLEAR_SOLIB closes the bfd's for any shared libraries. But + the to_sections for a core file might refer to those bfd's. So + detach any core file. */ + { + struct target_ops *t = find_core_target (); + if (t != NULL) + (t->to_detach) (NULL, 0); + } #endif clear_pc_function_cache (); |