diff options
author | Elliott Hughes <enh@google.com> | 2012-07-16 11:38:23 -0700 |
---|---|---|
committer | android code review <noreply-gerritcodereview@google.com> | 2012-07-16 11:38:23 -0700 |
commit | 3fd5e91e58ba40a7321a3f2c4c64970584e9bb56 (patch) | |
tree | 9327cd649b5f512a9927ee8aaf256513f5beb94c /linker | |
parent | 05f03b8875ed4aab95e5587d066d62a781af97bc (diff) | |
parent | bb5c30a3ee40324effd4daa346505e16faf91728 (diff) | |
download | bionic-3fd5e91e58ba40a7321a3f2c4c64970584e9bb56.zip bionic-3fd5e91e58ba40a7321a3f2c4c64970584e9bb56.tar.gz bionic-3fd5e91e58ba40a7321a3f2c4c64970584e9bb56.tar.bz2 |
Merge "bionic: Report linker relocation address to gdb"
Diffstat (limited to 'linker')
-rw-r--r-- | linker/linker.c | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/linker/linker.c b/linker/linker.c index 2a7ccd5..753ee89 100644 --- a/linker/linker.c +++ b/linker/linker.c @@ -1640,7 +1640,7 @@ static void parse_preloads(const char *path, char *delim) * fixed it's own GOT. It is safe to make references to externs * and other non-local data at this point. */ -static unsigned __linker_init_post_relocation(unsigned **elfdata) +static unsigned __linker_init_post_relocation(unsigned **elfdata, unsigned linker_base) { static soinfo linker_soinfo; @@ -1730,15 +1730,16 @@ sanitize: _r_debug.r_map = map; r_debug_tail = map; - /* gdb expects the linker to be in the debug shared object list, - * and we need to make sure that the reported load address is zero. - * Without this, gdb gets the wrong idea of where rtld_db_dlactivity() - * is. Don't use soinfo_alloc(), because the linker shouldn't + /* gdb expects the linker to be in the debug shared object list. + * Without this, gdb has trouble locating the linker's ".text" + * and ".plt" sections. Gdb could also potentially use this to + * relocate the offset of our exported 'rtld_db_dlactivity' symbol. + * Don't use soinfo_alloc(), because the linker shouldn't * be on the soinfo list. */ strlcpy((char*) linker_soinfo.name, "/system/bin/linker", sizeof linker_soinfo.name); linker_soinfo.flags = 0; - linker_soinfo.base = 0; // This is the important part; must be zero. + linker_soinfo.base = linker_base; insert_soinfo_into_debug_map(&linker_soinfo); /* extract information passed from the kernel */ @@ -1930,5 +1931,5 @@ unsigned __linker_init(unsigned **elfdata) { // We have successfully fixed our own relocations. It's safe to run // the main part of the linker now. - return __linker_init_post_relocation(elfdata); + return __linker_init_post_relocation(elfdata, linker_addr); } |