diff options
author | Kevin Buettner <kevinb@redhat.com> | 2001-11-30 20:27:09 +0000 |
---|---|---|
committer | Kevin Buettner <kevinb@redhat.com> | 2001-11-30 20:27:09 +0000 |
commit | a42dd537c4eefd5681bf0ced97b2eb7735b2d9f0 (patch) | |
tree | 505b640c11cf842e523d7a7a2d32e07c49376c48 /gdb/arm-tdep.c | |
parent | 25d559ca7846a5fb9cd61015912469efa792584d (diff) | |
download | gdb-a42dd537c4eefd5681bf0ced97b2eb7735b2d9f0.zip gdb-a42dd537c4eefd5681bf0ced97b2eb7735b2d9f0.tar.gz gdb-a42dd537c4eefd5681bf0ced97b2eb7735b2d9f0.tar.bz2 |
Define SVR4 link map offset fetcher for Linux/ARM.
Diffstat (limited to 'gdb/arm-tdep.c')
-rw-r--r-- | gdb/arm-tdep.c | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/gdb/arm-tdep.c b/gdb/arm-tdep.c index 4243fd7..f7d91ed 100644 --- a/gdb/arm-tdep.c +++ b/gdb/arm-tdep.c @@ -32,6 +32,7 @@ #include "regcache.h" #include "doublest.h" #include "value.h" +#include "solib-svr4.h" /* Each OS has a different mechanism for accessing the various registers stored in the sigcontext structure. @@ -2068,6 +2069,49 @@ arm_othernames (char *names, int n) set_disassembly_flavor (); } +/* Fetch, and possibly build, an appropriate link_map_offsets structure + for ARM linux targets using the struct offsets defined in <link.h>. + Note, however, that link.h is not actually referred to in this file. + Instead, the relevant structs offsets were obtained from examining + link.h. (We can't refer to link.h from this file because the host + system won't necessarily have it, or if it does, the structs which + it defines will refer to the host system, not the target.) */ + +struct link_map_offsets * +arm_linux_svr4_fetch_link_map_offsets (void) +{ + static struct link_map_offsets lmo; + static struct link_map_offsets *lmp = 0; + + if (lmp == 0) + { + lmp = &lmo; + + lmo.r_debug_size = 8; /* Actual size is 20, but this is all we + need. */ + + lmo.r_map_offset = 4; + lmo.r_map_size = 4; + + lmo.link_map_size = 20; /* Actual size is 552, but this is all we + need. */ + + lmo.l_addr_offset = 0; + lmo.l_addr_size = 4; + + lmo.l_name_offset = 4; + lmo.l_name_size = 4; + + lmo.l_next_offset = 12; + lmo.l_next_size = 4; + + lmo.l_prev_offset = 16; + lmo.l_prev_size = 4; + } + + return lmp; +} + void _initialize_arm_tdep (void) { |