29 #define USE_AUTOALLOCATE
31 #define BLUE "\33[34m"
33 #define BRIGHT_RED "\33[01;31m"
34 #define GREEN "\33[32m"
35 #define NORMAL "\33[0m"
36 #define MAGENTA "\33[35m"
38 static void test_rv(LONG rv,
SCARDCONTEXT hContext,
int dont_panic)
55 int main(
int argc,
char **argv)
60 DWORD dwReaderLen, dwState, dwProt, dwAtrLen;
61 DWORD dwPref, dwReaders = 0;
62 char *pcReaders = NULL, *mszReaders;
63 #ifdef USE_AUTOALLOCATE
64 unsigned char *pbAtr = NULL;
69 unsigned char as_char[100];
74 unsigned char *pbAttr = NULL;
86 DWORD send_length, length;
91 printf(
"\nMUSCLE PC/SC Lite unitary test Program\n\n");
93 printf(MAGENTA
"THIS PROGRAM IS NOT DESIGNED AS A TESTING TOOL FOR END USERS!\n");
94 printf(
"Do NOT use it unless you really know what you do.\n\n" NORMAL);
96 printf(
"Testing SCardEstablishContext\t: ");
98 test_rv(rv, hContext, PANIC);
100 printf(
"Testing SCardIsValidContext\t: ");
102 test_rv(rv, hContext, PANIC);
104 printf(
"Testing SCardIsValidContext\t: ");
106 test_rv(rv, hContext, DONT_PANIC);
108 printf(
"Testing SCardListReaderGroups\t: ");
109 #ifdef USE_AUTOALLOCATE
114 test_rv(rv, hContext, PANIC);
116 printf(
"Testing SCardListReaderGroups\t: ");
117 mszGroups = calloc(dwGroups,
sizeof(
char));
120 test_rv(rv, hContext, PANIC);
126 for (i = 0; i+1 < dwGroups; i++)
129 printf(GREEN
"Group %02d: %s\n" NORMAL, p, &mszGroups[i]);
130 while (mszGroups[++i] != 0) ;
133 #ifdef USE_AUTOALLOCATE
134 printf(
"Testing SCardFreeMemory\t\t: ");
136 test_rv(rv, hContext, PANIC);
143 printf(
"Testing SCardListReaders\t: ");
145 test_rv(rv, hContext, DONT_PANIC);
148 printf(
"Testing SCardGetStatusChange \n");
149 printf(
"Please insert a working reader\t: ");
150 (void)fflush(stdout);
151 rgReaderStates[0].szReader =
"\\\\?PnP?\\Notification";
155 test_rv(rv, hContext, PANIC);
158 printf(
"Testing SCardListReaders\t: ");
159 #ifdef USE_AUTOALLOCATE
164 test_rv(rv, hContext, PANIC);
166 printf(
"Testing SCardListReaders\t: ");
167 mszReaders = calloc(dwReaders,
sizeof(
char));
170 test_rv(rv, hContext, DONT_PANIC);
176 for (i = 0; i+1 < dwReaders; i++)
179 printf(GREEN
"Reader %02d: %s\n" NORMAL, p, &mszReaders[i]);
181 while (mszReaders[++i] != 0) ;
190 printf(
"Enter the reader number\t\t: ");
191 r = fgets(input,
sizeof(input), stdin);
195 iReader = atoi(input);
197 if (iReader > p || iReader <= 0)
198 printf(
"Invalid Value - try again\n");
200 while (iReader > p || iReader <= 0);
204 rgReaderStates[0].szReader = &mszReaders[iList[iReader]];
207 printf(
"Waiting for card insertion\t: ");
208 (void)fflush(stdout);
210 test_rv(rv, hContext, PANIC);
213 printf(
"\nA reader has been connected/disconnected\n");
214 goto wait_for_card_again;
217 printf(
"Testing SCardConnect\t\t: ");
218 rv =
SCardConnect(hContext, &mszReaders[iList[iReader]],
221 test_rv(rv, hContext, PANIC);
235 printf(
"Unknown protocol\n");
240 printf(
"Select file:");
242 memcpy(bSendBuffer,
"\x00\xA4\x00\x00\x02\x3F\x00", send_length);
243 for (i=0; i<send_length; i++)
244 printf(
" %02X", bSendBuffer[i]);
246 length =
sizeof(bRecvBuffer);
248 printf(
"Testing SCardTransmit\t\t: ");
249 rv =
SCardTransmit(hCard, pioSendPci, bSendBuffer, send_length,
250 &ioRecvPci, bRecvBuffer, &length);
251 test_rv(rv, hContext, PANIC);
252 printf(
" card response:" GREEN);
253 for (i=0; i<length; i++)
254 printf(
" %02X", bRecvBuffer[i]);
257 printf(
"Testing SCardControl\t\t: ");
260 char buffer[1024] =
"Foobar";
261 DWORD cbRecvLength =
sizeof(buffer);
263 rv =
SCardControl(hCard, buffer, 7, buffer, &cbRecvLength);
267 char buffer[1024] = { 0x02 };
268 DWORD cbRecvLength =
sizeof(buffer);
271 sizeof(buffer), &cbRecvLength);
274 for (i=0; i<cbRecvLength; i++)
275 printf(
"%c", buffer[i]);
280 test_rv(rv, hContext, DONT_PANIC);
282 printf(
"Testing SCardGetAttrib\t\t: ");
283 #ifdef USE_AUTOALLOCATE
289 test_rv(rv, hContext, DONT_PANIC);
292 printf(
"SCARD_ATTR_DEVICE_FRIENDLY_NAME length: " GREEN
"%ld\n" NORMAL, pcbAttrLen);
293 pbAttr = malloc(pcbAttrLen);
296 printf(
"Testing SCardGetAttrib\t\t: ");
299 test_rv(rv, hContext, DONT_PANIC);
301 printf(
"SCARD_ATTR_DEVICE_FRIENDLY_NAME: " GREEN
"%s\n" NORMAL, pbAttr);
303 #ifdef USE_AUTOALLOCATE
304 printf(
"Testing SCardFreeMemory\t\t: ");
306 test_rv(rv, hContext, PANIC);
312 printf(
"Testing SCardGetAttrib\t\t: ");
313 #ifdef USE_AUTOALLOCATE
319 test_rv(rv, hContext, DONT_PANIC);
322 printf(
"SCARD_ATTR_ATR_STRING length: " GREEN
"%ld\n" NORMAL, pcbAttrLen);
323 pbAttr = malloc(pcbAttrLen);
326 printf(
"Testing SCardGetAttrib\t\t: ");
329 test_rv(rv, hContext, DONT_PANIC);
332 printf(
"SCARD_ATTR_ATR_STRING length: " GREEN
"%ld\n" NORMAL, pcbAttrLen);
333 printf(
"SCARD_ATTR_ATR_STRING: " GREEN);
334 for (i = 0; i < pcbAttrLen; i++)
335 printf(
"%02X ", pbAttr[i]);
339 #ifdef USE_AUTOALLOCATE
340 printf(
"Testing SCardFreeMemory\t\t: ");
342 test_rv(rv, hContext, PANIC);
348 printf(
"Testing SCardGetAttrib\t\t: ");
349 dwBufLen =
sizeof(buf);
351 test_rv(rv, hContext, DONT_PANIC);
353 printf(
"Vendor IFD version\t\t: " GREEN
"0x%08lX\n" NORMAL,
356 printf(
"Testing SCardGetAttrib\t\t: ");
357 dwBufLen =
sizeof(buf);
359 test_rv(rv, hContext, DONT_PANIC);
362 if (dwBufLen ==
sizeof(uint32_t))
363 printf(
"Max message length\t\t: " GREEN
"%d\n" NORMAL,
366 printf(RED
"Wrong size" NORMAL);
369 printf(
"Testing SCardGetAttrib\t\t: ");
370 dwBufLen =
sizeof(buf);
372 test_rv(rv, hContext, DONT_PANIC);
374 printf(
"Vendor name\t\t\t: " GREEN
"%s\n" NORMAL, buf.as_char);
376 printf(
"Testing SCardSetAttrib\t\t: ");
378 test_rv(rv, hContext, DONT_PANIC);
380 printf(
"Testing SCardStatus\t\t: ");
382 #ifdef USE_AUTOALLOCATE
385 rv =
SCardStatus(hCard, (LPSTR)&pcReaders, &dwReaderLen, &dwState, &dwProt,
386 (LPBYTE)&pbAtr, &dwAtrLen);
389 pcReaders = malloc(
sizeof(
char) * 100);
392 rv =
SCardStatus(hCard, pcReaders, &dwReaderLen, &dwState, &dwProt,
395 test_rv(rv, hContext, PANIC);
397 printf(
"Current Reader Name\t\t: " GREEN
"%s\n" NORMAL, pcReaders);
398 printf(
"Current Reader State\t\t: " GREEN
"0x%.4lx\n" NORMAL, dwState);
399 printf(
"Current Reader Protocol\t\t: T=" GREEN
"%ld\n" NORMAL, dwProt - 1);
400 printf(
"Current Reader ATR Size\t\t: " GREEN
"%ld" NORMAL
" bytes\n",
402 printf(
"Current Reader ATR Value\t: " GREEN);
404 for (i = 0; i < dwAtrLen; i++)
406 printf(
"%02X ", pbAtr[i]);
410 #ifdef USE_AUTOALLOCATE
411 printf(
"Testing SCardFreeMemory\t\t: ");
413 test_rv(rv, hContext, PANIC);
414 printf(
"Testing SCardFreeMemory\t\t: ");
416 test_rv(rv, hContext, PANIC);
428 printf(
"Press enter: ");
430 printf(
"Testing SCardReconnect\t\t: ");
433 test_rv(rv, hContext, PANIC);
435 printf(
"Testing SCardDisconnect\t\t: ");
437 test_rv(rv, hContext, PANIC);
439 #ifdef USE_AUTOALLOCATE
440 printf(
"Testing SCardFreeMemory\t\t: ");
442 test_rv(rv, hContext, PANIC);
447 printf(
"Testing SCardReleaseContext\t: ");
449 test_rv(rv, hContext, PANIC);
452 printf(
"PC/SC Test Completed Successfully !\n");
#define SCARD_ATTR_ATR_STRING
Answer to reset (ATR) string.
#define SCARD_ATTR_DEVICE_FRIENDLY_NAME
Reader's display name.
#define SCARD_ATTR_VENDOR_IFD_VERSION
Vendor-supplied interface device version (DWORD in the form 0xMMmmbbbb where MM = major version...
PCSC_API LONG SCardListReaders(SCARDCONTEXT hContext, LPCSTR mszGroups, LPSTR mszReaders, LPDWORD pcchReaders)
Returns a list of currently available readers on the system.
#define MAX_BUFFER_SIZE
Maximum Tx/Rx Buffer for short APDU.
PCSC_API LONG SCardListReaderGroups(SCARDCONTEXT hContext, LPSTR mszGroups, LPDWORD pcchGroups)
Returns a list of currently available reader groups on the system.
#define SCARD_STATE_EMPTY
Card removed.
This keeps a list of defines shared between the driver and the application.
PCSC_API char * pcsc_stringify_error(const LONG pcscError)
Returns a human readable text for the given PC/SC error code.
PCSC_API LONG SCardEstablishContext(DWORD dwScope, LPCVOID pvReserved1, LPCVOID pvReserved2, LPSCARDCONTEXT phContext)
Creates an Application Context to the PC/SC Resource Manager.
#define SCARD_E_NO_READERS_AVAILABLE
Cannot find a smart card reader.
#define SCARD_PROTOCOL_T1
T=1 active protocol.
PCSC_API LONG SCardFreeMemory(SCARDCONTEXT hContext, LPCVOID pvMem)
Releases memory that has been returned from the resource manager using the SCARD_AUTOALLOCATE length ...
LONG SCardGetStatusChange(SCARDCONTEXT hContext, DWORD dwTimeout, SCARD_READERSTATE *rgReaderStates, DWORD cReaders)
Blocks execution until the current availability of the cards in a specific set of readers changes...
PCSC_API LONG SCardGetAttrib(SCARDHANDLE hCard, DWORD dwAttrId, LPBYTE pbAttr, LPDWORD pcbAttrLen)
Get an attribute from the IFD Handler (reader driver).
#define SCARD_PCI_T0
protocol control information (PCI) for T=0
PCSC_API LONG SCardDisconnect(SCARDHANDLE hCard, DWORD dwDisposition)
Terminates a connection made through SCardConnect().
#define SCARD_PCI_RAW
protocol control information (PCI) for RAW protocol
PCSC_API LONG SCardIsValidContext(SCARDCONTEXT hContext)
Check if a SCARDCONTEXT is valid.
#define INFINITE
Infinite timeout.
#define SCARD_STATE_UNKNOWN
Reader unknown.
#define SCARD_AUTOALLOCATE
see SCardFreeMemory()
LONG SCARDCONTEXT
hContext returned by SCardEstablishContext()
#define SCARD_SHARE_SHARED
Shared mode only.
#define SCARD_PROTOCOL_T0
T=0 active protocol.
#define SCARD_ATTR_MAXINPUT
FIXME.
PCSC_API LONG SCardReconnect(SCARDHANDLE hCard, DWORD dwShareMode, DWORD dwPreferredProtocols, DWORD dwInitialization, LPDWORD pdwActiveProtocol)
Reestablishes a connection to a reader that was previously connected to using SCardConnect().
#define SCARD_PCI_T1
protocol control information (PCI) for T=1
#define SCARD_UNPOWER_CARD
Power down on close.
This keeps a list of defines for pcsc-lite.
PCSC_API LONG SCardConnect(SCARDCONTEXT hContext, LPCSTR szReader, DWORD dwShareMode, DWORD dwPreferredProtocols, LPSCARDHANDLE phCard, LPDWORD pdwActiveProtocol)
Establishes a connection to the reader specified in * szReader.
PCSC_API LONG SCardStatus(SCARDHANDLE hCard, LPSTR mszReaderName, LPDWORD pcchReaderLen, LPDWORD pdwState, LPDWORD pdwProtocol, LPBYTE pbAtr, LPDWORD pcbAtrLen)
Returns the current status of the reader connected to by hCard.
PCSC_API LONG SCardSetAttrib(SCARDHANDLE hCard, DWORD dwAttrId, LPCBYTE pbAttr, DWORD cbAttrLen)
Set an attribute of the IFD Handler.
#define SCARD_RESET_CARD
Reset on close.
LONG SCARDHANDLE
hCard returned by SCardConnect()
#define SCARD_PROTOCOL_RAW
Raw active protocol.
#define SCARD_CTL_CODE(code)
Provide source compatibility on different platforms.
Protocol Control Information (PCI)
PCSC_API LONG SCardControl(SCARDHANDLE hCard, DWORD dwControlCode, LPCVOID pbSendBuffer, DWORD cbSendLength, LPVOID pbRecvBuffer, DWORD cbRecvLength, LPDWORD lpBytesReturned)
Sends a command directly to the IFD Handler (reader driver) to be processed by the reader...
#define SCARD_ATTR_VENDOR_NAME
Vendor name.
#define MAX_ATR_SIZE
Maximum ATR size.
PCSC_API LONG SCardTransmit(SCARDHANDLE hCard, const SCARD_IO_REQUEST *pioSendPci, LPCBYTE pbSendBuffer, DWORD cbSendLength, SCARD_IO_REQUEST *pioRecvPci, LPBYTE pbRecvBuffer, LPDWORD pcbRecvLength)
Sends an APDU to the smart card contained in the reader connected to by SCardConnect().
#define SCARD_S_SUCCESS
error codes from http://msdn.microsoft.com/en-us/library/aa924526.aspx
#define SCARD_SCOPE_SYSTEM
Scope in system.
This handles smart card reader communications.
PCSC_API LONG SCardReleaseContext(SCARDCONTEXT hContext)
Destroys a communication context to the PC/SC Resource Manager.