[17/17] target_sections hack
Tom Tromey
tromey@redhat.com
Thu Dec 15 05:22:00 GMT 2011
I was surprised to discover that one part of gdb relies on BFDs not
being shared.
In particular, if an solib shares exec_bfd, then remove_target_sections
will happily remove all the sections for both, then unpush the file
target. Then re-"run"ing will fail.
Unpushing the target here seems like an abstraction inversion.
(However, I don't really know this code very well.)
This patch fixes the problem via a gross hack: bypass the calls if the
BFD is the same as exec_bfd.
It occurs to me now that this approach will still fail if the inferior
calls dlmopen (causing a single library to be mapped more than once, but
after this series still sharing BFDs). One other idea I had was to
associate a tag with the target_sections; this would be just any handy
void*, like the solib. Then remove_target_sections could search for the
tag in addition to the BFD. Any other thoughts on this?
Tom
>From 6609c92b8da8473cd3ceb21e66d9fe2ee88218de Mon Sep 17 00:00:00 2001
From: Tom Tromey <tromey@redhat.com>
Date: Mon, 12 Dec 2011 15:00:23 -0700
Subject: [PATCH 17/18] target sections hack solib assumes that we will not
share BFDs
* solib.c (solib_map_sections): Conditionally call
add_target_sections.
(update_solib_list): Conditionally call remove_target_sections.
(clear_solib): Conditionally call remove_target_sections.
(reload_shared_libraries_1): Conditionally call
remove_target_sections.
---
gdb/solib.c | 11 +++++++----
1 files changed, 7 insertions(+), 4 deletions(-)
diff --git a/gdb/solib.c b/gdb/solib.c
index 79d1905..c8f3bfa 100644
--- a/gdb/solib.c
+++ b/gdb/solib.c
@@ -507,7 +507,8 @@ solib_map_sections (struct so_list *so)
section tables. Do this immediately after mapping the object so
that later nodes in the list can query this object, as is needed
in solib-osf.c. */
- add_target_sections (so->sections, so->sections_end);
+ if (so->abfd != exec_bfd)
+ add_target_sections (so->sections, so->sections_end);
return 1;
}
@@ -770,7 +771,8 @@ update_solib_list (int from_tty, struct target_ops *target)
/* Some targets' section tables might be referring to
sections from so->abfd; remove them. */
- remove_target_sections (gdb->abfd);
+ if (gdb->abfd != exec_bfd)
+ remove_target_sections (gdb->abfd);
free_so (gdb);
gdb = *gdb_link;
@@ -1150,7 +1152,7 @@ clear_solib (void)
so_list_head = so->next;
observer_notify_solib_unloaded (so);
- if (so->abfd)
+ if (so->abfd && so->abfd != exec_bfd)
remove_target_sections (so->abfd);
free_so (so);
}
@@ -1244,7 +1246,8 @@ reload_shared_libraries_1 (int from_tty)
if (so->objfile && ! (so->objfile->flags & OBJF_USERLOADED)
&& !solib_used (so))
free_objfile (so->objfile);
- remove_target_sections (so->abfd);
+ if (so->abfd != exec_bfd)
+ remove_target_sections (so->abfd);
free_so_symbols (so);
}
--
1.7.6.4
More information about the Gdb-patches
mailing list