summaryrefslogtreecommitdiff
path: root/p11-kit
diff options
context:
space:
mode:
Diffstat (limited to 'p11-kit')
-rw-r--r--p11-kit/proxy.c35
1 files changed, 14 insertions, 21 deletions
diff --git a/p11-kit/proxy.c b/p11-kit/proxy.c
index fae603c..5cd49bc 100644
--- a/p11-kit/proxy.c
+++ b/p11-kit/proxy.c
@@ -88,12 +88,12 @@ typedef struct {
typedef struct _State {
p11_virtual virt;
struct _State *next;
+ CK_FUNCTION_LIST **loaded;
CK_FUNCTION_LIST *wrapped;
CK_ULONG last_handle;
Proxy *px;
} State;
-static CK_FUNCTION_LIST **all_modules = NULL;
static State *all_instances = NULL;
static State global = { { { { -1, -1 }, NULL, }, }, NULL, NULL, FIRST_HANDLE, NULL };
@@ -248,7 +248,8 @@ modules_dup (CK_FUNCTION_LIST **modules)
}
static CK_RV
-proxy_create (Proxy **res, Mapping *mappings, unsigned int n_mappings)
+proxy_create (Proxy **res, CK_FUNCTION_LIST **loaded,
+ Mapping *mappings, unsigned int n_mappings)
{
CK_FUNCTION_LIST_PTR *f;
CK_FUNCTION_LIST_PTR funcs;
@@ -263,7 +264,7 @@ proxy_create (Proxy **res, Mapping *mappings, unsigned int n_mappings)
py->forkid = p11_forkid;
- py->inited = modules_dup (all_modules);
+ py->inited = modules_dup (loaded);
return_val_if_fail (py->inited != NULL, CKR_HOST_MEMORY);
rv = p11_kit_modules_initialize (py->inited, NULL);
@@ -370,7 +371,7 @@ proxy_C_Initialize (CK_X_FUNCTION_LIST *self,
return CKR_OK;
}
- rv = proxy_create (&py, mappings, n_mappings);
+ rv = proxy_create (&py, state->loaded, mappings, n_mappings);
free (mappings);
if (rv != CKR_OK) {
p11_debug ("out: %lu", rv);
@@ -1661,24 +1662,15 @@ CK_RV
C_GetFunctionList (CK_FUNCTION_LIST_PTR_PTR list)
{
CK_FUNCTION_LIST_PTR module = NULL;
- CK_FUNCTION_LIST **loaded;
+ CK_FUNCTION_LIST **loaded = NULL;
State *state;
CK_RV rv = CKR_OK;
p11_library_init_once ();
p11_lock ();
- if (all_modules == NULL) {
- /* WARNING: Reentrancy can occur here */
- rv = p11_modules_load_inlock_reentrant (P11_KIT_MODULE_LOADED_FROM_PROXY, &loaded);
- if (rv == CKR_OK) {
- if (all_modules == NULL)
- all_modules = loaded;
- else
- p11_modules_release_inlock_reentrant (loaded);
- }
- }
-
+ /* WARNING: Reentrancy can occur here */
+ rv = p11_modules_load_inlock_reentrant (P11_KIT_MODULE_LOADED_FROM_PROXY, &loaded);
if (rv == CKR_OK) {
state = calloc (1, sizeof (State));
if (!state) {
@@ -1687,6 +1679,8 @@ C_GetFunctionList (CK_FUNCTION_LIST_PTR_PTR list)
} else {
p11_virtual_init (&state->virt, &proxy_functions, state, NULL);
state->last_handle = FIRST_HANDLE;
+ state->loaded = loaded;
+ loaded = NULL;
module = p11_virtual_wrap (&state->virt, free);
if (module == NULL) {
@@ -1706,6 +1700,9 @@ C_GetFunctionList (CK_FUNCTION_LIST_PTR_PTR list)
*list = module;
}
+ if (loaded)
+ p11_kit_modules_release (loaded);
+
p11_unlock ();
return rv;
@@ -1722,11 +1719,7 @@ p11_proxy_module_cleanup (void)
for (; state != NULL; state = next) {
next = state->next;
p11_virtual_unwrap (state->wrapped);
- }
-
- if (all_modules) {
- p11_kit_modules_release (all_modules);
- all_modules = NULL;
+ p11_kit_modules_release (state->loaded);
}
}