mirror of
git://git.gnupg.org/gnupg.git
synced 2025-07-03 22:56:33 +02:00
card: Run factory-reset in locked stated also in gpg-card.
* tools/card-call-scd.c (scd_apdu): Add more pseudo APDUs. * tools/card-misc.c (send_apdu): Handle them. * tools/gpg-card.c (cmd_factoryreset): Use lock commands. -- This is port of the code used with gpg-card-edit. Note that the command "apdu" now also understands some extra keywords. Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
parent
8fb0d5e3c7
commit
12fd10791f
4 changed files with 57 additions and 12 deletions
|
@ -92,8 +92,13 @@ send_apdu (const char *hexapdu, const char *desc, unsigned int ignore,
|
|||
if (err)
|
||||
log_error ("sending card command %s failed: %s\n", desc,
|
||||
gpg_strerror (err));
|
||||
else if (!hexapdu || !strcmp (hexapdu, "undefined"))
|
||||
;
|
||||
else if (!hexapdu
|
||||
|| !strcmp (hexapdu, "undefined")
|
||||
|| !strcmp (hexapdu, "reset-keep-lock")
|
||||
|| !strcmp (hexapdu, "lock")
|
||||
|| !strcmp (hexapdu, "trylock")
|
||||
|| !strcmp (hexapdu, "unlock"))
|
||||
; /* Ignore pseudo APDUs. */
|
||||
else if (ignore == 0xffff)
|
||||
; /* Ignore all status words. */
|
||||
else if (sw != 0x9000)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue