From c1bd25fd1de1bc9e80bf95feb670c26be62c833b Mon Sep 17 00:00:00 2001 From: Daniel Jacobowitz Date: Mon, 13 Jun 2005 16:15:40 +0000 Subject: gdb/ * Makefile.in (symfile.o): Add $(exec_h). * exec.h (exec_set_section_address): Add prototype. * exec.c (exec_set_section_address): New function. * symfile.c: Include "exec.h". (struct place_section_arg, place_section): New. (default_symfile_offsets): Call place_section for each section of a relocatable file. gdb/testsuite/ * gdb.base/relocate.c: Add a copyright notice. (dummy): Remove. * gdb.base/relocate.exp: Test printing the values of variables from a relocatable file. --- gdb/exec.c | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) (limited to 'gdb/exec.c') diff --git a/gdb/exec.c b/gdb/exec.c index 938b106..60e3b36 100644 --- a/gdb/exec.c +++ b/gdb/exec.c @@ -670,6 +670,27 @@ set_section_command (char *args, int from_tty) error (_("Section %s not found"), secprint); } +/* If we can find a section in FILENAME with BFD index INDEX, and the + user has not assigned an address to it yet (via "set section"), adjust it + to ADDRESS. */ + +void +exec_set_section_address (const char *filename, int index, CORE_ADDR address) +{ + struct section_table *p; + + for (p = exec_ops.to_sections; p < exec_ops.to_sections_end; p++) + { + if (strcmp (filename, p->bfd->filename) == 0 + && index == p->the_bfd_section->index + && p->addr == 0) + { + p->addr = address; + p->endaddr += address; + } + } +} + /* If mourn is being called in all the right places, this could be say `gdb internal error' (since generic_mourn calls breakpoint_init_inferior). */ -- cgit v1.1