From: Loren J. Rittle Date: Fri, 8 Jun 2001 03:55:43 +0000 (+0000) Subject: eh_alloc.cc: Ensure that required macros are defined before including gthr.h. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=7628e178ef59d7f9daf52db48d29e9fc45e17136;p=gcc.git eh_alloc.cc: Ensure that required macros are defined before including gthr.h. * libsupc++/eh_alloc.cc: Ensure that required macros are defined before including gthr.h. Ensure that we get the version of gthr.h for which we know how to provide a configuration. * libsupc++/eh_globals.cc: Likewise. And, bring the threading code path into line with the current EH model. Use std, where appropriate. Co-Authored-By: John David Anglin From-SVN: r42999 --- diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index 5b8293a3f5d..724b5b9504e 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,3 +1,14 @@ +2001-06-07 Loren J. Rittle + John David Anglin + + * libsupc++/eh_alloc.cc: Ensure that required macros are + defined before including gthr.h. Ensure that we get the + version of gthr.h for which we know how to provide a + configuration. + * libsupc++/eh_globals.cc: Likewise. And, bring the threading + code path into line with the current EH model. Use std, where + appropriate. + 2001-06-07 Loren J. Rittle John David Anglin diff --git a/libstdc++-v3/libsupc++/eh_alloc.cc b/libstdc++-v3/libsupc++/eh_alloc.cc index ee9f31c3ca6..8b55d6c6083 100644 --- a/libstdc++-v3/libsupc++/eh_alloc.cc +++ b/libstdc++-v3/libsupc++/eh_alloc.cc @@ -35,7 +35,8 @@ #include #include #include "unwind-cxx.h" -#include "gthr.h" +#include "bits/c++config.h" +#include "bits/gthr.h" using namespace __cxxabiv1; diff --git a/libstdc++-v3/libsupc++/eh_globals.cc b/libstdc++-v3/libsupc++/eh_globals.cc index a247b842f59..3033619b12a 100644 --- a/libstdc++-v3/libsupc++/eh_globals.cc +++ b/libstdc++-v3/libsupc++/eh_globals.cc @@ -29,8 +29,10 @@ #include +#include #include "unwind-cxx.h" -#include "gthr.h" +#include "bits/c++config.h" +#include "bits/gthr.h" using namespace __cxxabiv1; @@ -47,7 +49,7 @@ get_globals_dtor (void *ptr) { __gthread_key_dtor (globals_key, ptr); if (ptr) - free (ptr); + std::free (ptr); } static void @@ -90,24 +92,20 @@ __cxa_get_globals () return &globals_static; if (use_thread_key < 0) - get_globals_init_once (); + { + get_globals_init_once (); + + // Make sure use_thread_key got initialized. + if (use_thread_key == 0) + return &globals_static; + } g = (__cxa_eh_globals *) __gthread_getspecific (globals_key); if (! g) { - static __gthread_once_t once = __GTHREAD_ONCE_INIT; - - // Make sure use_thread_key got initialized. Some systems have - // dummy thread routines in their libc that return a success. - if (__gthread_once (&once, eh_threads_initialize) != 0 - || use_thread_key < 0) - { - use_thread_key = 0; - return &globals_static; - } - - if ((g = malloc (sizeof (__cxa_eh_globals))) == 0 - || __gthread_setspecific (eh_context_key, (void *) g) != 0) + if ((g = (__cxa_eh_globals *) + std::malloc (sizeof (__cxa_eh_globals))) == 0 + || __gthread_setspecific (globals_key, (void *) g) != 0) std::terminate (); g->caughtExceptions = 0; g->uncaughtExceptions = 0;