diff --git a/g10/call-keyboxd.c b/g10/call-keyboxd.c index e0ee26e6b..e75b786a0 100644 --- a/g10/call-keyboxd.c +++ b/g10/call-keyboxd.c @@ -190,7 +190,7 @@ open_context (ctrl_t ctrl, keyboxd_local_t *r_kbl) return err; } - err = kbx_client_data_new (&kbl->kcd, kbl->ctx); + err = kbx_client_data_new (&kbl->kcd, kbl->ctx, 1); if (err) { assuan_release (kbl->ctx); diff --git a/kbx/kbx-client-util.c b/kbx/kbx-client-util.c index ba356b3c5..910050372 100644 --- a/kbx/kbx-client-util.c +++ b/kbx/kbx-client-util.c @@ -270,10 +270,12 @@ datastream_thread (void *arg) /* Create a new keyboxd client data object and return it at R_KCD. - * CTX is the assuan context to be used for connecting the - * keyboxd. */ + * CTX is the assuan context to be used for connecting the keyboxd. + * If dlines is set, communication is done without fd passing via + * D-lines. */ gpg_error_t -kbx_client_data_new (kbx_client_data_t *r_kcd, assuan_context_t ctx) +kbx_client_data_new (kbx_client_data_t *r_kcd, assuan_context_t ctx, + int dlines) { kbx_client_data_t kcd; int rc; @@ -285,6 +287,9 @@ kbx_client_data_new (kbx_client_data_t *r_kcd, assuan_context_t ctx) kcd->ctx = ctx; + if (dlines) + goto leave; + rc = npth_mutex_init (&kcd->mutex, NULL); if (rc) { @@ -312,6 +317,7 @@ kbx_client_data_new (kbx_client_data_t *r_kcd, assuan_context_t ctx) return err; } + leave: *r_kcd = kcd; return 0; } diff --git a/kbx/kbx-client-util.h b/kbx/kbx-client-util.h index db6cb9475..1cc68b5a0 100644 --- a/kbx/kbx-client-util.h +++ b/kbx/kbx-client-util.h @@ -26,7 +26,7 @@ struct kbx_client_data_s; typedef struct kbx_client_data_s *kbx_client_data_t; gpg_error_t kbx_client_data_new (kbx_client_data_t *r_kcd, - assuan_context_t ctx); + assuan_context_t ctx, int dlines); void kbx_client_data_release (kbx_client_data_t kcd); gpg_error_t kbx_client_data_cmd (kbx_client_data_t kcd, const char *command, gpg_error_t (*status_cb)(void *opaque, diff --git a/sm/keydb.c b/sm/keydb.c index ca32162d1..d7525bd76 100644 --- a/sm/keydb.c +++ b/sm/keydb.c @@ -570,7 +570,7 @@ open_context (ctrl_t ctrl, keydb_local_t *r_kbl) return err; } - err = kbx_client_data_new (&kbl->kcd, kbl->ctx); + err = kbx_client_data_new (&kbl->kcd, kbl->ctx, 1); if (err) { assuan_release (kbl->ctx);