0N/A/*
0N/A * This keeps a list of defines for pcsc-lite.
0N/A *
0N/A * MUSCLE SmartCard Development ( http://www.linuxnet.com )
0N/A *
0N/A * Copyright (C) 1999-2004
0N/A * David Corcoran <corcoran@linuxnet.com>
0N/A * Ludovic Rousseau <ludovic.rousseau@free.fr>
0N/A *
0N/A * $Id: pcsclite.h.in,v 1.47 2004/08/24 21:46:57 rousseau Exp $
0N/A */
0N/A
0N/A#ifndef __pcsclite_h__
0N/A#define __pcsclite_h__
0N/A
0N/A#ifndef __sun_jdk
0N/A#include <wintypes.h>
0N/A#else
0N/A#include <sys/types.h>
0N/A#include <inttypes.h>
0N/A#ifdef BYTE
0N/A#error BYTE is already defined
0N/A#else
0N/A typedef unsigned char BYTE;
0N/A#endif /* End BYTE */
0N/A
0N/A typedef unsigned char UCHAR;
0N/A typedef unsigned char *PUCHAR;
0N/A typedef unsigned short USHORT;
0N/A typedef unsigned long ULONG;
0N/A typedef void *LPVOID;
0N/A typedef short BOOL;
0N/A typedef unsigned long *PULONG;
0N/A typedef const void *LPCVOID;
0N/A typedef unsigned long DWORD;
0N/A typedef unsigned long *PDWORD;
0N/A typedef unsigned short WORD;
0N/A typedef long LONG;
0N/A typedef long RESPONSECODE;
0N/A typedef const char *LPCTSTR;
0N/A typedef const BYTE *LPCBYTE;
0N/A typedef BYTE *LPBYTE;
0N/A typedef DWORD *LPDWORD;
0N/A typedef char *LPTSTR;
0N/A
0N/A#endif
0N/A
0N/A#ifdef __cplusplus
0N/Aextern "C"
0N/A{
0N/A#endif
0N/A
0N/A#ifdef WIN32
0N/A#include <winscard.h>
0N/A#else
0N/Atypedef long SCARDCONTEXT;
0N/Atypedef SCARDCONTEXT *PSCARDCONTEXT;
0N/Atypedef SCARDCONTEXT *LPSCARDCONTEXT;
0N/Atypedef long SCARDHANDLE;
0N/Atypedef SCARDHANDLE *PSCARDHANDLE;
0N/Atypedef SCARDHANDLE *LPSCARDHANDLE;
0N/A
0N/A#define MAX_ATR_SIZE 33 /* Maximum ATR size */
0N/A
0N/Atypedef struct
0N/A{
0N/A const char *szReader;
0N/A void *pvUserData;
0N/A unsigned long dwCurrentState;
0N/A unsigned long dwEventState;
0N/A unsigned long cbAtr;
0N/A unsigned char rgbAtr[MAX_ATR_SIZE];
0N/A}
0N/ASCARD_READERSTATE_A;
0N/A
0N/Atypedef SCARD_READERSTATE_A SCARD_READERSTATE, *PSCARD_READERSTATE_A,
0N/A *LPSCARD_READERSTATE_A;
0N/A
0N/Atypedef struct _SCARD_IO_REQUEST
0N/A{
0N/A unsigned long dwProtocol; /* Protocol identifier */
0N/A unsigned long cbPciLength; /* Protocol Control Inf Length */
0N/A}
0N/ASCARD_IO_REQUEST, *PSCARD_IO_REQUEST, *LPSCARD_IO_REQUEST;
0N/A
0N/Atypedef const SCARD_IO_REQUEST *LPCSCARD_IO_REQUEST;
0N/A
0N/Aextern SCARD_IO_REQUEST g_rgSCardT0Pci, g_rgSCardT1Pci,
0N/A g_rgSCardRawPci;
0N/A
0N/A#define SCARD_PCI_T0 (&g_rgSCardT0Pci)
0N/A#define SCARD_PCI_T1 (&g_rgSCardT1Pci)
0N/A#define SCARD_PCI_RAW (&g_rgSCardRawPci)
0N/A
0N/A#define SCARD_S_SUCCESS 0x00000000
0N/A#define SCARD_E_CANCELLED 0x80100002
0N/A#define SCARD_E_CANT_DISPOSE 0x8010000E
0N/A#define SCARD_E_INSUFFICIENT_BUFFER 0x80100008
0N/A#define SCARD_E_INVALID_ATR 0x80100015
0N/A#define SCARD_E_INVALID_HANDLE 0x80100003
0N/A#define SCARD_E_INVALID_PARAMETER 0x80100004
0N/A#define SCARD_E_INVALID_TARGET 0x80100005
0N/A#define SCARD_E_INVALID_VALUE 0x80100011
0N/A#define SCARD_E_NO_MEMORY 0x80100006
0N/A#define SCARD_F_COMM_ERROR 0x80100013
0N/A#define SCARD_F_INTERNAL_ERROR 0x80100001
0N/A#define SCARD_F_UNKNOWN_ERROR 0x80100014
0N/A#define SCARD_F_WAITED_TOO_LONG 0x80100007
0N/A#define SCARD_E_UNKNOWN_READER 0x80100009
0N/A#define SCARD_E_TIMEOUT 0x8010000A
0N/A#define SCARD_E_SHARING_VIOLATION 0x8010000B
0N/A#define SCARD_E_NO_SMARTCARD 0x8010000C
0N/A#define SCARD_E_UNKNOWN_CARD 0x8010000D
0N/A#define SCARD_E_PROTO_MISMATCH 0x8010000F
0N/A#define SCARD_E_NOT_READY 0x80100010
0N/A#define SCARD_E_SYSTEM_CANCELLED 0x80100012
0N/A#define SCARD_E_NOT_TRANSACTED 0x80100016
0N/A#define SCARD_E_READER_UNAVAILABLE 0x80100017
0N/A
0N/A#define SCARD_W_UNSUPPORTED_CARD 0x80100065
0N/A#define SCARD_W_UNRESPONSIVE_CARD 0x80100066
0N/A#define SCARD_W_UNPOWERED_CARD 0x80100067
0N/A#define SCARD_W_RESET_CARD 0x80100068
0N/A#define SCARD_W_REMOVED_CARD 0x80100069
0N/A
0N/A#define SCARD_E_PCI_TOO_SMALL 0x80100019
0N/A#define SCARD_E_READER_UNSUPPORTED 0x8010001A
0N/A#define SCARD_E_DUPLICATE_READER 0x8010001B
0N/A#define SCARD_E_CARD_UNSUPPORTED 0x8010001C
0N/A#define SCARD_E_NO_SERVICE 0x8010001D
0N/A#define SCARD_E_SERVICE_STOPPED 0x8010001E
0N/A
0N/A#define SCARD_SCOPE_USER 0x0000 /* Scope in user space */
0N/A#define SCARD_SCOPE_TERMINAL 0x0001 /* Scope in terminal */
0N/A#define SCARD_SCOPE_SYSTEM 0x0002 /* Scope in system */
0N/A
0N/A#define SCARD_PROTOCOL_UNSET 0x0000 /* protocol not set */
0N/A#define SCARD_PROTOCOL_T0 0x0001 /* T=0 active protocol. */
0N/A#define SCARD_PROTOCOL_T1 0x0002 /* T=1 active protocol. */
0N/A#define SCARD_PROTOCOL_RAW 0x0004 /* Raw active protocol. */
0N/A#define SCARD_PROTOCOL_T15 0x0008 /* T=15 protocol. */
0N/A
0N/A#define SCARD_PROTOCOL_ANY (SCARD_PROTOCOL_T0|SCARD_PROTOCOL_T1) /* IFD determines prot. */
0N/A
0N/A#define SCARD_SHARE_EXCLUSIVE 0x0001 /* Exclusive mode only */
0N/A#define SCARD_SHARE_SHARED 0x0002 /* Shared mode only */
0N/A#define SCARD_SHARE_DIRECT 0x0003 /* Raw mode only */
0N/A
0N/A#define SCARD_LEAVE_CARD 0x0000 /* Do nothing on close */
0N/A#define SCARD_RESET_CARD 0x0001 /* Reset on close */
0N/A#define SCARD_UNPOWER_CARD 0x0002 /* Power down on close */
0N/A#define SCARD_EJECT_CARD 0x0003 /* Eject on close */
0N/A
0N/A#define SCARD_UNKNOWN 0x0001 /* Unknown state */
0N/A#define SCARD_ABSENT 0x0002 /* Card is absent */
0N/A#define SCARD_PRESENT 0x0004 /* Card is present */
0N/A#define SCARD_SWALLOWED 0x0008 /* Card not powered */
0N/A#define SCARD_POWERED 0x0010 /* Card is powered */
0N/A#define SCARD_NEGOTIABLE 0x0020 /* Ready for PTS */
0N/A#define SCARD_SPECIFIC 0x0040 /* PTS has been set */
0N/A
0N/A#define SCARD_STATE_UNAWARE 0x0000 /* App wants status */
0N/A#define SCARD_STATE_IGNORE 0x0001 /* Ignore this reader */
0N/A#define SCARD_STATE_CHANGED 0x0002 /* State has changed */
0N/A#define SCARD_STATE_UNKNOWN 0x0004 /* Reader unknown */
0N/A#define SCARD_STATE_UNAVAILABLE 0x0008 /* Status unavailable */
0N/A#define SCARD_STATE_EMPTY 0x0010 /* Card removed */
0N/A#define SCARD_STATE_PRESENT 0x0020 /* Card inserted */
0N/A#define SCARD_STATE_ATRMATCH 0x0040 /* ATR matches card */
0N/A#define SCARD_STATE_EXCLUSIVE 0x0080 /* Exclusive Mode */
0N/A#define SCARD_STATE_INUSE 0x0100 /* Shared Mode */
0N/A#define SCARD_STATE_MUTE 0x0200 /* Unresponsive card */
0N/A#define SCARD_STATE_UNPOWERED 0x0400 /* Unpowered card */
0N/A
0N/A/*
0N/A * Tags for requesting card and reader attributes
0N/A */
0N/A
0N/A#define SCARD_ATTR_VALUE(Class, Tag) ((((ULONG)(Class)) << 16) | ((ULONG)(Tag)))
0N/A
0N/A#define SCARD_CLASS_VENDOR_INFO 1 /* Vendor information definitions */
0N/A#define SCARD_CLASS_COMMUNICATIONS 2 /* Communication definitions */
0N/A#define SCARD_CLASS_PROTOCOL 3 /* Protocol definitions */
0N/A#define SCARD_CLASS_POWER_MGMT 4 /* Power Management definitions */
0N/A#define SCARD_CLASS_SECURITY 5 /* Security Assurance definitions */
0N/A#define SCARD_CLASS_MECHANICAL 6 /* Mechanical characteristic definitions */
0N/A#define SCARD_CLASS_VENDOR_DEFINED 7 /* Vendor specific definitions */
0N/A#define SCARD_CLASS_IFD_PROTOCOL 8 /* Interface Device Protocol options */
0N/A#define SCARD_CLASS_ICC_STATE 9 /* ICC State specific definitions */
0N/A#define SCARD_CLASS_SYSTEM 0x7fff /* System-specific definitions */
0N/A
0N/A#define SCARD_ATTR_VENDOR_NAME SCARD_ATTR_VALUE(SCARD_CLASS_VENDOR_INFO, 0x0100)
0N/A#define SCARD_ATTR_VENDOR_IFD_TYPE SCARD_ATTR_VALUE(SCARD_CLASS_VENDOR_INFO, 0x0101)
0N/A#define SCARD_ATTR_VENDOR_IFD_VERSION SCARD_ATTR_VALUE(SCARD_CLASS_VENDOR_INFO, 0x0102)
0N/A#define SCARD_ATTR_VENDOR_IFD_SERIAL_NO SCARD_ATTR_VALUE(SCARD_CLASS_VENDOR_INFO, 0x0103)
0N/A#define SCARD_ATTR_CHANNEL_ID SCARD_ATTR_VALUE(SCARD_CLASS_COMMUNICATIONS, 0x0110)
0N/A#define SCARD_ATTR_ASYNC_PROTOCOL_TYPES SCARD_ATTR_VALUE(SCARD_CLASS_PROTOCOL, 0x0120)
0N/A#define SCARD_ATTR_DEFAULT_CLK SCARD_ATTR_VALUE(SCARD_CLASS_PROTOCOL, 0x0121)
0N/A#define SCARD_ATTR_MAX_CLK SCARD_ATTR_VALUE(SCARD_CLASS_PROTOCOL, 0x0122)
0N/A#define SCARD_ATTR_DEFAULT_DATA_RATE SCARD_ATTR_VALUE(SCARD_CLASS_PROTOCOL, 0x0123)
0N/A#define SCARD_ATTR_MAX_DATA_RATE SCARD_ATTR_VALUE(SCARD_CLASS_PROTOCOL, 0x0124)
0N/A#define SCARD_ATTR_MAX_IFSD SCARD_ATTR_VALUE(SCARD_CLASS_PROTOCOL, 0x0125)
0N/A#define SCARD_ATTR_SYNC_PROTOCOL_TYPES SCARD_ATTR_VALUE(SCARD_CLASS_PROTOCOL, 0x0126)
0N/A#define SCARD_ATTR_POWER_MGMT_SUPPORT SCARD_ATTR_VALUE(SCARD_CLASS_POWER_MGMT, 0x0131)
0N/A#define SCARD_ATTR_USER_TO_CARD_AUTH_DEVICE SCARD_ATTR_VALUE(SCARD_CLASS_SECURITY, 0x0140)
0N/A#define SCARD_ATTR_USER_AUTH_INPUT_DEVICE SCARD_ATTR_VALUE(SCARD_CLASS_SECURITY, 0x0142)
0N/A#define SCARD_ATTR_CHARACTERISTICS SCARD_ATTR_VALUE(SCARD_CLASS_MECHANICAL, 0x0150)
0N/A
0N/A#define SCARD_ATTR_CURRENT_PROTOCOL_TYPE SCARD_ATTR_VALUE(SCARD_CLASS_IFD_PROTOCOL, 0x0201)
0N/A#define SCARD_ATTR_CURRENT_CLK SCARD_ATTR_VALUE(SCARD_CLASS_IFD_PROTOCOL, 0x0202)
0N/A#define SCARD_ATTR_CURRENT_F SCARD_ATTR_VALUE(SCARD_CLASS_IFD_PROTOCOL, 0x0203)
0N/A#define SCARD_ATTR_CURRENT_D SCARD_ATTR_VALUE(SCARD_CLASS_IFD_PROTOCOL, 0x0204)
0N/A#define SCARD_ATTR_CURRENT_N SCARD_ATTR_VALUE(SCARD_CLASS_IFD_PROTOCOL, 0x0205)
0N/A#define SCARD_ATTR_CURRENT_W SCARD_ATTR_VALUE(SCARD_CLASS_IFD_PROTOCOL, 0x0206)
0N/A#define SCARD_ATTR_CURRENT_IFSC SCARD_ATTR_VALUE(SCARD_CLASS_IFD_PROTOCOL, 0x0207)
0N/A#define SCARD_ATTR_CURRENT_IFSD SCARD_ATTR_VALUE(SCARD_CLASS_IFD_PROTOCOL, 0x0208)
0N/A#define SCARD_ATTR_CURRENT_BWT SCARD_ATTR_VALUE(SCARD_CLASS_IFD_PROTOCOL, 0x0209)
0N/A#define SCARD_ATTR_CURRENT_CWT SCARD_ATTR_VALUE(SCARD_CLASS_IFD_PROTOCOL, 0x020a)
0N/A#define SCARD_ATTR_CURRENT_EBC_ENCODING SCARD_ATTR_VALUE(SCARD_CLASS_IFD_PROTOCOL, 0x020b)
0N/A#define SCARD_ATTR_EXTENDED_BWT SCARD_ATTR_VALUE(SCARD_CLASS_IFD_PROTOCOL, 0x020c)
0N/A
0N/A#define SCARD_ATTR_ICC_PRESENCE SCARD_ATTR_VALUE(SCARD_CLASS_ICC_STATE, 0x0300)
0N/A#define SCARD_ATTR_ICC_INTERFACE_STATUS SCARD_ATTR_VALUE(SCARD_CLASS_ICC_STATE, 0x0301)
0N/A#define SCARD_ATTR_CURRENT_IO_STATE SCARD_ATTR_VALUE(SCARD_CLASS_ICC_STATE, 0x0302)
0N/A#define SCARD_ATTR_ATR_STRING SCARD_ATTR_VALUE(SCARD_CLASS_ICC_STATE, 0x0303)
0N/A#define SCARD_ATTR_ICC_TYPE_PER_ATR SCARD_ATTR_VALUE(SCARD_CLASS_ICC_STATE, 0x0304)
0N/A
0N/A#define SCARD_ATTR_ESC_RESET SCARD_ATTR_VALUE(SCARD_CLASS_VENDOR_DEFINED, 0xA000)
0N/A#define SCARD_ATTR_ESC_CANCEL SCARD_ATTR_VALUE(SCARD_CLASS_VENDOR_DEFINED, 0xA003)
0N/A#define SCARD_ATTR_ESC_AUTHREQUEST SCARD_ATTR_VALUE(SCARD_CLASS_VENDOR_DEFINED, 0xA005)
0N/A#define SCARD_ATTR_MAXINPUT SCARD_ATTR_VALUE(SCARD_CLASS_VENDOR_DEFINED, 0xA007)
0N/A
0N/A#define SCARD_ATTR_DEVICE_UNIT SCARD_ATTR_VALUE(SCARD_CLASS_SYSTEM, 0x0001)
0N/A#define SCARD_ATTR_DEVICE_IN_USE SCARD_ATTR_VALUE(SCARD_CLASS_SYSTEM, 0x0002)
0N/A#define SCARD_ATTR_DEVICE_FRIENDLY_NAME_A SCARD_ATTR_VALUE(SCARD_CLASS_SYSTEM, 0x0003)
0N/A#define SCARD_ATTR_DEVICE_SYSTEM_NAME_A SCARD_ATTR_VALUE(SCARD_CLASS_SYSTEM, 0x0004)
0N/A#define SCARD_ATTR_DEVICE_FRIENDLY_NAME_W SCARD_ATTR_VALUE(SCARD_CLASS_SYSTEM, 0x0005)
0N/A#define SCARD_ATTR_DEVICE_SYSTEM_NAME_W SCARD_ATTR_VALUE(SCARD_CLASS_SYSTEM, 0x0006)
0N/A#define SCARD_ATTR_SUPRESS_T1_IFS_REQUEST SCARD_ATTR_VALUE(SCARD_CLASS_SYSTEM, 0x0007)
0N/A
0N/A#ifdef UNICODE
0N/A#define SCARD_ATTR_DEVICE_FRIENDLY_NAME SCARD_ATTR_DEVICE_FRIENDLY_NAME_W
0N/A#define SCARD_ATTR_DEVICE_SYSTEM_NAME SCARD_ATTR_DEVICE_SYSTEM_NAME_W
0N/A#else
0N/A#define SCARD_ATTR_DEVICE_FRIENDLY_NAME SCARD_ATTR_DEVICE_FRIENDLY_NAME_A
0N/A#define SCARD_ATTR_DEVICE_SYSTEM_NAME SCARD_ATTR_DEVICE_SYSTEM_NAME_A
0N/A#endif
0N/A
0N/A#endif
0N/A
0N/A/* PC/SC Lite specific extensions */
0N/A#define SCARD_W_INSERTED_CARD 0x8010006A
0N/A#define SCARD_E_UNSUPPORTED_FEATURE 0x8010001F
0N/A
0N/A#define SCARD_SCOPE_GLOBAL 0x0003 /* Scope is global */
0N/A
0N/A#define SCARD_RESET 0x0001 /* Card was reset */
0N/A#define SCARD_INSERTED 0x0002 /* Card was inserted */
0N/A#define SCARD_REMOVED 0x0004 /* Card was removed */
0N/A
0N/A#define BLOCK_STATUS_RESUME 0x00FF /* Normal resume */
0N/A#define BLOCK_STATUS_BLOCKING 0x00FA /* Function is blocking */
0N/A
0N/A#define PCSCLITE_CONFIG_DIR "/etc"
0N/A
0N/A#ifndef USE_IPCDIR
0N/A#define PCSCLITE_IPC_DIR "/var/run"
0N/A#else
0N/A#define PCSCLITE_IPC_DIR USE_IPCDIR
0N/A#endif
0N/A
0N/A#define PCSCLITE_READER_CONFIG PCSCLITE_CONFIG_DIR "/reader.conf"
0N/A#define PCSCLITE_PUBSHM_FILE PCSCLITE_IPC_DIR "/pcscd.pub"
0N/A#define PCSCLITE_CSOCK_NAME PCSCLITE_IPC_DIR "/pcscd.comm"
0N/A
0N/A#define PCSCLITE_SVC_IDENTITY 0x01030000 /* Service ID */
0N/A
0N/A#ifndef INFINITE
0N/A#define INFINITE 0xFFFFFFFF /* Infinite timeout */
0N/A#endif
0N/A#define PCSCLITE_INFINITE_TIMEOUT 4320000 /* 50 day infinite t/o */
0N/A
0N/A#define PCSCLITE_VERSION_NUMBER "1.2.9-beta7" /* Current version */
0N/A#define PCSCLITE_CLIENT_ATTEMPTS 120 /* Attempts to reach sv */
0N/A#define PCSCLITE_MCLIENT_ATTEMPTS 20 /* Attempts to reach sv */
0N/A#define PCSCLITE_STATUS_POLL_RATE 400000 /* Status polling rate */
0N/A#define PCSCLITE_MSG_KEY_LEN 16 /* App ID key length */
0N/A#define PCSCLITE_RW_ATTEMPTS 100 /* Attempts to rd/wrt */
0N/A
0N/A/* Maximum applications */
0N/A#define PCSCLITE_MAX_APPLICATIONS 16
0N/A/* Maximum contexts by application */
0N/A#define PCSCLITE_MAX_APPLICATION_CONTEXTS 16
0N/A/* Maximum of applications contexts that pcscd can accept */
0N/A#define PCSCLITE_MAX_APPLICATIONS_CONTEXTS \
0N/A PCSCLITE_MAX_APPLICATIONS * PCSCLITE_MAX_APPLICATION_CONTEXTS
0N/A/* Maximum channels on a reader context */
0N/A#define PCSCLITE_MAX_READER_CONTEXT_CHANNELS 16
0N/A/* Maximum channels on an application context */
0N/A#define PCSCLITE_MAX_APPLICATION_CONTEXT_CHANNELS 16
0N/A/* Maximum readers context (a slot is count as a reader) */
0N/A#define PCSCLITE_MAX_READERS_CONTEXTS 16
0N/A
0N/A/* PCSCLITE_MAX_READERS is deprecated
0N/A * use PCSCLITE_MAX_READERS_CONTEXTS instead */
0N/A/* extern int PCSCLITE_MAX_READERS __attribute__ ((deprecated)); */
0N/A
0N/A#define PCSCLITE_MAX_THREADS 16 /* Stat change threads */
0N/A#define PCSCLITE_STATUS_WAIT 200000 /* Status Change Sleep */
0N/A#define PCSCLITE_TRANSACTION_TIMEOUT 40 /* Transaction timeout */
0N/A#define MAX_READERNAME 52
0N/A#define MAX_LIBNAME 100
0N/A#define MAX_DEVICENAME 255
0N/A
0N/A#ifndef SCARD_ATR_LENGTH
0N/A#define SCARD_ATR_LENGTH MAX_ATR_SIZE /* Maximum ATR size */
0N/A#endif
0N/A
0N/A/*
0N/A * Enhanced messaging has been added to accomodate newer devices which have
0N/A * more advanced capabilites, such as dedicated secure co-processors which
0N/A * can stream and encrypt data over USB. In order to used enhanced messaging
0N/A * you must define PCSCLITE_ENHANCED_MESSAGING in the framework(library),
0N/A * the daemon, and your application
0N/A */
0N/A#undef PCSCLITE_ENHANCED_MESSAGING
0N/A#ifndef PCSCLITE_ENHANCED_MESSAGING
0N/A#define PCSCLITE_MAX_MESSAGE_SIZE 2048 /* Transport msg len */
0N/A#define MAX_BUFFER_SIZE 264 /* Maximum Tx/Rx Buffer */
0N/A#define PCSCLITE_SERVER_ATTEMPTS 5 /* Attempts to reach cl */
0N/A#else
0N/A/*
0N/A * The message and buffer sizes must be multiples of 16.
0N/A * The max message size must be at least large enough
0N/A * to accomodate the transmit_struct
0N/A */
0N/A#define PCSCLITE_MAX_MESSAGE_SIZE (1<<17) /* enhanced (128K) msg len */
0N/A#define MAX_BUFFER_SIZE (1<<15) /* enhanced (32K) Tx/Rx Buffer */
0N/A#define PCSCLITE_SERVER_ATTEMPTS 200 /* To allow larger data reads/writes */
0N/A#endif
0N/A
0N/A/*
0N/A * Gets a stringified error response
0N/A */
0N/Achar *pcsc_stringify_error(long);
0N/A
0N/A#ifdef __cplusplus
0N/A}
0N/A#endif
0N/A
0N/A#endif