mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-23 15:07:03 +01:00
card: Take care of removed and re-inserted cards.
* tools/gpg-card.c (cmd_list): Take care of the need_sn_cmd flag. (cmd_factoryreset): Clear that flag. (dispatch_command): Set flag after a reset and after a CARD_NOT_PRESENT error. --
This commit is contained in:
parent
c2a47475ba
commit
46a3de4b5a
@ -1141,13 +1141,15 @@ cmd_list (card_info_t info, char *argstr)
|
|||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!info->serialno)
|
if (!info->serialno || info->need_sn_cmd)
|
||||||
{
|
{
|
||||||
/* This is probably the first call. We need to send a SERIALNO
|
/* This is probably the first call or was explictly requested.
|
||||||
* command to scd so that our session knows all cards. */
|
* We need to send a SERIALNO command to scdaemon so that our
|
||||||
|
* session knows all cards. */
|
||||||
err = scd_serialno (NULL, NULL);
|
err = scd_serialno (NULL, NULL);
|
||||||
if (err)
|
if (err)
|
||||||
goto leave;
|
goto leave;
|
||||||
|
info->need_sn_cmd = 0;
|
||||||
need_learn = 1;
|
need_learn = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2807,6 +2809,8 @@ cmd_factoryreset (card_info_t info)
|
|||||||
|
|
||||||
/* Then, connect the card again. */
|
/* Then, connect the card again. */
|
||||||
err = scd_serialno (NULL, NULL);
|
err = scd_serialno (NULL, NULL);
|
||||||
|
if (!err)
|
||||||
|
info->need_sn_cmd = 0;
|
||||||
|
|
||||||
leave:
|
leave:
|
||||||
if (err && any_apdu && !is_yubikey)
|
if (err && any_apdu && !is_yubikey)
|
||||||
@ -3272,6 +3276,8 @@ dispatch_command (card_info_t info, const char *orig_command)
|
|||||||
{
|
{
|
||||||
flush_keyblock_cache ();
|
flush_keyblock_cache ();
|
||||||
err = scd_apdu (NULL, NULL, NULL, NULL);
|
err = scd_apdu (NULL, NULL, NULL, NULL);
|
||||||
|
if (!err)
|
||||||
|
info->need_sn_cmd = 1;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -3318,7 +3324,11 @@ dispatch_command (card_info_t info, const char *orig_command)
|
|||||||
err = 0;
|
err = 0;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
log_error ("Command '%s' failed: %s\n", command, gpg_strerror (err));
|
log_error ("Command '%s' failed: %s\n", command, gpg_strerror (err));
|
||||||
|
if (gpg_err_code (err) == GPG_ERR_CARD_NOT_PRESENT)
|
||||||
|
info->need_sn_cmd = 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
xfree (command);
|
xfree (command);
|
||||||
|
|
||||||
@ -3485,6 +3495,8 @@ interactive_loop (void)
|
|||||||
{
|
{
|
||||||
flush_keyblock_cache ();
|
flush_keyblock_cache ();
|
||||||
err = scd_apdu (NULL, NULL, NULL, NULL);
|
err = scd_apdu (NULL, NULL, NULL, NULL);
|
||||||
|
if (!err)
|
||||||
|
info->need_sn_cmd = 1;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -3538,6 +3550,8 @@ interactive_loop (void)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
log_error ("Command '%s' failed: %s\n", s, gpg_strerror (err));
|
log_error ("Command '%s' failed: %s\n", s, gpg_strerror (err));
|
||||||
|
if (gpg_err_code (err) == GPG_ERR_CARD_NOT_PRESENT)
|
||||||
|
info->need_sn_cmd = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
} /* End of main menu loop. */
|
} /* End of main menu loop. */
|
||||||
|
@ -138,6 +138,7 @@ typedef struct key_info_s *key_info_t;
|
|||||||
struct card_info_s
|
struct card_info_s
|
||||||
{
|
{
|
||||||
int initialized; /* True if a learn command was successful. */
|
int initialized; /* True if a learn command was successful. */
|
||||||
|
int need_sn_cmd; /* The SERIALNO command needs to be issued. */
|
||||||
int error; /* private. */
|
int error; /* private. */
|
||||||
char *reader; /* Reader information. */
|
char *reader; /* Reader information. */
|
||||||
char *cardtype; /* NULL or type of the card. */
|
char *cardtype; /* NULL or type of the card. */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user