diff options
author | Ulrich Drepper <drepper@redhat.com> | 2000-06-04 21:26:12 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2000-06-04 21:26:12 +0000 |
commit | add40772bf9dc663fb4fefc024ba6d7da72fa55c (patch) | |
tree | 9067c53f2b5f9804f8aa9d8cd32b79457c9929ab | |
parent | 1dd548500f4b9f8526faebedd19c697a8dba57d9 (diff) | |
download | glibc-add40772bf9dc663fb4fefc024ba6d7da72fa55c.tar.gz glibc-add40772bf9dc663fb4fefc024ba6d7da72fa55c.tar.xz glibc-add40772bf9dc663fb4fefc024ba6d7da72fa55c.zip |
Update.
2000-06-04 Ulrich Drepper <drepper@redhat.com> * iconv/gconv_dl.c (do_release_shlib): Don't reset reference counter for the object we are releasing, just decrement it. Patch by Akira Higuchi <a-higuti@math.sci.hokudai.ac.jp>.
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | iconv/gconv_dl.c | 12 |
2 files changed, 14 insertions, 4 deletions
diff --git a/ChangeLog b/ChangeLog index 8a8d89773f..ec2c846214 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +2000-06-04 Ulrich Drepper <drepper@redhat.com> + + * iconv/gconv_dl.c (do_release_shlib): Don't reset reference + counter for the object we are releasing, just decrement it. + Patch by Akira Higuchi <a-higuti@math.sci.hokudai.ac.jp>. + 2000-06-04 Jakub Jelinek <jakub@redhat.com> * sysdeps/i386/fpu/bits/mathinline.h: Only inline sinh, cosh and tanh diff --git a/iconv/gconv_dl.c b/iconv/gconv_dl.c index d4738b5c03..710b440c58 100644 --- a/iconv/gconv_dl.c +++ b/iconv/gconv_dl.c @@ -1,5 +1,5 @@ /* Handle loading/unloading of shared object for transformation. - Copyright (C) 1997, 1998, 1999 Free Software Foundation, Inc. + Copyright (C) 1997, 1998, 1999, 2000 Free Software Foundation, Inc. This file is part of the GNU C Library. Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997. @@ -18,6 +18,7 @@ write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ +#include <assert.h> #include <dlfcn.h> #include <inttypes.h> #include <search.h> @@ -154,9 +155,12 @@ do_release_shlib (const void *nodep, VISIT value, int level) return; if (obj == release_handle) - /* This is the object we want to unload. Now set the release - counter to zero. */ - obj->counter = 0; + { + /* This is the object we want to unload. Now decrement the + reference counter. */ + assert (obj->counter > 0); + --obj->counter; + } else if (obj->counter <= 0) { if (--obj->counter < -TRIES_BEFORE_UNLOAD && obj->handle != NULL) |