1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-10 13:04:23 +01:00

scd: Handle CCID bwi of time extension.

* scd/ccid-driver.c (bulk_in): Increase timeout by the multiplier
value as defined section 6.2.6 in CCID specification.

--

Backport master commit of:
	996c497a864d820af06333014b2c5f74d1054866

For TPDU level transfer, it was handled.  This is fix for APDU level
transfer.

GnuPG-bug-id: 4646
Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
This commit is contained in:
NIIBE Yutaka 2019-07-25 09:16:46 +09:00
parent f8961a576d
commit 879660bf45

View File

@ -1946,6 +1946,7 @@ bulk_in (ccid_driver_t handle, unsigned char *buffer, size_t length,
int rc; int rc;
int msglen; int msglen;
int notified = 0; int notified = 0;
int bwi = 1;
/* Fixme: The next line for the current Valgrind without support /* Fixme: The next line for the current Valgrind without support
for USB IOCTLs. */ for USB IOCTLs. */
@ -1956,7 +1957,7 @@ bulk_in (ccid_driver_t handle, unsigned char *buffer, size_t length,
npth_unprotect (); npth_unprotect ();
#endif #endif
rc = libusb_bulk_transfer (handle->idev, handle->ep_bulk_in, rc = libusb_bulk_transfer (handle->idev, handle->ep_bulk_in,
(char*)buffer, length, &msglen, timeout); buffer, length, &msglen, bwi*timeout);
#ifdef USE_NPTH #ifdef USE_NPTH
npth_protect (); npth_protect ();
#endif #endif
@ -2004,6 +2005,10 @@ bulk_in (ccid_driver_t handle, unsigned char *buffer, size_t length,
DEBUGOUT_2 ("time extension requested (%02X,%02X)\n", DEBUGOUT_2 ("time extension requested (%02X,%02X)\n",
buffer[7], buffer[8]); buffer[7], buffer[8]);
bwi = 1;
if (buffer[8] != 0 && buffer[8] != 0xff)
bwi = buffer[8];
/* Gnuk enhancement to prompt user input by ack button */ /* Gnuk enhancement to prompt user input by ack button */
if (buffer[8] == 0xff && !notified) if (buffer[8] == 0xff && !notified)
{ {