diff options
author | Jim Blandy <jimb@codesourcery.com> | 2000-03-15 16:55:07 +0000 |
---|---|---|
committer | Jim Blandy <jimb@codesourcery.com> | 2000-03-15 16:55:07 +0000 |
commit | 07cd4b9723e0a6d6bfec8980b0afcdbd9fdeb332 (patch) | |
tree | b46d5728b4a5b131a25dd4ff4b2f6fd3fec0faf2 /gdb/objfiles.c | |
parent | 8f2eba6efa236376dc3e15723714d39999652408 (diff) | |
download | gdb-07cd4b9723e0a6d6bfec8980b0afcdbd9fdeb332.zip gdb-07cd4b9723e0a6d6bfec8980b0afcdbd9fdeb332.tar.gz gdb-07cd4b9723e0a6d6bfec8980b0afcdbd9fdeb332.tar.bz2 |
Deal with the inferior unloading shared objects.
* solib.c (current_sos): New function, replacing find_solib.
(find_solib): Deleted.
(free_so): New function.
(clear_solib): Call free_so, instead of writing it out.
(solib_add): Rewritten: compare the inferior's current list of
shared objects with GDB's list, and do the required loads and
unloads.
(info_sharedlibrary_command, solib_address): Don't use find_solib
to walk the list of shared libraries: call solib_add, and then
walk the list at so_list_head normally.
* objfiles.c (free_objfile): Don't call CLEAR_SOLIB, and don't
detach the core target. These tasks are taken care of elsewhere.
* target.c (remove_target_sections): New function.
* target.h (remove_target_sections): New declaration.
* solib.c (symbol_add_stub): Check whether we've already created
an objfile for this shared object first, before doing all that
work to compute section addresses, etc.
* objfiles.c (unlink_objfile): Report an internal error if objfile
doesn't occur in the object_files list.
* solib.c (special_symbol_handling): Delete argument; it's not
used.
* solib.c (SOLIB_EXTRACT_ADDRESS): New macro to extract addresses
from solib structures. Use it throughout solib.c, get rid of all
CORE_ADDR casts.
(struct so_list): Change type of lmaddr to CORE_ADDR.
(first_link_map_member): Change return value type to CORE_ADDR,
update callers.
(solib_add_common_symbols): Change parameter type to CORE_ADDR,
update callers.
(open_symbol_file_object, find_solib): Change type of lm variable
to CORE_ADDR.
Diffstat (limited to 'gdb/objfiles.c')
-rw-r--r-- | gdb/objfiles.c | 15 |
1 files changed, 3 insertions, 12 deletions
diff --git a/gdb/objfiles.c b/gdb/objfiles.c index bcd047c..41ec317 100644 --- a/gdb/objfiles.c +++ b/gdb/objfiles.c @@ -370,9 +370,11 @@ unlink_objfile (objfile) { *objpp = (*objpp)->next; objfile->next = NULL; - break; + return; } } + + internal_error ("objfiles.c (unlink_objfile): objfile already unlinked"); } @@ -436,17 +438,6 @@ free_objfile (objfile) is unknown, but we play it safe for now and keep each action until it is shown to be no longer needed. */ -#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 /* I *think* all our callers call clear_symtab_users. If so, no need to call this here. */ clear_pc_function_cache (); |