Update.
authorUlrich Drepper <drepper@redhat.com>
Sun, 1 Aug 1999 21:43:03 +0000 (21:43 +0000)
committerUlrich Drepper <drepper@redhat.com>
Sun, 1 Aug 1999 21:43:03 +0000 (21:43 +0000)
* elf/Makefile (tests): Add resolvfail.  Add rules to build the
program.
* elf/resolvfail.c: New file.

ChangeLog
elf/Makefile
elf/resolvfail.c [new file with mode: 0644]
linuxthreads/ChangeLog
linuxthreads/Versions

index a8d91a8b1872f9a66be46fea022b94b287c99d59..19129191329683a0f271b67dd85f997d7128db99 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,9 @@
 1999-08-01  Ulrich Drepper  <drepper@cygnus.com>
 
+       * elf/Makefile (tests): Add resolvfail.  Add rules to build the
+       program.
+       * elf/resolvfail.c: New file.
+
        * elf/dl-sym.c (_dl_sym): Always determine module of the caller to
        pass it to _dl_lookup_symbol.
 
index 5cecc2b3ac1d148929f78033630b34f04d1e3a2f..cd0f390d6f521229f80a3a9f69019a1b87cb32a7 100644 (file)
@@ -71,7 +71,7 @@ install-rootsbin += ldconfig
 endif
 
 ifeq (yes,$(build-shared))
-tests = loadtest restest1 preloadtest loadfail multiload origtest
+tests = loadtest restest1 preloadtest loadfail multiload origtest resolvfail
 endif
 modules-names = testobj1 testobj2 testobj3 testobj4 testobj5 testobj6 \
                testobj1_1 failobj
@@ -237,3 +237,9 @@ $(objpfx)multiload.out: $(objpfx)testobj1.so
 
 $(objpfx)origtest: $(libdl)
 $(objpfx)origtest.out: $(objpfx)testobj1.so
+
+ifeq ($(have-thread-library),yes)
+$(objpfx)resolvfail: $(libdl) $(shared-thread-library)
+else
+$(objpfx)resolvfail: $(libdl)
+endif
diff --git a/elf/resolvfail.c b/elf/resolvfail.c
new file mode 100644 (file)
index 0000000..9dd5cbe
--- /dev/null
@@ -0,0 +1,25 @@
+#include <dlfcn.h>
+
+static const char obj[] = "testobj1.so";
+
+int
+main (void)
+{
+  void *d = dlopen (obj, RTLD_LAZY);
+  int n;
+
+  if (d == NULL)
+    {
+      printf ("cannot load %s: %s\n", obj, dlerror ());
+      return 1;
+    }
+
+  for (n = 0; n < 10000; ++n)
+    if (dlsym (d, "does not exist") != NULL)
+      {
+       puts ("dlsym() did not fail");
+       return 1;
+      }
+
+  return 0;
+}
index 09a223828bbfcb57fb34cae50c49c88e062e3bea..50c9e01280d1da79a220dcedbb6e56712659efcb 100644 (file)
@@ -1,3 +1,8 @@
+1999-08-01  Ulrich Drepper  <drepper@cygnus.com>
+
+       * Versions [ld.so] (GLIBC_2.0): Export __libc_internal_tsd_get and
+       __libc_internal_tsd_set.
+
 1999-07-29  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
 
        * manager.c: Remove inclusion of <linux/tasks.h> since it's not
index 66a8f46b5c68a9aa763175a7cb118896e05754a0..5ec3dacd3df18709506760a695ca95ac675d1eec 100644 (file)
@@ -22,6 +22,13 @@ libc {
   }
 }
 
+ld.so {
+  GLIBC_2.0 {
+    # Internal libc interface to libpthread
+    __libc_internal_tsd_get; __libc_internal_tsd_set;
+  }
+}
+
 libpthread {
   GLIBC_2.0 {
     # Hidden entry point (through macros).