mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-21 14:47:03 +01:00
scd: Internal CCID driver thing only for SPR532.
* scd/ccid-driver.c (ccid_vendor_specific_setup): New. Limit only for SPR532, excluding other readers by SCM. (ccid_slot_status): Use ccid_vendor_specific_setup. -- We follow the setup procedure of libccid implementation, which sends the escape command for SPR532 only. Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
This commit is contained in:
parent
d1c9cc3ca0
commit
38040ffee8
@ -1299,6 +1299,19 @@ ccid_vendor_specific_init (ccid_driver_t handle)
|
||||
}
|
||||
|
||||
|
||||
static int
|
||||
ccid_vendor_specific_setup (ccid_driver_t handle)
|
||||
{
|
||||
if (handle->id_vendor == VENDOR_SCM && handle->id_product == SCM_SPR532)
|
||||
{
|
||||
DEBUGOUT ("sending escape sequence to switch to a case 1 APDU\n");
|
||||
send_escape_cmd (handle, (const unsigned char*)"\x80\x02\x00", 3,
|
||||
NULL, 0, NULL);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
#define MAX_DEVICE 4 /* See MAX_READER in apdu.c. */
|
||||
|
||||
struct ccid_dev_table {
|
||||
@ -2428,12 +2441,7 @@ ccid_slot_status (ccid_driver_t handle, int *statusbits, int on_wire)
|
||||
if (handle->transfer == NULL)
|
||||
{
|
||||
ccid_setup_intr (handle);
|
||||
if (handle->id_vendor == VENDOR_SCM)
|
||||
{
|
||||
DEBUGOUT ("sending escape sequence to switch to a case 1 APDU\n");
|
||||
send_escape_cmd (handle, (const unsigned char*)"\x80\x02\x00", 3,
|
||||
NULL, 0, NULL);
|
||||
}
|
||||
ccid_vendor_specific_setup (handle);
|
||||
}
|
||||
|
||||
*statusbits = 0;
|
||||
|
Loading…
x
Reference in New Issue
Block a user