mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-11 13:14:25 +01:00
SCD: Upon error, open_pcsc_reader_wrapped does same as _direct.
* scd/apdu.c (PCSC_E_NO_SERVICE): New. (open_pcsc_reader_direct): Use PCSC_E_NO_SERVICE. (open_pcsc_reader_wrapped): Set pcsc_no_service.
This commit is contained in:
parent
51a4df9d4a
commit
80a34c0b50
11
scd/apdu.c
11
scd/apdu.c
@ -221,6 +221,7 @@ static char (* DLSTDCALL CT_close) (unsigned short ctn);
|
|||||||
#define PCSC_E_SYSTEM_CANCELLED 0x80100012
|
#define PCSC_E_SYSTEM_CANCELLED 0x80100012
|
||||||
#define PCSC_E_NOT_TRANSACTED 0x80100016
|
#define PCSC_E_NOT_TRANSACTED 0x80100016
|
||||||
#define PCSC_E_READER_UNAVAILABLE 0x80100017
|
#define PCSC_E_READER_UNAVAILABLE 0x80100017
|
||||||
|
#define PCSC_E_NO_SERVICE 0x8010001D
|
||||||
#define PCSC_W_REMOVED_CARD 0x80100069
|
#define PCSC_W_REMOVED_CARD 0x80100069
|
||||||
|
|
||||||
#define CM_IOCTL_GET_FEATURE_REQUEST (0x42000000 + 3400)
|
#define CM_IOCTL_GET_FEATURE_REQUEST (0x42000000 + 3400)
|
||||||
@ -1711,7 +1712,7 @@ open_pcsc_reader_direct (const char *portstr)
|
|||||||
pcsc_error_string (err), err);
|
pcsc_error_string (err), err);
|
||||||
reader_table[slot].used = 0;
|
reader_table[slot].used = 0;
|
||||||
unlock_slot (slot);
|
unlock_slot (slot);
|
||||||
if (err == 0x8010001d)
|
if (err == PCSC_E_NO_SERVICE)
|
||||||
pcsc_no_service = 1;
|
pcsc_no_service = 1;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -1819,6 +1820,7 @@ open_pcsc_reader_wrapped (const char *portstr)
|
|||||||
{
|
{
|
||||||
log_error ("can't run PC/SC access module `%s': %s\n",
|
log_error ("can't run PC/SC access module `%s': %s\n",
|
||||||
wrapperpgm, strerror (errno));
|
wrapperpgm, strerror (errno));
|
||||||
|
pcsc_no_service = 1;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1918,6 +1920,8 @@ open_pcsc_reader_wrapped (const char *portstr)
|
|||||||
;
|
;
|
||||||
#undef WAIT
|
#undef WAIT
|
||||||
|
|
||||||
|
pcsc_no_service = 1;
|
||||||
|
|
||||||
/* Now send the open request. */
|
/* Now send the open request. */
|
||||||
msgbuf[0] = 0x01; /* OPEN command. */
|
msgbuf[0] = 0x01; /* OPEN command. */
|
||||||
len = portstr? strlen (portstr):0;
|
len = portstr? strlen (portstr):0;
|
||||||
@ -1950,10 +1954,15 @@ open_pcsc_reader_wrapped (const char *portstr)
|
|||||||
{
|
{
|
||||||
log_error ("PC/SC returned a too large ATR (len=%lx)\n",
|
log_error ("PC/SC returned a too large ATR (len=%lx)\n",
|
||||||
(unsigned long)len);
|
(unsigned long)len);
|
||||||
|
pcsc_no_service = 0;
|
||||||
goto command_failed;
|
goto command_failed;
|
||||||
}
|
}
|
||||||
err = PCSC_ERR_MASK ((msgbuf[5] << 24) | (msgbuf[6] << 16)
|
err = PCSC_ERR_MASK ((msgbuf[5] << 24) | (msgbuf[6] << 16)
|
||||||
| (msgbuf[7] << 8 ) | msgbuf[8]);
|
| (msgbuf[7] << 8 ) | msgbuf[8]);
|
||||||
|
|
||||||
|
if (err != PCSC_E_NO_SERVICE)
|
||||||
|
pcsc_no_service = 0;
|
||||||
|
|
||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("PC/SC OPEN failed: %s (0x%08x)\n",
|
log_error ("PC/SC OPEN failed: %s (0x%08x)\n",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user