From d1927c7f37ad4481b54469b963bf783c208afb72 Mon Sep 17 00:00:00 2001 From: Lennart Poettering Date: Tue, 4 Sep 2007 02:25:44 +0000 Subject: [PATCH] initialize libltdl for multi-thread support git-svn-id: file:///home/lennart/svn/public/pulseaudio/branches/lennart@1763 fefdeb5f-60dc-0310-8127-8f9354f1896f --- src/daemon/main.c | 40 ++++++++++++++++++++++++++++++++++++++-- 1 file changed, 38 insertions(+), 2 deletions(-) diff --git a/src/daemon/main.c b/src/daemon/main.c index 77487dc..b754ee7 100644 --- a/src/daemon/main.c +++ b/src/daemon/main.c @@ -81,6 +81,9 @@ #include #include #include +#include +#include +#include #include "cmdline.h" #include "cpulimit.h" @@ -311,6 +314,39 @@ static void set_all_rlimits(const pa_daemon_conf *conf) { } #endif +static pa_mutex *libtool_mutex = NULL; + +static void libtool_lock(void) { + pa_mutex_lock(libtool_mutex); +} + +static void libtool_unlock(void) { + pa_mutex_unlock(libtool_mutex); +} + +PA_STATIC_TLS_DECLARE(libtool_tls, NULL); + +static void libtool_set_error(const char * error) { + pa_tls_set(PA_STATIC_TLS_GET(libtool_tls), (char*) error); +} + +static const char *libtool_get_error(void) { + return pa_tls_get(PA_STATIC_TLS_GET(libtool_tls)); +} + +static void libtool_init(void) { + pa_assert_se(libtool_mutex = pa_mutex_new(1)); + libtool_lock(); /* Hmm, somehow libtool expects this mutex to be initialized in locking state! */ + pa_assert_se(lt_dlmutex_register(libtool_lock, libtool_unlock, libtool_set_error, libtool_get_error) == 0); + pa_assert_se(lt_dlinit() == 0); +} + +static void libtool_done(void) { + pa_assert_se(lt_dlexit() == 0); + pa_mutex_free(libtool_mutex); + libtool_mutex = NULL; +} + int main(int argc, char *argv[]) { pa_core *c = NULL; pa_strbuf *buf = NULL; @@ -365,7 +401,7 @@ int main(int argc, char *argv[]) { LTDL_SET_PRELOADED_SYMBOLS(); - pa_assert_se(lt_dlinit() == 0); + libtool_init(); #ifdef OS_IS_WIN32 { @@ -714,7 +750,7 @@ finish: WSACleanup(); #endif - lt_dlexit(); + libtool_done(); return retval; } -- 2.7.4