summaryrefslogtreecommitdiff
path: root/gdb
diff options
context:
space:
mode:
authorKevin Buettner <kevinb@redhat.com>2001-09-14 00:40:29 +0000
committerKevin Buettner <kevinb@redhat.com>2001-09-14 00:40:29 +0000
commit8c5c927165493f25e4d90f8fe26837e55df72ecb (patch)
treec99c42bbb16a94f80a65a6ce9602a427377ad805 /gdb
parent69584168d59e9fe4a56d7ae52b180c6a94f9e6c8 (diff)
downloadgdb-8c5c927165493f25e4d90f8fe26837e55df72ecb.tar.gz
Commit Ilya Golubev's clear_solib() fixes.
Diffstat (limited to 'gdb')
-rw-r--r--gdb/ChangeLog8
-rw-r--r--gdb/irix5-nat.c1
-rw-r--r--gdb/osfsolib.c1
-rw-r--r--gdb/solib.c2
4 files changed, 12 insertions, 0 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index 71200c2eb75..a835ab8b239 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,3 +1,11 @@
+2001-09-13 Kevin Buettner <kevinb@redhat.com>
+
+ From Ilya Golubev <gin@mo.msk.ru>:
+ * solib.c (clear_solib): Call `remove_target_sections' to fix
+ stale pointers in `struct target_ops'.
+ * irix5-nat.c (clear_solib): Likewise.
+ * osfsolib.c (clear_solib): Likewise.
+
2001-09-13 Jim Blandy <jimb@redhat.com>
* monitor.c (monitor_load): Don't delete symtab users, or reset
diff --git a/gdb/irix5-nat.c b/gdb/irix5-nat.c
index c1549fc0623..3c3284047cc 100644
--- a/gdb/irix5-nat.c
+++ b/gdb/irix5-nat.c
@@ -1061,6 +1061,7 @@ clear_solib (void)
}
if (so_list_head->abfd)
{
+ remove_target_sections (so_list_head->abfd);
bfd_filename = bfd_get_filename (so_list_head->abfd);
if (!bfd_close (so_list_head->abfd))
warning ("cannot close \"%s\": %s",
diff --git a/gdb/osfsolib.c b/gdb/osfsolib.c
index b5a61518bc1..734cbc23ab5 100644
--- a/gdb/osfsolib.c
+++ b/gdb/osfsolib.c
@@ -802,6 +802,7 @@ clear_solib (void)
}
if (so_list_head->abfd)
{
+ remove_target_sections (so_list_head->abfd);
bfd_filename = bfd_get_filename (so_list_head->abfd);
if (!bfd_close (so_list_head->abfd))
warning ("cannot close \"%s\": %s",
diff --git a/gdb/solib.c b/gdb/solib.c
index dfcca0cc47b..c43858e8b55 100644
--- a/gdb/solib.c
+++ b/gdb/solib.c
@@ -730,6 +730,8 @@ clear_solib (void)
{
struct so_list *so = so_list_head;
so_list_head = so->next;
+ if (so->abfd)
+ remove_target_sections (so->abfd);
free_so (so);
}