From a8571d373c763ce55314d6010c43e7052fa42a45 Mon Sep 17 00:00:00 2001 From: Andreas Jaeger Date: Wed, 10 May 2000 09:06:56 +0000 Subject: Update. 2000-05-09 Jakub Jelinek * elf/dl-sym.c (_dl_sym): Test ref not result for non-zero. (_dl_vsym): Likewise. Reported by Owen Taylor . * elf/dl-deps.c (_dl_map_object_deps): Zero terminate L->l_initfini always. --- ChangeLog | 9 +++++++++ elf/dl-deps.c | 4 +++- elf/dl-sym.c | 4 ++-- 3 files changed, 14 insertions(+), 3 deletions(-) diff --git a/ChangeLog b/ChangeLog index f7e5a488d1..14bf6c66de 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,12 @@ +2000-05-09 Jakub Jelinek + + * elf/dl-sym.c (_dl_sym): Test ref not result for non-zero. + (_dl_vsym): Likewise. + Reported by Owen Taylor . + + * elf/dl-deps.c (_dl_map_object_deps): Zero terminate L->l_initfini + always. + 2000-05-08 Andreas Jaeger * include/libintl.h: Add prototype for __bind_textdomain_codeset. diff --git a/elf/dl-deps.c b/elf/dl-deps.c index d59f53658d..fca210f72a 100644 --- a/elf/dl-deps.c +++ b/elf/dl-deps.c @@ -465,7 +465,7 @@ _dl_map_object_deps (struct link_map *map, /* Store the search list we built in the object. It will be used for searches in the scope of this object. */ - map->l_searchlist.r_list = malloc ((2 * nlist + map->l_searchlist.r_list = malloc ((2 * nlist + 1 + (nlist == nduplist ? 0 : nduplist)) * sizeof (struct link_map *)); if (map->l_searchlist.r_list == NULL) @@ -549,4 +549,6 @@ _dl_map_object_deps (struct link_map *map, } } } + /* Terminate the list of dependencies. */ + map->l_initfini[nlist] = NULL; } diff --git a/elf/dl-sym.c b/elf/dl-sym.c index 84236ff993..8ab6f2c64e 100644 --- a/elf/dl-sym.c +++ b/elf/dl-sym.c @@ -74,7 +74,7 @@ RTLD_NEXT used in code not dynamically loaded")); } } - if (result) + if (ref) return DL_SYMBOL_ADDRESS (result, ref); return NULL; @@ -130,7 +130,7 @@ RTLD_NEXT used in code not dynamically loaded")); map->l_local_scope, &vers, 0); } - if (result) + if (ref) return DL_SYMBOL_ADDRESS (result, ref); return NULL; } -- cgit v1.2.3