60 #ifdef PCSCLITE_STATIC_DRIVER 63 #if ! (defined(IFDHANDLERv2) || defined(IFDHANDLERv3)) 64 #error IFDHANDLER version not defined 73 UCHAR ucPTS1, UCHAR ucPTS2, UCHAR ucPTS3)
77 #ifndef PCSCLITE_STATIC_DRIVER 78 RESPONSECODE(*IFDH_set_protocol_parameters) (DWORD, DWORD, UCHAR,
79 UCHAR, UCHAR, UCHAR) = NULL;
81 IFDH_set_protocol_parameters = (RESPONSECODE(*)(DWORD, DWORD, UCHAR,
85 if (NULL == IFDH_set_protocol_parameters)
96 #ifndef PCSCLITE_STATIC_DRIVER 97 rv = (*IFDH_set_protocol_parameters) (rContext->
slot,
98 dwProtocol, ucFlags, ucPTS1, ucPTS2, ucPTS3);
101 ucPTS1, ucPTS2, ucPTS3);
114 #ifndef PCSCLITE_STATIC_DRIVER 115 RESPONSECODE(*IFDH_create_channel) (DWORD, DWORD) = NULL;
116 RESPONSECODE(*IFDH_create_channel_by_name) (DWORD, LPSTR) = NULL;
118 if (rContext->
version == IFD_HVERSION_2_0)
119 IFDH_create_channel =
123 IFDH_create_channel =
125 IFDH_create_channel_by_name =
131 (void)pthread_mutex_lock(rContext->
mMutex);
133 #ifndef PCSCLITE_STATIC_DRIVER 134 if (rContext->
version == IFD_HVERSION_2_0)
136 rv = (*IFDH_create_channel) (rContext->
slot, rContext->
port);
140 if (rContext->
device[0] !=
'\0')
141 rv = (*IFDH_create_channel_by_name) (rContext->
slot, rContext->
device);
143 rv = (*IFDH_create_channel) (rContext->
slot, rContext->
port);
146 #if defined(IFDHANDLERv2) 151 if (rContext->
device[0] !=
'\0')
160 (void)pthread_mutex_unlock(rContext->
mMutex);
173 #ifndef PCSCLITE_STATIC_DRIVER 174 RESPONSECODE(*IFDH_close_channel) (DWORD) = NULL;
182 rv = pthread_mutex_trylock(rContext->
mMutex);
185 Log1(PCSC_LOG_ERROR,
"Locking failed");
194 #ifndef PCSCLITE_STATIC_DRIVER 195 rv = (*IFDH_close_channel) (rContext->
slot);
201 (void)pthread_mutex_unlock(rContext->
mMutex);
210 DWORD dwLength, PUCHAR pucValue)
214 #ifndef PCSCLITE_STATIC_DRIVER 215 RESPONSECODE(*IFDH_set_capabilities) (DWORD, DWORD, DWORD, PUCHAR) = NULL;
225 #ifndef PCSCLITE_STATIC_DRIVER 226 rv = (*IFDH_set_capabilities) (rContext->
slot, dwTag,
241 PDWORD pdwLength, PUCHAR pucValue)
245 #ifndef PCSCLITE_STATIC_DRIVER 246 RESPONSECODE(*IFDH_get_capabilities) (DWORD, DWORD, PDWORD, PUCHAR) = NULL;
248 IFDH_get_capabilities =
253 (void)pthread_mutex_lock(rContext->
mMutex);
255 #ifndef PCSCLITE_STATIC_DRIVER 256 rv = (*IFDH_get_capabilities) (rContext->
slot, dwTag, pdwLength, pucValue);
262 (void)pthread_mutex_unlock(rContext->
mMutex);
271 PUCHAR pucAtr, PDWORD pdwAtrLen)
276 DWORD dummyAtrLen =
sizeof(dummyAtr);
278 #ifndef PCSCLITE_STATIC_DRIVER 279 RESPONSECODE(*IFDH_power_icc) (DWORD, DWORD, PUCHAR, PDWORD) = NULL;
289 if (NULL == pdwAtrLen)
290 pdwAtrLen = &dummyAtrLen;
306 #ifndef PCSCLITE_STATIC_DRIVER 311 (void)pthread_mutex_lock(rContext->
mMutex);
313 #ifndef PCSCLITE_STATIC_DRIVER 314 rv = (*IFDH_power_icc) (rContext->
slot, dwAction, pucAtr, pdwAtrLen);
320 (void)pthread_mutex_unlock(rContext->
mMutex);
330 (void)SendHotplugSignal();
347 DWORD dwCardStatus = 0;
349 #ifndef PCSCLITE_STATIC_DRIVER 350 RESPONSECODE(*IFDH_icc_presence) (DWORD) = NULL;
356 (void)pthread_mutex_lock(rContext->
mMutex);
358 #ifndef PCSCLITE_STATIC_DRIVER 359 rv = (*IFDH_icc_presence) (rContext->
slot);
365 (void)pthread_mutex_unlock(rContext->
mMutex);
374 Log2(PCSC_LOG_ERROR,
"Card not transacted: %ld", rv);
379 (void)SendHotplugSignal();
386 *pdwStatus = dwCardStatus;
402 DWORD TxLength, PUCHAR RxBuffer, PDWORD RxLength)
406 #ifndef PCSCLITE_STATIC_DRIVER 407 RESPONSECODE(*IFDH_control_v2) (DWORD, PUCHAR, DWORD, PUCHAR,
411 if (rContext->
version != IFD_HVERSION_2_0)
414 #ifndef PCSCLITE_STATIC_DRIVER 419 (void)pthread_mutex_lock(rContext->
mMutex);
421 #ifndef PCSCLITE_STATIC_DRIVER 422 rv = (*IFDH_control_v2) (rContext->
slot, TxBuffer, TxLength,
424 #elif defined(IFDHANDLERv2) 430 (void)pthread_mutex_unlock(rContext->
mMutex);
436 Log2(PCSC_LOG_ERROR,
"Card not transacted: %ld", rv);
437 LogXxd(PCSC_LOG_DEBUG,
"TxBuffer ", TxBuffer, TxLength);
438 LogXxd(PCSC_LOG_DEBUG,
"RxBuffer ", RxBuffer, *RxLength);
453 LPCVOID TxBuffer, DWORD TxLength, LPVOID RxBuffer, DWORD RxLength,
454 LPDWORD BytesReturned)
458 #ifndef PCSCLITE_STATIC_DRIVER 459 RESPONSECODE(*IFDH_control) (DWORD, DWORD, LPCVOID, DWORD, LPVOID, DWORD, LPDWORD);
462 if (rContext->
version < IFD_HVERSION_3_0)
465 #ifndef PCSCLITE_STATIC_DRIVER 470 (void)pthread_mutex_lock(rContext->
mMutex);
472 #ifndef PCSCLITE_STATIC_DRIVER 473 rv = (*IFDH_control) (rContext->
slot, ControlCode, TxBuffer,
474 TxLength, RxBuffer, RxLength, BytesReturned);
475 #elif defined(IFDHANDLERv3) 477 TxLength, RxBuffer, RxLength, BytesReturned);
481 (void)pthread_mutex_unlock(rContext->
mMutex);
487 Log2(PCSC_LOG_ERROR,
"Card not transacted: %ld", rv);
488 Log3(PCSC_LOG_DEBUG,
"ControlCode: 0x%.8lX BytesReturned: %ld",
489 ControlCode, *BytesReturned);
490 LogXxd(PCSC_LOG_DEBUG,
"TxBuffer ", TxBuffer, TxLength);
491 LogXxd(PCSC_LOG_DEBUG,
"RxBuffer ", RxBuffer, *BytesReturned);
495 (void)SendHotplugSignal();
513 PUCHAR pucTxBuffer, DWORD dwTxLength, PUCHAR pucRxBuffer,
518 #ifndef PCSCLITE_STATIC_DRIVER 524 DebugLogCategory(DEBUG_CATEGORY_APDU, pucTxBuffer, dwTxLength);
526 #ifndef PCSCLITE_STATIC_DRIVER 527 IFDH_transmit_to_icc =
532 (void)pthread_mutex_lock(rContext->
mMutex);
534 #ifndef PCSCLITE_STATIC_DRIVER 535 rv = (*IFDH_transmit_to_icc) (rContext->
slot, pioTxPci, (LPBYTE)
536 pucTxBuffer, dwTxLength, pucRxBuffer, pdwRxLength, pioRxPci);
539 (LPBYTE) pucTxBuffer, dwTxLength,
540 pucRxBuffer, pdwRxLength, pioRxPci);
544 (void)pthread_mutex_unlock(rContext->
mMutex);
547 DebugLogCategory(DEBUG_CATEGORY_SW, pucRxBuffer, *pdwRxLength);
553 Log2(PCSC_LOG_ERROR,
"Card not transacted: %ld", rv);
557 (void)SendHotplugSignal();
RESPONSECODE IFDHTransmitToICC(DWORD Lun, SCARD_IO_HEADER SendPci, PUCHAR TxBuffer, DWORD TxLength, PUCHAR RxBuffer, PDWORD RxLength, PSCARD_IO_HEADER RecvPci)
This function performs an APDU exchange with the card/slot specified by Lun.
LONG IFDStatusICC(READER_CONTEXT *rContext, PDWORD pdwStatus)
Provide statistical information about the IFD and ICC including insertions, atr, powering status/etc...
This abstracts dynamic library loading functions.
#define IFD_NO_SUCH_DEVICE
The IFD_NO_SUCH_DEVICE error must be returned by the driver when it detects the reader is no more pre...
LONG IFDSetPTS(READER_CONTEXT *rContext, DWORD dwProtocol, UCHAR ucFlags, UCHAR ucPTS1, UCHAR ucPTS2, UCHAR ucPTS3)
Set the protocol type selection (PTS).
#define IFD_NOT_SUPPORTED
request is not supported
#define SCARD_E_READER_UNAVAILABLE
The specified reader is not currently available for use.
FCT_MAP_V2 psFunctions_v2
API V2.0.
LONG IFDGetCapabilities(READER_CONTEXT *rContext, DWORD dwTag, PDWORD pdwLength, PUCHAR pucValue)
Get's capabilities in the reader.
#define SCARD_UNKNOWN
Unknown state.
RESPONSECODE IFDHCloseChannel(DWORD Lun)
This function should close the reader communication channel for the particular reader.
#define SCARD_E_NOT_TRANSACTED
An attempt was made to end a non-existent transaction.
RESPONSECODE IFDHCreateChannel(DWORD Lun, DWORD Channel)
This function is required to open a communications channel to the port listed by Channel.
This handles abstract system level calls.
int slot
Current Reader Slot.
union ReaderContext::@3 psFunctions
driver functions
This wraps the dynamic ifdhandler functions.
RESPONSECODE IFDHSetProtocolParameters(DWORD Lun, DWORD Protocol, UCHAR Flags, UCHAR PTS1, UCHAR PTS2, UCHAR PTS3)
This function should set the Protocol Type Selection (PTS) of a particular card/slot using the three ...
RESPONSECODE IFDHPowerICC(DWORD Lun, DWORD Action, PUCHAR Atr, PDWORD AtrLength)
This function controls the power and reset signals of the smart card reader at the particular reader/...
struct _SCARD_IO_HEADER SCARD_IO_HEADER
Use by SCardTransmit()
RESPONSECODE IFDHGetCapabilities(DWORD Lun, DWORD Tag, PDWORD Length, PUCHAR Value)
This function should get the slot/card capabilities for a particular slot/card specified by Lun...
#define SCARD_PRESENT
Card is present.
int SYS_USleep(int)
Makes the current process sleep for some microseconds.
RESPONSECODE IFDHCreateChannelByName(DWORD Lun, LPSTR DeviceName)
This function is required to open a communications channel to the port listed by DeviceName.
#define IFD_ICC_PRESENT
card is present
This keeps track of smart card protocols, timing issues and Answer to Reset ATR handling.
FCT_MAP_V3 psFunctions_v3
API V3.0.
RESPONSECODE IFDHControl(DWORD Lun, DWORD dwControlCode, PUCHAR TxBuffer, DWORD TxLength, PUCHAR RxBuffer, DWORD RxLength, LPDWORD pdwBytesReturned)
This function performs a data exchange with the reader (not the card) specified by Lun...
LONG IFDTransmit(READER_CONTEXT *rContext, SCARD_IO_HEADER pioTxPci, PUCHAR pucTxBuffer, DWORD dwTxLength, PUCHAR pucRxBuffer, PDWORD pdwRxLength, PSCARD_IO_HEADER pioRxPci)
Transmit an APDU to the ICC.
int version
IFD Handler version number.
pthread_mutex_t * mMutex
Mutex for this connection.
LONG IFDSetCapabilities(READER_CONTEXT *rContext, DWORD dwTag, DWORD dwLength, PUCHAR pucValue)
Set capabilities in the reader.
LONG IFDCloseIFD(READER_CONTEXT *rContext)
Close a communication channel to the IFD.
#define SCARD_W_REMOVED_CARD
The smart card has been removed, so further communication is not possible.
#define SCARD_E_UNSUPPORTED_FEATURE
This smart card does not support the requested feature.
LONG IFDPowerICC(READER_CONTEXT *rContext, DWORD dwAction, PUCHAR pucAtr, PDWORD pdwAtrLen)
Power up/down or reset's an ICC located in the IFD.
LONG IFDOpenIFD(READER_CONTEXT *rContext)
Open a communication channel to the IFD.
This keeps a list of defines for pcsc-lite.
#define SCARD_ABSENT
Card is absent.
char * device
Device Name.
RESPONSECODE IFDHICCPresence(DWORD Lun)
This function returns the status of the card inserted in the reader/slot specified by Lun...
This keeps track of a list of currently available reader structures.
#define MAX_ATR_SIZE
Maximum ATR size.
#define IFD_ERROR_INSUFFICIENT_BUFFER
buffer is too small
#define SCARD_E_INSUFFICIENT_BUFFER
The data buffer to receive returned data is too small for the returned data.
#define IFD_ICC_NOT_PRESENT
card is absent
RESPONSECODE IFDHSetCapabilities(DWORD Lun, DWORD Tag, DWORD Length, PUCHAR Value)
This function should set the slot/card capabilities for a particular slot/card specified by Lun...
#define SCARD_S_SUCCESS
error codes from http://msdn.microsoft.com/en-us/library/aa924526.aspx
#define IFD_SUCCESS
no error
LONG IFDControl(READER_CONTEXT *rContext, DWORD ControlCode, LPCVOID TxBuffer, DWORD TxLength, LPVOID RxBuffer, DWORD RxLength, LPDWORD BytesReturned)
Provide a means for toggling a specific action on the reader such as swallow, eject, biometric.