mirror of
git://git.gnupg.org/gnupg.git
synced 2025-07-02 22:46:30 +02:00
gpg: Avoid multiple open calls to the keybox file.
* g10/keydb.h (KEYDB_HANDLE): Move typedef to ... * g10/gpg.h: here. (struct server_control_s): Add field 'cached_getkey_kdb'. * g10/gpg.c (gpg_deinit_default_ctrl): Release that keydb handle. * g10/getkey.c (getkey_end): Cache keydb handle. (get_pubkey): Use cached keydb handle. * kbx/keybox-search.c (keybox_search_reset): Use lseek instead of closing the file. -- Before this patch a "gpg --check-sigs" opened and closed the keybox file for almost every signature check. By caching the keydb handle and using lseek(2) this can be limited to just 2 times. This might speed up things on Windows. Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
parent
aca5f494a8
commit
5556eca5ac
5 changed files with 33 additions and 11 deletions
23
g10/getkey.c
23
g10/getkey.c
|
@ -736,11 +736,21 @@ get_pubkey (ctrl_t ctrl, PKT_public_key * pk, u32 * keyid)
|
|||
memset (&ctx, 0, sizeof ctx);
|
||||
ctx.exact = 1; /* Use the key ID exactly as given. */
|
||||
ctx.not_allocated = 1;
|
||||
ctx.kr_handle = keydb_new ();
|
||||
if (!ctx.kr_handle)
|
||||
|
||||
if (ctrl && ctrl->cached_getkey_kdb)
|
||||
{
|
||||
rc = gpg_error_from_syserror ();
|
||||
goto leave;
|
||||
ctx.kr_handle = ctrl->cached_getkey_kdb;
|
||||
ctrl->cached_getkey_kdb = NULL;
|
||||
keydb_search_reset (ctx.kr_handle);
|
||||
}
|
||||
else
|
||||
{
|
||||
ctx.kr_handle = keydb_new ();
|
||||
if (!ctx.kr_handle)
|
||||
{
|
||||
rc = gpg_error_from_syserror ();
|
||||
goto leave;
|
||||
}
|
||||
}
|
||||
ctx.nitems = 1;
|
||||
ctx.items[0].mode = KEYDB_SEARCH_MODE_LONG_KID;
|
||||
|
@ -2208,7 +2218,10 @@ getkey_end (ctrl_t ctrl, getkey_ctx_t ctx)
|
|||
{
|
||||
if (ctx)
|
||||
{
|
||||
keydb_release (ctx->kr_handle);
|
||||
if (ctrl && !ctrl->cached_getkey_kdb)
|
||||
ctrl->cached_getkey_kdb = ctx->kr_handle;
|
||||
else
|
||||
keydb_release (ctx->kr_handle);
|
||||
free_strlist (ctx->extra_list);
|
||||
if (!ctx->not_allocated)
|
||||
xfree (ctx);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue