+2001-01-11 H.J. Lu <hjl@gnu.org>
+
+ * elf/dl-libc.c (do_dlopen): Move DL_STATIC_INIT to ...
+ * elf/dl-open.c (_dl_open): Here.
+ * sysdeps/unix/sysv/linux/ia64/dl-static.c (_dl_static_lock):
+ Make it static.
+ (_dl_static_init): Initialize the variables every time when possible.
+ * sysdeps/unix/sysv/linux/ia64/ldsodefs.h (DL_STATIC_INIT):
+ Undefine it first.
+
2001-01-11 Ulrich Drepper <drepper@redhat.com>
* stdlib/Makefile (routines): Add cxa_on_exit.
struct do_dlopen_args *args = (struct do_dlopen_args *) ptr;
/* Open and relocate the shared object. */
args->map = _dl_open (args->name, RTLD_LAZY, NULL);
-
-#ifndef SHARED
- DL_STATIC_INIT (args->map);
-#endif
}
static void
_dl_signal_error (errcode, objname, local_errstring);
}
+#ifndef SHARED
+ DL_STATIC_INIT (args.map);
+#endif
+
return args.map;
}
+2001-01-11 Ulrich Drepper <drepper@redhat.com>
+
+ * pthread.c (pthread_initialize): Use __cxs_on_exit not __cxa_atexit.
+
+2001-01-11 Jakub Jelinek <jakub@redhat.com>
+
+ * Makefile (tests): Add ex15.
+ * Examples/ex15.c: New test.
+
2001-01-08 Ulrich Drepper <drepper@redhat.com>
* pthread.c (pthread_exit_process): Free memory allocated for
#else
#include <bits/libc-lock.h>
-__libc_lock_define_initialized_recursive (, _dl_static_lock)
+__libc_lock_define_initialized_recursive (static, _dl_static_lock)
static void *variables[] =
{
const ElfW(Sym) *ref;
lookup_t loadbase;
void (*f) (void *[]);
- static int done = 0;
__libc_lock_lock (_dl_static_lock);
- if (done)
- {
- __libc_lock_unlock (_dl_static_lock);
- return;
- }
-
- done = 1;
-
loadbase = _dl_lookup_symbol ("_dl_var_init", map, &ref,
map->l_local_scope, 0, 1);
- f = (void (*) (void *[])) DL_SYMBOL_ADDRESS (loadbase, ref);
- f (variables);
+ if (ref != NULL)
+ {
+ f = (void (*) (void *[])) DL_SYMBOL_ADDRESS (loadbase, ref);
+ f (variables);
+ }
__libc_lock_unlock (_dl_static_lock);
}
/* We need special support to initialize DSO loaded for statically linked
binaries. */
extern void _dl_static_init (struct link_map *map);
+#undef DL_STATIC_INIT
#define DL_STATIC_INIT(map) _dl_static_init (map)
#endif /* ldsodefs.h */