aboutsummaryrefslogtreecommitdiff
path: root/gdb/solib-darwin.c
diff options
context:
space:
mode:
authorTristan Gingold <gingold@adacore.com>2011-09-27 15:30:18 +0000
committerTristan Gingold <gingold@adacore.com>2011-09-27 15:30:18 +0000
commitf00c55f83236fbdbae20f1556dc046bb90975755 (patch)
tree4627f8b0c096890c78461a77d345853f16643b96 /gdb/solib-darwin.c
parent6710bf39b7c037de481a4b351fb69cec6b48b138 (diff)
downloadgdb-f00c55f83236fbdbae20f1556dc046bb90975755.zip
gdb-f00c55f83236fbdbae20f1556dc046bb90975755.tar.gz
gdb-f00c55f83236fbdbae20f1556dc046bb90975755.tar.bz2
2011-09-27 Tristan Gingold <gingold@adacore.com>
* target.h (enum target_object): Add TARGET_OBJECT_DARWIN_DYLD_INFO. * solib-darwin.c (DYLD_VERSION_MAX): Update number. (darwin_solib_get_all_image_info_addr_at_init): New function. (darwin_solib_read_all_image_info_addr): Likewise. (darwin_solib_create_inferior_hook): Use the above two functions. * darwin-nat.c (darwin_execvp): Renames retval to res. (darwin_read_write_inferior): Update comment. (darwin_read_dyld_info): New function. (darwin_xfer_partial): Handle DYLD_INFO.
Diffstat (limited to 'gdb/solib-darwin.c')
-rw-r--r--gdb/solib-darwin.c74
1 files changed, 47 insertions, 27 deletions
diff --git a/gdb/solib-darwin.c b/gdb/solib-darwin.c
index 24301d9..d592809 100644
--- a/gdb/solib-darwin.c
+++ b/gdb/solib-darwin.c
@@ -68,7 +68,7 @@ struct gdb_dyld_all_image_infos
/* Current all_image_infos version. */
#define DYLD_VERSION_MIN 1
-#define DYLD_VERSION_MAX 7
+#define DYLD_VERSION_MAX 12
/* Address of structure dyld_all_image_infos in inferior. */
static CORE_ADDR dyld_all_image_addr;
@@ -293,22 +293,19 @@ darwin_special_symbol_handling (void)
{
}
-/* Shared library startup support. See documentation in solib-svr4.c. */
+/* Extract dyld_all_image_addr when the process was just created, assuming the
+ current PC is at the entry of the dynamic linker. */
static void
-darwin_solib_create_inferior_hook (int from_tty)
+darwin_solib_get_all_image_info_addr_at_init (void)
{
- struct minimal_symbol *msymbol;
- char **bkpt_namep;
- asection *interp_sect;
gdb_byte *interp_name;
- CORE_ADDR sym_addr;
CORE_ADDR load_addr = 0;
- int load_addr_found = 0;
- int loader_found_in_list = 0;
- struct so_list *so;
bfd *dyld_bfd = NULL;
- struct inferior *inf = current_inferior ();
+
+ /* This method doesn't work with an attached process. */
+ if (current_inferior ()->attach_flag)
+ return;
/* Find the program interpreter. */
interp_name = find_program_interpreter ();
@@ -316,7 +313,6 @@ darwin_solib_create_inferior_hook (int from_tty)
return;
/* Create a bfd for the interpreter. */
- sym_addr = 0;
dyld_bfd = bfd_openr (interp_name, gnutarget);
if (dyld_bfd)
{
@@ -335,21 +331,11 @@ darwin_solib_create_inferior_hook (int from_tty)
if (!dyld_bfd)
return;
- if (!inf->attach_flag)
- {
- /* We find the dynamic linker's base address by examining
- the current pc (which should point at the entry point for the
- dynamic linker) and subtracting the offset of the entry point. */
- load_addr = (regcache_read_pc (get_current_regcache ())
- - bfd_get_start_address (dyld_bfd));
- }
- else
- {
- /* FIXME: todo.
- Get address of __DATA.__dyld in exec_bfd, read address at offset 0.
- */
- return;
- }
+ /* We find the dynamic linker's base address by examining
+ the current pc (which should point at the entry point for the
+ dynamic linker) and subtracting the offset of the entry point. */
+ load_addr = (regcache_read_pc (get_current_regcache ())
+ - bfd_get_start_address (dyld_bfd));
/* Now try to set a breakpoint in the dynamic linker. */
dyld_all_image_addr =
@@ -361,6 +347,40 @@ darwin_solib_create_inferior_hook (int from_tty)
return;
dyld_all_image_addr += load_addr;
+}
+
+/* Extract dyld_all_image_addr reading it from
+ TARGET_OBJECT_DARWIN_DYLD_INFO. */
+
+static void
+darwin_solib_read_all_image_info_addr (void)
+{
+ gdb_byte buf[8 + 8 + 4];
+ LONGEST len;
+ enum bfd_endian byte_order = gdbarch_byte_order (target_gdbarch);
+
+ len = target_read (&current_target, TARGET_OBJECT_DARWIN_DYLD_INFO, NULL,
+ buf, 0, sizeof (buf));
+ if (len != sizeof (buf))
+ return;
+
+ dyld_all_image_addr = extract_unsigned_integer (buf, 8, byte_order);
+}
+
+/* Shared library startup support. See documentation in solib-svr4.c. */
+
+static void
+darwin_solib_create_inferior_hook (int from_tty)
+{
+ dyld_all_image_addr = 0;
+
+ darwin_solib_read_all_image_info_addr ();
+
+ if (dyld_all_image_addr == 0)
+ darwin_solib_get_all_image_info_addr_at_init ();
+
+ if (dyld_all_image_addr == 0)
+ return;
darwin_load_image_infos ();