summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStef Walter <stefw@gnome.org>2013-02-06 22:16:42 +0100
committerStef Walter <stefw@gnome.org>2013-02-20 10:17:54 +0100
commit95ec58961a480c15fe780bbce6d6cd974f478407 (patch)
treeed8044874aec4d1a5a73c5a2dc7da55147fc19c5
parentc6ebe7eb68e07e4f22c7b7ede14a1e4f04e893b7 (diff)
Only do shared object and DLL initialization in libraries
Don't do library initialization on shared object load when not running in a library. We'll want to plug into this and do different things per library in the future.
-rw-r--r--common/library.c60
-rw-r--r--common/library.h2
-rw-r--r--p11-kit/util.c54
-rw-r--r--trust/module.c55
4 files changed, 122 insertions, 49 deletions
diff --git a/common/library.c b/common/library.c
index de340bb..0bc7e0c 100644
--- a/common/library.c
+++ b/common/library.c
@@ -176,18 +176,12 @@ p11_library_init_impl (void)
pthread_key_create (&thread_local, free);
}
-#ifdef __GNUC__
-__attribute__((constructor))
-#endif
void
p11_library_init (void)
{
p11_library_init_once ();
}
-#ifdef __GNUC__
-__attribute__((destructor))
-#endif
void
p11_library_uninit (void)
{
@@ -233,17 +227,21 @@ p11_library_init (void)
p11_debug ("initializing library");
p11_mutex_init (&p11_library_mutex);
thread_local = TlsAlloc ();
+ if (thread_local == TLS_OUT_OF_INDEXES)
+ p11_debug ("couldn't setup tls");
}
-static void
-free_tls_value (LPVOID data)
+void
+p11_library_thread_cleanup (void)
{
p11_local *local = data;
- if (local == NULL)
- return;
- if (local->last_error)
- LocalFree (local->last_error);
- LocalFree (data);
+ if (thread_local != TLS_OUT_OF_INDEXES) {
+ p11_debug ("thread stopped, freeing tls");
+ local = TlsGetValue (thread_local);
+ if (local->last_error)
+ LocalFree (local->last_error);
+ LocalFree (local);
+ }
}
void
@@ -261,40 +259,4 @@ p11_library_uninit (void)
_p11_mutex_uninit (&p11_library_mutex);
}
-
-BOOL WINAPI
-DllMain (HINSTANCE instance,
- DWORD reason,
- LPVOID reserved)
-{
- LPVOID data;
-
- switch (reason) {
- case DLL_PROCESS_ATTACH:
- p11_library_init ();
- if (thread_local == TLS_OUT_OF_INDEXES) {
- p11_debug ("couldn't setup tls");
- return FALSE;
- }
- break;
-
- case DLL_THREAD_DETACH:
- if (thread_local != TLS_OUT_OF_INDEXES) {
- p11_debug ("thread stopped, freeing tls");
- data = TlsGetValue (thread_local);
- free_tls_value (data);
- }
- break;
-
- case DLL_PROCESS_DETACH:
- p11_library_uninit ();
- break;
-
- default:
- break;
- }
-
- return TRUE;
-}
-
#endif /* OS_WIN32 */
diff --git a/common/library.h b/common/library.h
index 338dc0f..b310cb9 100644
--- a/common/library.h
+++ b/common/library.h
@@ -79,6 +79,8 @@ void p11_library_init_impl (void);
void p11_library_init (void);
+void p11_library_thread_cleanup (void);
+
void p11_library_uninit (void);
#endif /* P11_LIBRARY_H_ */
diff --git a/p11-kit/util.c b/p11-kit/util.c
index 11a9a22..95190c5 100644
--- a/p11-kit/util.c
+++ b/p11-kit/util.c
@@ -231,3 +231,57 @@ _p11_get_progname_unlocked (void)
return NULL;
return p11_my_progname;
}
+
+#ifdef OS_UNIX
+
+void p11_kit_init (void);
+
+void p11_kit_fini (void);
+
+#ifdef __GNUC__
+__attribute__((constructor))
+#endif
+void
+p11_kit_init (void)
+{
+ p11_library_init_once ();
+}
+
+#ifdef __GNUC__
+__attribute__((destructor))
+#endif
+void
+p11_kit_fini (void)
+{
+ p11_library_uninit ();
+}
+
+#endif /* OS_UNIX */
+
+#ifdef OS_WIN32
+
+BOOL WINAPI
+DllMain (HINSTANCE instance,
+ DWORD reason,
+ LPVOID reserved)
+{
+ LPVOID data;
+
+ switch (reason) {
+ case DLL_PROCESS_ATTACH:
+ p11_library_init ();
+ break;
+ case DLL_THREAD_DETACH:
+ p11_library_thread_cleanup ();
+ break;
+ case DLL_PROCESS_DETACH:
+ p11_library_uninit ();
+ break;
+ default:
+ break;
+ }
+
+ return TRUE;
+}
+
+#endif /* OS_WIN32 */
diff --git a/trust/module.c b/trust/module.c
index ab28095..2583b2b 100644
--- a/trust/module.c
+++ b/trust/module.c
@@ -1506,6 +1506,7 @@ __declspec(dllexport)
CK_RV
C_GetFunctionList (CK_FUNCTION_LIST_PTR_PTR list)
{
+ p11_library_init_once ();
return sys_C_GetFunctionList (list);
}
@@ -1515,3 +1516,57 @@ p11_module_next_id (void)
static CK_ULONG unique = 0x10;
return (unique)++;
}
+
+#ifdef OS_UNIX
+
+void p11_trust_module_init (void);
+
+void p11_trust_module_fini (void);
+
+#ifdef __GNUC__
+__attribute__((constructor))
+#endif
+void
+p11_trust_module_init (void)
+{
+ p11_library_init_once ();
+}
+
+#ifdef __GNUC__
+__attribute__((destructor))
+#endif
+void
+p11_trust_module_fini (void)
+{
+ p11_library_uninit ();
+}
+
+#endif /* OS_UNIX */
+
+#ifdef OS_WIN32
+
+BOOL WINAPI
+DllMain (HINSTANCE instance,
+ DWORD reason,
+ LPVOID reserved)
+{
+ LPVOID data;
+
+ switch (reason) {
+ case DLL_PROCESS_ATTACH:
+ p11_library_init ();
+ break;
+ case DLL_THREAD_DETACH:
+ p11_library_thread_cleanup ();
+ break;
+ case DLL_PROCESS_DETACH:
+ p11_library_uninit ();
+ break;
+ default:
+ break;
+ }
+
+ return TRUE;
+}
+
+#endif /* OS_WIN32 */