Move the GThread implementations to glib/

We can now get threads initialised from inside of libglib by calling
g_thread_init_glib().
This commit is contained in:
Ryan Lortie 2011-08-31 18:00:03 -04:00
parent 96e4896804
commit cfa1d0540e
7 changed files with 23 additions and 25 deletions

View File

@ -209,6 +209,12 @@ if OS_UNIX
libglib_2_0_la_SOURCES += glib-unix.c libglib_2_0_la_SOURCES += glib-unix.c
endif endif
if OS_WIN32
libglib_2_0_la_SOURCES += gthread-win32.c
else
libglib_2_0_la_SOURCES += gthread-posix.c
endif
EXTRA_libglib_2_0_la_SOURCES = \ EXTRA_libglib_2_0_la_SOURCES = \
giounix.c \ giounix.c \
giowin32.c \ giowin32.c \
@ -347,7 +353,7 @@ pcre_lib =
pcre_inc = pcre_inc =
endif endif
libglib_2_0_la_LIBADD = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ @ICONV_LIBS@ @G_LIBS_EXTRA@ $(pcre_lib) $(GLIB_RT_LIBS) libglib_2_0_la_LIBADD = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ @ICONV_LIBS@ @G_LIBS_EXTRA@ $(pcre_lib) $(GLIB_RT_LIBS) $(G_THREAD_LIBS_EXTRA) $(G_THREAD_LIBS_FOR_GTHREAD)
libglib_2_0_la_DEPENDENCIES = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ $(glib_win32_res) $(glib_def) libglib_2_0_la_DEPENDENCIES = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ $(glib_win32_res) $(glib_def)
libglib_2_0_la_LDFLAGS = $(GLIB_LINK_FLAGS) \ libglib_2_0_la_LDFLAGS = $(GLIB_LINK_FLAGS) \

View File

@ -132,8 +132,8 @@ static gulong g_thread_min_stack_size = 0;
#define G_MUTEX_SIZE (sizeof (pthread_mutex_t)) #define G_MUTEX_SIZE (sizeof (pthread_mutex_t))
static void void
g_thread_impl_init(void) _g_thread_impl_init(void)
{ {
#ifdef _SC_THREAD_STACK_MIN #ifdef _SC_THREAD_STACK_MIN
g_thread_min_stack_size = MAX (sysconf (_SC_THREAD_STACK_MIN), 0); g_thread_min_stack_size = MAX (sysconf (_SC_THREAD_STACK_MIN), 0);
@ -381,7 +381,7 @@ g_thread_equal_posix_impl (gpointer thread1, gpointer thread2)
return (pthread_equal (*(pthread_t*)thread1, *(pthread_t*)thread2) != 0); return (pthread_equal (*(pthread_t*)thread1, *(pthread_t*)thread2) != 0);
} }
static GThreadFunctions g_thread_functions_for_glib_use_default = GThreadFunctions g_thread_functions_for_glib_use =
{ {
g_mutex_new_posix_impl, g_mutex_new_posix_impl,
(void (*)(GMutex *)) pthread_mutex_lock, (void (*)(GMutex *)) pthread_mutex_lock,
@ -405,5 +405,3 @@ static GThreadFunctions g_thread_functions_for_glib_use_default =
g_thread_self_posix_impl, g_thread_self_posix_impl,
g_thread_equal_posix_impl g_thread_equal_posix_impl
}; };
#include "gthread-impl.c"

View File

@ -70,9 +70,6 @@ static GDestroyNotify g_private_destructors[G_PRIVATE_MAX];
static guint g_private_next = 0; static guint g_private_next = 0;
/* A "forward" declaration of this structure */
static GThreadFunctions g_thread_functions_for_glib_use_default;
typedef struct _GThreadData GThreadData; typedef struct _GThreadData GThreadData;
struct _GThreadData struct _GThreadData
{ {
@ -516,7 +513,7 @@ g_thread_join_win32_impl (gpointer thread)
g_free (target); g_free (target);
} }
static GThreadFunctions g_thread_functions_for_glib_use_default = GThreadFunctions g_thread_functions_for_glib_use =
{ {
g_mutex_new_win32_impl, /* mutex */ g_mutex_new_win32_impl, /* mutex */
g_mutex_lock_win32_impl, g_mutex_lock_win32_impl,
@ -541,8 +538,8 @@ static GThreadFunctions g_thread_functions_for_glib_use_default =
NULL /* no equal function necessary */ NULL /* no equal function necessary */
}; };
static void void
g_thread_impl_init () _g_thread_impl_init (void)
{ {
static gboolean beenhere = FALSE; static gboolean beenhere = FALSE;
@ -559,5 +556,3 @@ g_thread_impl_init ()
(g_cond_event_tls = TlsAlloc ())); (g_cond_event_tls = TlsAlloc ()));
InitializeCriticalSection (&g_thread_global_spinlock); InitializeCriticalSection (&g_thread_global_spinlock);
} }
#include "gthread-impl.c"

