diff options
author | Werner Koch <[email protected]> | 2004-12-19 17:44:20 +0000 |
---|---|---|
committer | Werner Koch <[email protected]> | 2004-12-19 17:44:20 +0000 |
commit | 8f22f895e94d45755c99470eb76fd9fd508b5b5f (patch) | |
tree | c428f9546b0f65eeb0189214b1ebabeededd65ec /agent/query.c | |
parent | * maperror.c (map_assuan_err_with_source): Oops, args were swapped. (diff) | |
download | gnupg-8f22f895e94d45755c99470eb76fd9fd508b5b5f.tar.gz gnupg-8f22f895e94d45755c99470eb76fd9fd508b5b5f.zip |
* query.c (initialize_module_query):
* call-scd.c (initialize_module_call_scd): New.
* w32-pth.c (pth_init): Enable debugging depending on env var.
(pth_self): New.
(pth_mutex_release, pth_mutex_acquire): Implemented directly using
the W32 API.
Diffstat (limited to 'agent/query.c')
-rw-r--r-- | agent/query.c | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/agent/query.c b/agent/query.c index b514f6f5e..4aafcbe99 100644 --- a/agent/query.c +++ b/agent/query.c @@ -51,7 +51,7 @@ static ASSUAN_CONTEXT entry_ctx = NULL; #ifdef USE_GNU_PTH -static pth_mutex_t entry_lock = PTH_MUTEX_INIT; +static pth_mutex_t entry_lock; #endif /* data to be passed to our callbacks */ @@ -64,6 +64,25 @@ struct entry_parm_s { +/* This function must be called once to initialize this module. This + has to be done before a second thread is spawned. We can't do the + static initialization because Pth emulation code might not be able + to do a static init; in particualr, it is not possible for W32. */ +void +initialize_module_query (void) +{ +#ifdef USE_GNU_PTH + static int initialized; + + if (!initialized) + if (pth_mutex_init (&entry_lock)) + initialized = 1; +#endif /*USE_GNU_PTH*/ +} + + + + /* Unlock the pinentry so that another thread can start one and disconnect that pinentry - we do this after the unlock so that a stalled pinentry does not block other threads. Fixme: We should |