diff options
author | Ulrich Drepper <drepper@redhat.com> | 2000-10-21 07:16:18 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2000-10-21 07:16:18 +0000 |
commit | d785c366924df522974f4ee88d77fd8aaed58803 (patch) | |
tree | 12b41ae0e43531a39697176a6f7e71476262587e /elf/lateglobal.c | |
parent | c91bc73e3e463ae6a80e548b899703efae256090 (diff) | |
download | glibc-d785c366924df522974f4ee88d77fd8aaed58803.zip glibc-d785c366924df522974f4ee88d77fd8aaed58803.tar.gz glibc-d785c366924df522974f4ee88d77fd8aaed58803.tar.bz2 |
Update.
2000-10-21 Ulrich Drepper <drepper@redhat.com>
* elf/dl-open.c (add_to_global): New function. Split out from
dl_open_worker.
(dl_open_worker): Call add_to_global not only for new objects, also for
previously loaded objects when (mode & RTLD_GLOBAL) and the object
was not yet in the global scope.
* elf/Makefile: Add rules to build and run lateglobal.
* elf/lateglobal.c: New file.
* elf/ltglobmod1.c: New file.
* elf/ltglobmod2.c: New file.
Diffstat (limited to 'elf/lateglobal.c')
-rw-r--r-- | elf/lateglobal.c | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/elf/lateglobal.c b/elf/lateglobal.c new file mode 100644 index 0000000..2f6c269 --- /dev/null +++ b/elf/lateglobal.c @@ -0,0 +1,47 @@ +#include <dlfcn.h> +#include <mcheck.h> +#include <stdio.h> +#include <stdlib.h> + +int +main (void) +{ + void *h[2]; + int fail; + int (*fp) (void); + + mtrace (); + + h[0] = dlopen ("ltglobmod1.so", RTLD_LAZY); + if (h == NULL) + { + printf ("%s: cannot open %s: %s", + __FUNCTION__, "ltglobmod1.so", dlerror ()); + exit (EXIT_FAILURE); + } + h[1] = dlopen ("ltglobmod2.so", RTLD_LAZY); + if (h == NULL) + { + printf ("%s: cannot open %s: %s", + __FUNCTION__, "ltglobmod2.so", dlerror ()); + exit (EXIT_FAILURE); + } + + puts ("loaded \"ltglobmod1.so\" without RTLD_GLOBAL"); + + fp = dlsym (h[1], "foo"); + if (fp == NULL) + { + printf ("cannot get address of `foo': %s", dlerror ()); + exit (EXIT_FAILURE); + } + + fail = fp (); + + puts ("back in main"); + + dlclose (h[1]); + dlclose (h[0]); + + return fail; +} |