View File

@ -356,7 +356,7 @@ gboolean g_threads_got_initialized = FALSE;
* *
* For that reason, all of those macros are documented here. * For that reason, all of those macros are documented here.
*/ */
GThreadFunctions g_thread_functions_for_glib_use = { static GThreadFunctions g_thread_functions_for_glib_use_old = {
/* GMutex Virtual Functions {{{2 ------------------------------------------ */ /* GMutex Virtual Functions {{{2 ------------------------------------------ */
/** /**
@ -925,6 +925,8 @@ G_LOCK_DEFINE_STATIC (g_thread);
void void
g_thread_init_glib (void) g_thread_init_glib (void)
{ {
_g_thread_impl_init ();
/* We let the main thread (the one that calls g_thread_init) inherit /* We let the main thread (the one that calls g_thread_init) inherit
* the static_private data set before calling g_thread_init * the static_private data set before calling g_thread_init
*/ */

View File

@ -59,6 +59,7 @@ G_GNUC_INTERNAL void _g_main_thread_init (void);
G_GNUC_INTERNAL void _g_atomic_thread_init (void); G_GNUC_INTERNAL void _g_atomic_thread_init (void);
G_GNUC_INTERNAL void _g_utils_thread_init (void); G_GNUC_INTERNAL void _g_utils_thread_init (void);
G_GNUC_INTERNAL void _g_futex_thread_init (void); G_GNUC_INTERNAL void _g_futex_thread_init (void);
G_GNUC_INTERNAL void _g_thread_impl_init (void);
#ifdef G_OS_WIN32 #ifdef G_OS_WIN32
G_GNUC_INTERNAL void _g_win32_thread_init (void); G_GNUC_INTERNAL void _g_win32_thread_init (void);

View File

@ -13,8 +13,6 @@ AM_CPPFLAGS = \
EXTRA_DIST += \ EXTRA_DIST += \
makefile.msc.in \ makefile.msc.in \
gthread-posix.c \
gthread-win32.c \
gthread.def \ gthread.def \
gthread.rc.in gthread.rc.in
@ -66,11 +64,7 @@ gthread_win32_res = gthread-win32-res.o
gthread_win32_res_ldflag = -Wl,$(gthread_win32_res) gthread_win32_res_ldflag = -Wl,$(gthread_win32_res)
endif endif
if OS_WIN32 libgthread_2_0_la_SOURCES = gthread-impl.c
libgthread_2_0_la_SOURCES = gthread-win32.c
else
libgthread_2_0_la_SOURCES = gthread-posix.c
endif
libgthread_2_0_la_LDFLAGS = $(GLIB_LINK_FLAGS) \ libgthread_2_0_la_LDFLAGS = $(GLIB_LINK_FLAGS) \
$(gthread_win32_res_ldflag) \ $(gthread_win32_res_ldflag) \
-version-info $(LT_CURRENT):$(LT_REVISION):$(LT_AGE) \ -version-info $(LT_CURRENT):$(LT_REVISION):$(LT_AGE) \

View File

@ -31,6 +31,10 @@
* MT safe * MT safe
*/ */
#include "glib.h"
#include "gthreadprivate.h"
void void
g_thread_init (GThreadFunctions *init) g_thread_init (GThreadFunctions *init)
{ {
@ -44,8 +48,6 @@ g_thread_init (GThreadFunctions *init)
already_done = TRUE; already_done = TRUE;
g_thread_impl_init ();
g_thread_functions_for_glib_use = g_thread_functions_for_glib_use_default;
g_thread_init_glib (); g_thread_init_glib ();
} }