diff options
author | Ulrich Drepper <drepper@redhat.com> | 2005-04-27 01:39:11 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2005-04-27 01:39:11 +0000 |
commit | bfc832ccf15e467b6271e8b237e467a30efd3d12 (patch) | |
tree | 6f96e6258327c795b2cf93643b64b950e2f9d239 /elf/unload6mod2.c | |
parent | 462be6908c551edd67cba1bfe93187f6e7aae6e9 (diff) | |
download | glibc-bfc832ccf15e467b6271e8b237e467a30efd3d12.tar.gz glibc-bfc832ccf15e467b6271e8b237e467a30efd3d12.tar.xz glibc-bfc832ccf15e467b6271e8b237e467a30efd3d12.zip |
* elf/dl-close.c: Include stddef.h.
(_dl_close): If called recursively, just remember GC needs to be rerun and decrease l_direct_opencount. Avoid GC if l_direct_opencount decreased to 1. Rerun GC at the end if any destructor unloaded some additional libraries. * elf/Makefile: Add rules to build and run unload6 test. * elf/unload6.c: New test. * elf/unload6mod1.c: New file. * elf/unload6mod2.c: New file. * elf/unload6mod3.c: New file. * malloc/hooks.c (mem2chunk_check): Add magic_p argument, set *magic_p if magic_p is not NULL. (top_check): Invoke MALLOC_FAILURE_ACTION if MORECORE failed. (malloc_check): Fail if sz == -1. (free_check): Adjust mem2chunk_check caller. (realloc_check): Likewise. Fail if bytes == -1. If bytes == 0 and oldmem != NULL, call free_check and return NULL. If reallocating and returning NULL, invert magic byte again to make oldmem valid region for further checking. (memalign_check): Fail if bytes == -1. * malloc/Makefile: Add rules to build and run tst-mcheck. * malloc/tst-mcheck.c: New test.
Diffstat (limited to 'elf/unload6mod2.c')
-rw-r--r-- | elf/unload6mod2.c | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/elf/unload6mod2.c b/elf/unload6mod2.c new file mode 100644 index 0000000000..980efa4b0e --- /dev/null +++ b/elf/unload6mod2.c @@ -0,0 +1,23 @@ +#include <dlfcn.h> +#include <stdio.h> +#include <unistd.h> + +static void *h; + +static void __attribute__((constructor)) +mod2init (void) +{ + h = dlopen ("unload6mod3.so", RTLD_LAZY); + if (h == NULL) + { + puts ("dlopen unload6mod3.so failed"); + fflush (stdout); + _exit (1); + } +} + +static void __attribute__((destructor)) +mod2fini (void) +{ + dlclose (h); +} |