mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-08 12:44:23 +01:00
scd: Fix Cherry ST-2000 support for pinpad input.
* scd/apdu.c (pcsc_vendor_specific_init): Set pinmax to 15. * scd/ccid-driver.c (ccid_transceive_secure): Add zero for the template of APDU. -- (backport from 2.1 commit 444e9232aa9e00aacd939cbf7bdb881b550dfebe) GnuPG-bug-id: 2003, 2004
This commit is contained in:
parent
be34857939
commit
9200bf1bab
16
scd/apdu.c
16
scd/apdu.c
@ -1784,8 +1784,12 @@ pcsc_vendor_specific_init (int slot)
|
|||||||
reader_table[slot].is_spr532 = 1;
|
reader_table[slot].is_spr532 = 1;
|
||||||
reader_table[slot].pinpad_varlen_supported = 1;
|
reader_table[slot].pinpad_varlen_supported = 1;
|
||||||
}
|
}
|
||||||
else if (strstr (reader_table[slot].rdrname, "ST-2xxx")
|
else if (strstr (reader_table[slot].rdrname, "ST-2xxx"))
|
||||||
|| strstr (reader_table[slot].rdrname, "cyberJack")
|
{
|
||||||
|
reader_table[slot].pcsc.pinmax = 15;
|
||||||
|
reader_table[slot].pinpad_varlen_supported = 1;
|
||||||
|
}
|
||||||
|
else if (strstr (reader_table[slot].rdrname, "cyberJack")
|
||||||
|| strstr (reader_table[slot].rdrname, "DIGIPASS")
|
|| strstr (reader_table[slot].rdrname, "DIGIPASS")
|
||||||
|| strstr (reader_table[slot].rdrname, "Gnuk")
|
|| strstr (reader_table[slot].rdrname, "Gnuk")
|
||||||
|| strstr (reader_table[slot].rdrname, "KAAN"))
|
|| strstr (reader_table[slot].rdrname, "KAAN"))
|
||||||
@ -1850,8 +1854,12 @@ pcsc_vendor_specific_init (int slot)
|
|||||||
reader_table[slot].is_spr532 = 1;
|
reader_table[slot].is_spr532 = 1;
|
||||||
reader_table[slot].pinpad_varlen_supported = 1;
|
reader_table[slot].pinpad_varlen_supported = 1;
|
||||||
}
|
}
|
||||||
else if ((vendor == 0x046a && product == 0x003e) /* Cherry ST-2xxx */
|
else if (vendor == 0x046a && product == 0x003e) /* Cherry ST-2xxx */
|
||||||
|| vendor == 0x0c4b /* Tested with Reiner cyberJack GO */
|
{
|
||||||
|
reader_table[slot].pcsc.pinmax = 15;
|
||||||
|
reader_table[slot].pinpad_varlen_supported = 1;
|
||||||
|
}
|
||||||
|
else if (vendor == 0x0c4b /* Tested with Reiner cyberJack GO */
|
||||||
|| vendor == 0x1a44 /* Tested with Vasco DIGIPASS 920 */
|
|| vendor == 0x1a44 /* Tested with Vasco DIGIPASS 920 */
|
||||||
|| vendor == 0x234b /* Tested with FSIJ Gnuk Token */
|
|| vendor == 0x234b /* Tested with FSIJ Gnuk Token */
|
||||||
|| vendor == 0x0d46 /* Tested with KAAN Advanced??? */)
|
|| vendor == 0x0d46 /* Tested with KAAN Advanced??? */)
|
||||||
|
@ -3355,6 +3355,7 @@ ccid_transceive_secure (ccid_driver_t handle,
|
|||||||
size_t dummy_nresp;
|
size_t dummy_nresp;
|
||||||
int testmode;
|
int testmode;
|
||||||
int cherry_mode = 0;
|
int cherry_mode = 0;
|
||||||
|
int add_zero = 0;
|
||||||
int enable_varlen = 0;
|
int enable_varlen = 0;
|
||||||
|
|
||||||
testmode = !resp && !nresp;
|
testmode = !resp && !nresp;
|
||||||
@ -3396,7 +3397,7 @@ ccid_transceive_secure (ccid_driver_t handle,
|
|||||||
enable_varlen = 1;
|
enable_varlen = 1;
|
||||||
break;
|
break;
|
||||||
case VENDOR_CHERRY:
|
case VENDOR_CHERRY:
|
||||||
pininfo->maxlen = 25;
|
pininfo->maxlen = 15;
|
||||||
enable_varlen = 1;
|
enable_varlen = 1;
|
||||||
/* The CHERRY XX44 keyboard echos an asterisk for each entered
|
/* The CHERRY XX44 keyboard echos an asterisk for each entered
|
||||||
character on the keyboard channel. We use a special variant
|
character on the keyboard channel. We use a special variant
|
||||||
@ -3405,6 +3406,7 @@ ccid_transceive_secure (ccid_driver_t handle,
|
|||||||
Lc byte to the APDU. It seems that it will be replaced with
|
Lc byte to the APDU. It seems that it will be replaced with
|
||||||
the actual length instead of being appended before the APDU
|
the actual length instead of being appended before the APDU
|
||||||
is send to the card. */
|
is send to the card. */
|
||||||
|
add_zero = 1;
|
||||||
if (handle->id_product != CHERRY_ST2000)
|
if (handle->id_product != CHERRY_ST2000)
|
||||||
cherry_mode = 1;
|
cherry_mode = 1;
|
||||||
break;
|
break;
|
||||||
@ -3527,7 +3529,7 @@ ccid_transceive_secure (ccid_driver_t handle,
|
|||||||
msg[msglen++] = apdu_buf[1]; /* INS */
|
msg[msglen++] = apdu_buf[1]; /* INS */
|
||||||
msg[msglen++] = apdu_buf[2]; /* P1 */
|
msg[msglen++] = apdu_buf[2]; /* P1 */
|
||||||
msg[msglen++] = apdu_buf[3]; /* P2 */
|
msg[msglen++] = apdu_buf[3]; /* P2 */
|
||||||
if (cherry_mode)
|
if (add_zero)
|
||||||
msg[msglen++] = 0;
|
msg[msglen++] = 0;
|
||||||
else if (pininfo->fixedlen != 0)
|
else if (pininfo->fixedlen != 0)
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user