From c933c15d587a1c0df3f4b3bf37d8d15164dd318f Mon Sep 17 00:00:00 2001 From: NIIBE Yutaka Date: Tue, 15 Oct 2019 09:40:01 +0900 Subject: scd,ccid: Add 08e6:34c2 (GEMPC_EZIO). * scd/ccid-driver.c (ccid_transceive_secure): Add pinpad support for 08e6:34c2 which supports extended APDU exchange. Signed-off-by: NIIBE Yutaka --- scd/ccid-driver.c | 28 +++++++++++++++++++++------- scd/ccid-driver.h | 1 + 2 files changed, 22 insertions(+), 7 deletions(-) diff --git a/scd/ccid-driver.c b/scd/ccid-driver.c index d3e9ef024..fe7937d62 100644 --- a/scd/ccid-driver.c +++ b/scd/ccid-driver.c @@ -3435,15 +3435,29 @@ ccid_transceive_secure (ccid_driver_t handle, cherry_mode = 1; break; case VENDOR_NXP: - if (handle->id_product == CRYPTOUCAN){ - pininfo->maxlen = 25; - enable_varlen = 1; - } + if (handle->id_product == CRYPTOUCAN) + { + pininfo->maxlen = 25; + enable_varlen = 1; + } + break; + case VENDOR_GEMPC: + if (handle->id_product == GEMPC_PINPAD) + { + pininfo->maxlen = 25; + enable_varlen = 1; + break; + } + else if (handle->id_product == GEMPC_EZIO) + { + enable_varlen = 0; + pininfo->minlen = 4; + pininfo->maxlen = 8; + break; + } break; default: - if ((handle->id_vendor == VENDOR_GEMPC && - handle->id_product == GEMPC_PINPAD) - || (handle->id_vendor == VENDOR_VEGA && + if ((handle->id_vendor == VENDOR_VEGA && handle->id_product == VEGA_ALPHA)) { enable_varlen = 0; diff --git a/scd/ccid-driver.h b/scd/ccid-driver.h index 8e7ff4482..e1ef98202 100644 --- a/scd/ccid-driver.h +++ b/scd/ccid-driver.h @@ -83,6 +83,7 @@ enum { #define VASCO_920 0x0920 #define GEMPC_PINPAD 0x3478 #define GEMPC_CT30 0x3437 +#define GEMPC_EZIO 0x34c2 /* (!=34c0) Also known as IDBridge CT710 */ #define VEGA_ALPHA 0x0008 #define CYBERJACK_GO 0x0504 #define CRYPTOUCAN 0x81e6 -- cgit v1.2.3