aboutsummaryrefslogtreecommitdiff
path: root/elf/lateglobal.c
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2000-10-21 07:16:18 +0000
committerUlrich Drepper <drepper@redhat.com>2000-10-21 07:16:18 +0000
commitd785c366924df522974f4ee88d77fd8aaed58803 (patch)
tree12b41ae0e43531a39697176a6f7e71476262587e /elf/lateglobal.c
parentc91bc73e3e463ae6a80e548b899703efae256090 (diff)
downloadglibc-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.c47
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;
+}