From 3b3938c9f4cbc473ba598690710465d6e115b30f Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Mon, 8 May 2000 15:29:32 +0000 Subject: [PATCH] Update. 2000-05-08 Jakub Jelinek * elf/dl-fini.c (_dl_fini): Bump l_opencount of all objects so that they are not dlclose'd from underneath us. --- ChangeLog | 5 +++++ elf/dl-fini.c | 8 +++++++- 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index afdb9a7ca4..72f8238979 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +2000-05-08 Jakub Jelinek + + * elf/dl-fini.c (_dl_fini): Bump l_opencount of all objects so that + they are not dlclose'd from underneath us. + 2000-05-08 Andreas Schwab * posix/execle.c: Fix size parameter of memcpy. diff --git a/elf/dl-fini.c b/elf/dl-fini.c index f218689628..9b103aeb7e 100644 --- a/elf/dl-fini.c +++ b/elf/dl-fini.c @@ -58,7 +58,13 @@ _dl_fini (void) the pointers in. */ maps = (struct link_map **) alloca (nloaded * sizeof (struct link_map *)); for (l = _dl_loaded, nloaded = 0; l != NULL; l = l->l_next) - maps[nloaded++] = l; + { + maps[nloaded++] = l; + + /* Bump l_opencount of all objects so that they are not dlclose()ed + from underneath us. */ + ++l->l_opencount; + } /* Now we have to do the sorting. */ for (l = _dl_loaded->l_next; l != NULL; l = l->l_next)