diff options
author | Konstantin Belousov <kib@FreeBSD.org> | 2012-01-04 17:17:11 +0000 |
---|---|---|
committer | Konstantin Belousov <kib@FreeBSD.org> | 2012-01-04 17:17:11 +0000 |
commit | 68266d5aba92df041615ea834bb45dd825e64f43 (patch) | |
tree | a8416e8ccdf1e476ad85f3e81d13f307fdf0526c /libexec | |
parent | 3079d69f903d9854766f93c04fb7e61a88294e56 (diff) | |
download | src-68266d5aba92df041615ea834bb45dd825e64f43.tar.gz src-68266d5aba92df041615ea834bb45dd825e64f43.zip |
Postpone the resolution of IRELATIVE relocations and IFUNC-targeted
relocations until tls is initialized and stacks permissions correctly
set. This allows the ifunc to call malloc(3) and some other heavy
services.
Add debug banner.
MFC after: 3 days
Notes
Notes:
svn path=/head/; revision=229508
Diffstat (limited to 'libexec')
-rw-r--r-- | libexec/rtld-elf/rtld.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/libexec/rtld-elf/rtld.c b/libexec/rtld-elf/rtld.c index 6cddd157cc8d..3973c6737e59 100644 --- a/libexec/rtld-elf/rtld.c +++ b/libexec/rtld-elf/rtld.c @@ -515,10 +515,6 @@ _rtld(Elf_Addr *sp, func_ptr_type *exit_proc, Obj_Entry **objp) ld_bind_now != NULL && *ld_bind_now != '\0', &obj_rtld, NULL) == -1) die(); - if (resolve_objects_ifunc(obj_main, - ld_bind_now != NULL && *ld_bind_now != '\0', NULL) == -1) - die(); - dbg("doing copy relocations"); if (do_copy_relocations(obj_main) == -1) die(); @@ -549,6 +545,11 @@ _rtld(Elf_Addr *sp, func_ptr_type *exit_proc, Obj_Entry **objp) map_stacks_exec(NULL); + dbg("resolving ifuncs"); + if (resolve_objects_ifunc(obj_main, + ld_bind_now != NULL && *ld_bind_now != '\0', NULL) == -1) + die(); + wlock_acquire(rtld_bind_lock, &lockstate); objlist_call_init(&initlist, &lockstate); objlist_clear(&initlist); |