]> granicus.if.org Git - p11-kit/commitdiff
trust: Factor out module initialization into separate file
authorDaiki Ueno <dueno@redhat.com>
Fri, 24 Aug 2018 15:42:16 +0000 (17:42 +0200)
committerDaiki Ueno <ueno@gnu.org>
Tue, 28 Aug 2018 12:44:56 +0000 (14:44 +0200)
This prevents double call to p11_library_init() in test-module.c, once
from the ELF constructor, and secondly from the test itself.

trust/Makefile.am
trust/module-init.c [new file with mode: 0644]
trust/module.c

index cb9de25cc0ab63385d0f629430ce8fe2ee71a759..c4a65a3a24bb714f48699114bb9c888cd60a8e56 100644 (file)
@@ -64,7 +64,7 @@ p11_kit_trust_la_LDFLAGS = \
        -export-symbols-regex 'C_GetFunctionList' \
        $(NULL)
 
-p11_kit_trust_la_SOURCES = $(TRUST_SRCS)
+p11_kit_trust_la_SOURCES = $(TRUST_SRCS) trust/module-init.c
 
 libtrust_testable_la_LDFLAGS = \
        -no-undefined
diff --git a/trust/module-init.c b/trust/module-init.c
new file mode 100644 (file)
index 0000000..10c303c
--- /dev/null
@@ -0,0 +1,43 @@
+/*
+ * Copyright (C) 2012 Red Hat Inc.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *
+ *     * Redistributions of source code must retain the above
+ *       copyright notice, this list of conditions and the
+ *       following disclaimer.
+ *     * Redistributions in binary form must reproduce the
+ *       above copyright notice, this list of conditions and
+ *       the following disclaimer in the documentation and/or
+ *       other materials provided with the distribution.
+ *     * The names of contributors to this software may not be
+ *       used to endorse or promote products derived from this
+ *       software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+ * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
+ * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
+ * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
+ * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
+ * DAMAGE.
+ *
+ * Author: Stef Walter <stefw@redhat.com>
+ */
+
+#include "config.h"
+
+#include "module.h"
+#include "library.h"
+
+#define INIT p11_trust_module_init
+#define FINI p11_trust_module_fini
+#define CLEANUP
+#include "init.h"
index fc67a4d6cbcd3a2330721bae3700732b43ab725a..e09113b548c6d950debc0009eaf2550a2622f4de 100644 (file)
@@ -1832,57 +1832,3 @@ 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 ();
-}
-
-#ifdef __GNUC__
-__attribute__((destructor))
-#endif
-void
-p11_trust_module_fini (void)
-{
-       p11_library_uninit ();
-}
-
-#endif /* OS_UNIX */
-
-#ifdef OS_WIN32
-
-BOOL WINAPI DllMain (HINSTANCE, DWORD, LPVOID);
-
-BOOL WINAPI
-DllMain (HINSTANCE instance,
-         DWORD reason,
-         LPVOID reserved)
-{
-       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 */