aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Kingdon <jkingdon@engr.sgi.com>1993-09-30 21:27:16 +0000
committerJim Kingdon <jkingdon@engr.sgi.com>1993-09-30 21:27:16 +0000
commitc5198d937809755e1893f84a78d795b49aaaca56 (patch)
treeca3f822589b413bcba8ba9a792a102866ed80acf
parent01dfd415135645a6703f8d3bb2d591bdf89b51ef (diff)
downloadgdb-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.
-rw-r--r--gdb/ChangeLog6
-rw-r--r--gdb/corelow.c1
-rw-r--r--gdb/objfiles.c9
3 files changed, 16 insertions, 0 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index 7487978..0ff6254 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,5 +1,11 @@
Thu Sep 30 11:30:56 1993 Jim Kingdon (kingdon@lioth.cygnus.com)
+ * 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.
+
* fork-child.c (fork_inferior): Don't call target_terminal_init
and target_terminal_inferior until we are sure that the inferior
has called gdb_setpgid. This fixes PR 2900 (Schauer tracked it
diff --git a/gdb/corelow.c b/gdb/corelow.c
index 749acce..a30f2c3 100644
--- a/gdb/corelow.c
+++ b/gdb/corelow.c
@@ -216,6 +216,7 @@ core_detach (args, from_tty)
if (args)
error ("Too many arguments");
unpush_target (&core_ops);
+ reinit_frame_cache ();
if (from_tty)
printf_filtered ("No core file now.\n");
}
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 ();