* corelow.c (core_detach): Call reinit_frame_cache.
authorJim Kingdon <jkingdon@engr.sgi.com>
Thu, 30 Sep 1993 21:27:16 +0000 (21:27 +0000)
committerJim Kingdon <jkingdon@engr.sgi.com>
Thu, 30 Sep 1993 21:27:16 +0000 (21:27 +0000)
* 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.

gdb/ChangeLog
gdb/corelow.c
gdb/objfiles.c

index 74879780ba255829bc541b3d0ee344bc3c9c4ec7..0ff625406ee7eb68746b7d44fa2eb711e8b7531b 100644 (file)
@@ -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
index 749acce6e188996f21f941bc15db0baa4f97648f..a30f2c3089bfaddaec6ce71627f131159b7c5d7e 100644 (file)
@@ -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");
 }
index 903b9bd2ea142d8ab69667c77c5b3a83aeff1162..7b55084d13fdf9af6702f543fc09448cde7f7b6e 100644 (file)
@@ -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 ();