From 97a51d8a0cc6508464305efdd372a630fdcfb7e6 Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Sun, 8 Mar 1998 22:56:54 +0000 Subject: [PATCH] Update. 1998-03-08 22:55 Ulrich Drepper * elf/rtld.c (dl_main): Delay initialization of path structure if the dynamically linker is invoked implicitly until we read the dynamic section. --- ChangeLog | 6 ++++++ elf/rtld.c | 10 +++++++--- 2 files changed, 13 insertions(+), 3 deletions(-) diff --git a/ChangeLog b/ChangeLog index 93337e1..ad0b113 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +1998-03-08 22:55 Ulrich Drepper + + * elf/rtld.c (dl_main): Delay initialization of path structure if + the dynamically linker is invoked implicitly until we read the + dynamic section. + 1998-03-08 Ulrich Drepper * sysdeps/unix/sysv/linux/chown.c: Add versioning stuff. diff --git a/elf/rtld.c b/elf/rtld.c index c80fe27..304d07a 100644 --- a/elf/rtld.c +++ b/elf/rtld.c @@ -400,9 +400,8 @@ of this helper program; chances are you did not intend to run this program.\n", main_map->l_entry = *user_entry; main_map->l_opencount = 1; - /* Initialize the data structures for the search paths for shared - objects. */ - _dl_init_paths (NULL); + /* We delay initializing the path structure until we got the dynamic + information for the program. */ } /* Scan the program header table for the dynamic section. */ @@ -470,6 +469,11 @@ of this helper program; chances are you did not intend to run this program.\n", /* Set up our cache of pointers into the hash table. */ _dl_setup_hash (main_map); + if (*user_entry != (ElfW(Addr)) &ENTRY_POINT) + /* Initialize the data structures for the search paths for shared + objects. */ + _dl_init_paths (NULL); + /* Put the link_map for ourselves on the chain so it can be found by name. Note that at this point the global chain of link maps contains exactly one element, which is pointed to by main_map. */ -- 2.7.4