mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-06 12:33:23 +01:00
scd: Fix selecting additional APP.
* scd/app.c (select_additional_application_internal): Factor out. (select_additional_application): Getting the lock and call select_additional_application_internal, set current_apptype, then. (select_application): Call select_additional_application_internal for Yubikey. Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
This commit is contained in:
parent
4781c4a866
commit
8dc19d35e8
87
scd/app.c
87
scd/app.c
@ -30,6 +30,11 @@
|
|||||||
#include "apdu.h"
|
#include "apdu.h"
|
||||||
#include "../common/tlv.h"
|
#include "../common/tlv.h"
|
||||||
|
|
||||||
|
|
||||||
|
/* Forward declaration of internal function. */
|
||||||
|
static gpg_error_t
|
||||||
|
select_additional_application_internal (card_t card, apptype_t req_apptype);
|
||||||
|
|
||||||
/* Lock to protect the list of cards and its associated
|
/* Lock to protect the list of cards and its associated
|
||||||
* applications. */
|
* applications. */
|
||||||
static npth_mutex_t card_list_lock;
|
static npth_mutex_t card_list_lock;
|
||||||
@ -644,6 +649,22 @@ select_application (ctrl_t ctrl, const char *name, card_t *r_card,
|
|||||||
if (card)
|
if (card)
|
||||||
{
|
{
|
||||||
err = check_application_conflict (card, name, NULL, 0);
|
err = check_application_conflict (card, name, NULL, 0);
|
||||||
|
if (!err)
|
||||||
|
ctrl->current_apptype = card->app ? card->app->apptype : APPTYPE_NONE;
|
||||||
|
else if (gpg_err_code (err) == GPG_ERR_FALSE)
|
||||||
|
{
|
||||||
|
apptype_t req_apptype = apptype_from_name (name);
|
||||||
|
|
||||||
|
if (!req_apptype)
|
||||||
|
err = gpg_error (GPG_ERR_NOT_FOUND);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
err = select_additional_application_internal (card, req_apptype);
|
||||||
|
if (!err)
|
||||||
|
ctrl->current_apptype = req_apptype;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!err)
|
if (!err)
|
||||||
{
|
{
|
||||||
/* Note: We do not use card_ref as we are already locked. */
|
/* Note: We do not use card_ref as we are already locked. */
|
||||||
@ -655,8 +676,6 @@ select_application (ctrl_t ctrl, const char *name, card_t *r_card,
|
|||||||
card->next = card_top;
|
card->next = card_top;
|
||||||
card_top = card;
|
card_top = card;
|
||||||
}
|
}
|
||||||
|
|
||||||
ctrl->current_apptype = card->app ? card->app->apptype : APPTYPE_NONE;
|
|
||||||
}
|
}
|
||||||
unlock_card (card);
|
unlock_card (card);
|
||||||
}
|
}
|
||||||
@ -669,32 +688,13 @@ select_application (ctrl_t ctrl, const char *name, card_t *r_card,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* This function needs to be called with the NAME of the new
|
static gpg_error_t
|
||||||
* application to be selected on CARD. On success the application is
|
select_additional_application_internal (card_t card, apptype_t req_apptype)
|
||||||
* added to the list of the card's active applications as currently
|
|
||||||
* active application. On error no new application is allocated.
|
|
||||||
* Selecting an already selected application has no effect. */
|
|
||||||
gpg_error_t
|
|
||||||
select_additional_application (ctrl_t ctrl, const char *name)
|
|
||||||
{
|
{
|
||||||
gpg_error_t err = 0;
|
gpg_error_t err = 0;
|
||||||
apptype_t req_apptype;
|
app_t app;
|
||||||
card_t card;
|
|
||||||
app_t app = NULL;
|
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
req_apptype = apptype_from_name (name);
|
|
||||||
if (!req_apptype)
|
|
||||||
err = gpg_error (GPG_ERR_NOT_FOUND);
|
|
||||||
|
|
||||||
card = ctrl->card_ctx;
|
|
||||||
if (!card)
|
|
||||||
return gpg_error (GPG_ERR_CARD_NOT_INITIALIZED);
|
|
||||||
|
|
||||||
err = lock_card (card, ctrl);
|
|
||||||
if (err)
|
|
||||||
return err;
|
|
||||||
|
|
||||||
/* Check that the requested app has not yet been put onto the list. */
|
/* Check that the requested app has not yet been put onto the list. */
|
||||||
for (app = card->app; app; app = app->next)
|
for (app = card->app; app; app = app->next)
|
||||||
if (app->apptype == req_apptype)
|
if (app->apptype == req_apptype)
|
||||||
@ -704,8 +704,6 @@ select_additional_application (ctrl_t ctrl, const char *name)
|
|||||||
* maybe_switch_app will do that anyway. */
|
* maybe_switch_app will do that anyway. */
|
||||||
err = 0;
|
err = 0;
|
||||||
app = NULL;
|
app = NULL;
|
||||||
ctrl->current_apptype = req_apptype;
|
|
||||||
log_debug ("current_apptype is set to %s\n", name);
|
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -740,16 +738,49 @@ select_additional_application (ctrl_t ctrl, const char *name)
|
|||||||
* reselect by maybe_switch_app after the select we just did. */
|
* reselect by maybe_switch_app after the select we just did. */
|
||||||
app->next = card->app;
|
app->next = card->app;
|
||||||
card->app = app;
|
card->app = app;
|
||||||
ctrl->current_apptype = app->apptype;
|
|
||||||
log_info ("added app '%s' to the card context\n", strapptype (app->apptype));
|
log_info ("added app '%s' to the card context\n", strapptype (app->apptype));
|
||||||
|
|
||||||
leave:
|
leave:
|
||||||
unlock_card (card);
|
|
||||||
if (err)
|
if (err)
|
||||||
xfree (app);
|
xfree (app);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* This function needs to be called with the NAME of the new
|
||||||
|
* application to be selected on CARD. On success the application is
|
||||||
|
* added to the list of the card's active applications as currently
|
||||||
|
* active application. On error no new application is allocated.
|
||||||
|
* Selecting an already selected application has no effect. */
|
||||||
|
gpg_error_t
|
||||||
|
select_additional_application (ctrl_t ctrl, const char *name)
|
||||||
|
{
|
||||||
|
gpg_error_t err = 0;
|
||||||
|
apptype_t req_apptype;
|
||||||
|
card_t card;
|
||||||
|
|
||||||
|
req_apptype = apptype_from_name (name);
|
||||||
|
if (!req_apptype)
|
||||||
|
err = gpg_error (GPG_ERR_NOT_FOUND);
|
||||||
|
|
||||||
|
card = ctrl->card_ctx;
|
||||||
|
if (!card)
|
||||||
|
return gpg_error (GPG_ERR_CARD_NOT_INITIALIZED);
|
||||||
|
|
||||||
|
err = lock_card (card, ctrl);
|
||||||
|
if (err)
|
||||||
|
return err;
|
||||||
|
|
||||||
|
err = select_additional_application_internal (card, req_apptype);
|
||||||
|
if (!err)
|
||||||
|
{
|
||||||
|
ctrl->current_apptype = req_apptype;
|
||||||
|
log_debug ("current_apptype is set to %s\n", name);
|
||||||
|
}
|
||||||
|
|
||||||
|
unlock_card (card);
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
char *
|
char *
|
||||||
get_supported_applications (void)
|
get_supported_applications (void)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user