55 #define USE_AUTOALLOCATE
57 #define BLUE "\33[34m"
59 #define BRIGHT_RED "\33[01;31m"
60 #define GREEN "\33[32m"
61 #define NORMAL "\33[0m"
62 #define MAGENTA "\33[35m"
64 static void test_rv(LONG rv,
SCARDCONTEXT hContext,
int dont_panic)
81 int main(
int argc,
char **argv)
86 DWORD dwReaderLen, dwState, dwProt, dwAtrLen;
87 DWORD dwPref, dwReaders = 0;
88 char *pcReaders = NULL, *mszReaders;
89 #ifdef USE_AUTOALLOCATE
90 unsigned char *pbAtr = NULL;
95 unsigned char as_char[100];
100 unsigned char *pbAttr = NULL;
112 DWORD send_length, length;
117 printf(
"\nMUSCLE PC/SC Lite unitary test Program\n\n");
119 printf(MAGENTA
"THIS PROGRAM IS NOT DESIGNED AS A TESTING TOOL FOR END USERS!\n");
120 printf(
"Do NOT use it unless you really know what you do.\n\n" NORMAL);
122 printf(
"Testing SCardEstablishContext\t: ");
124 test_rv(rv, hContext, PANIC);
126 printf(
"Testing SCardIsValidContext\t: ");
128 test_rv(rv, hContext, PANIC);
130 printf(
"Testing SCardIsValidContext\t: ");
132 test_rv(rv, hContext, DONT_PANIC);
134 printf(
"Testing SCardListReaderGroups\t: ");
135 #ifdef USE_AUTOALLOCATE
140 test_rv(rv, hContext, PANIC);
142 printf(
"Testing SCardListReaderGroups\t: ");
143 mszGroups = calloc(dwGroups,
sizeof(
char));
146 test_rv(rv, hContext, PANIC);
152 for (i = 0; i+1 < dwGroups; i++)
155 printf(GREEN
"Group %02d: %s\n" NORMAL, p, &mszGroups[i]);
156 while (mszGroups[++i] != 0) ;
159 #ifdef USE_AUTOALLOCATE
160 printf(
"Testing SCardFreeMemory\t\t: ");
162 test_rv(rv, hContext, PANIC);
169 printf(
"Testing SCardListReaders\t: ");
171 test_rv(rv, hContext, DONT_PANIC);
174 printf(
"Testing SCardGetStatusChange \n");
175 printf(
"Please insert a working reader\t: ");
176 (void)fflush(stdout);
177 rgReaderStates[0].szReader =
"\\\\?PnP?\\Notification";
181 test_rv(rv, hContext, PANIC);
184 printf(
"Testing SCardListReaders\t: ");
185 #ifdef USE_AUTOALLOCATE
190 test_rv(rv, hContext, PANIC);
192 printf(
"Testing SCardListReaders\t: ");
193 mszReaders = calloc(dwReaders,
sizeof(
char));
196 test_rv(rv, hContext, DONT_PANIC);
202 for (i = 0; i+1 < dwReaders; i++)
205 printf(GREEN
"Reader %02d: %s\n" NORMAL, p, &mszReaders[i]);
207 while (mszReaders[++i] != 0) ;
216 printf(
"Enter the reader number\t\t: ");
217 r = fgets(input,
sizeof(input), stdin);
221 iReader = atoi(input);
223 if (iReader > p || iReader <= 0)
224 printf(
"Invalid Value - try again\n");
226 while (iReader > p || iReader <= 0);
230 rgReaderStates[0].szReader = &mszReaders[iList[iReader]];
233 printf(
"Waiting for card insertion\t: ");
234 (void)fflush(stdout);
236 test_rv(rv, hContext, PANIC);
239 printf(
"\nA reader has been connected/disconnected\n");
240 goto wait_for_card_again;
243 printf(
"Testing SCardConnect\t\t: ");
244 rv =
SCardConnect(hContext, &mszReaders[iList[iReader]],
247 test_rv(rv, hContext, PANIC);
261 printf(
"Unknown protocol\n");
266 printf(
"Select file:");
268 memcpy(bSendBuffer,
"\x00\xA4\x00\x00\x02\x3F\x00", send_length);
269 for (i=0; i<send_length; i++)
270 printf(
" %02X", bSendBuffer[i]);
272 length =
sizeof(bRecvBuffer);
274 printf(
"Testing SCardTransmit\t\t: ");
275 rv =
SCardTransmit(hCard, pioSendPci, bSendBuffer, send_length,
276 &ioRecvPci, bRecvBuffer, &length);
277 test_rv(rv, hContext, PANIC);
278 printf(
" card response:" GREEN);
279 for (i=0; i<length; i++)
280 printf(
" %02X", bRecvBuffer[i]);
283 printf(
"Testing SCardControl\t\t: ");
286 char buffer[1024] =
"Foobar";
287 DWORD cbRecvLength =
sizeof(buffer);
289 rv =
SCardControl(hCard, buffer, 7, buffer, &cbRecvLength);
293 char buffer[1024] = { 0x02 };
294 DWORD cbRecvLength =
sizeof(buffer);
297 sizeof(buffer), &cbRecvLength);
300 for (i=0; i<cbRecvLength; i++)
301 printf(
"%c", buffer[i]);
306 test_rv(rv, hContext, DONT_PANIC);
308 printf(
"Testing SCardGetAttrib\t\t: ");
309 #ifdef USE_AUTOALLOCATE
315 test_rv(rv, hContext, DONT_PANIC);
318 printf(
"SCARD_ATTR_DEVICE_FRIENDLY_NAME length: " GREEN
"%ld\n" NORMAL, pcbAttrLen);
319 pbAttr = malloc(pcbAttrLen);
322 printf(
"Testing SCardGetAttrib\t\t: ");
325 test_rv(rv, hContext, DONT_PANIC);
327 printf(
"SCARD_ATTR_DEVICE_FRIENDLY_NAME: " GREEN
"%s\n" NORMAL, pbAttr);
329 #ifdef USE_AUTOALLOCATE
330 printf(
"Testing SCardFreeMemory\t\t: ");
332 test_rv(rv, hContext, PANIC);
338 printf(
"Testing SCardGetAttrib\t\t: ");
339 #ifdef USE_AUTOALLOCATE
345 test_rv(rv, hContext, DONT_PANIC);
348 printf(
"SCARD_ATTR_ATR_STRING length: " GREEN
"%ld\n" NORMAL, pcbAttrLen);
349 pbAttr = malloc(pcbAttrLen);
352 printf(
"Testing SCardGetAttrib\t\t: ");
355 test_rv(rv, hContext, DONT_PANIC);
358 printf(
"SCARD_ATTR_ATR_STRING length: " GREEN
"%ld\n" NORMAL, pcbAttrLen);
359 printf(
"SCARD_ATTR_ATR_STRING: " GREEN);
360 for (i = 0; i < pcbAttrLen; i++)
361 printf(
"%02X ", pbAttr[i]);
365 #ifdef USE_AUTOALLOCATE
366 printf(
"Testing SCardFreeMemory\t\t: ");
368 test_rv(rv, hContext, PANIC);
374 printf(
"Testing SCardGetAttrib\t\t: ");
375 dwBufLen =
sizeof(buf);
377 test_rv(rv, hContext, DONT_PANIC);
379 printf(
"Vendor IFD version\t\t: " GREEN
"0x%08lX\n" NORMAL,
382 printf(
"Testing SCardGetAttrib\t\t: ");
383 dwBufLen =
sizeof(buf);
385 test_rv(rv, hContext, DONT_PANIC);
388 if (dwBufLen ==
sizeof(uint32_t))
389 printf(
"Max message length\t\t: " GREEN
"%d\n" NORMAL,
392 printf(RED
"Wrong size" NORMAL);
395 printf(
"Testing SCardGetAttrib\t\t: ");
396 dwBufLen =
sizeof(buf);
398 test_rv(rv, hContext, DONT_PANIC);
400 printf(
"Vendor name\t\t\t: " GREEN
"%s\n" NORMAL, buf.as_char);
402 printf(
"Testing SCardSetAttrib\t\t: ");
404 test_rv(rv, hContext, DONT_PANIC);
406 printf(
"Testing SCardStatus\t\t: ");
408 #ifdef USE_AUTOALLOCATE
411 rv =
SCardStatus(hCard, (LPSTR)&pcReaders, &dwReaderLen, &dwState, &dwProt,
412 (LPBYTE)&pbAtr, &dwAtrLen);
415 pcReaders = malloc(
sizeof(
char) * 100);
418 rv =
SCardStatus(hCard, pcReaders, &dwReaderLen, &dwState, &dwProt,
421 test_rv(rv, hContext, PANIC);
423 printf(
"Current Reader Name\t\t: " GREEN
"%s\n" NORMAL, pcReaders);
424 printf(
"Current Reader State\t\t: " GREEN
"0x%.4lx\n" NORMAL, dwState);
425 printf(
"Current Reader Protocol\t\t: T=" GREEN
"%ld\n" NORMAL, dwProt - 1);
426 printf(
"Current Reader ATR Size\t\t: " GREEN
"%ld" NORMAL
" bytes\n",
428 printf(
"Current Reader ATR Value\t: " GREEN);
430 for (i = 0; i < dwAtrLen; i++)
432 printf(
"%02X ", pbAtr[i]);
436 #ifdef USE_AUTOALLOCATE
437 printf(
"Testing SCardFreeMemory\t\t: ");
439 test_rv(rv, hContext, PANIC);
440 printf(
"Testing SCardFreeMemory\t\t: ");
442 test_rv(rv, hContext, PANIC);
454 printf(
"Press enter: ");
456 printf(
"Testing SCardReconnect\t\t: ");
459 test_rv(rv, hContext, PANIC);
461 printf(
"Testing SCardDisconnect\t\t: ");
463 test_rv(rv, hContext, PANIC);
465 #ifdef USE_AUTOALLOCATE
466 printf(
"Testing SCardFreeMemory\t\t: ");
468 test_rv(rv, hContext, PANIC);
473 printf(
"Testing SCardReleaseContext\t: ");
475 test_rv(rv, hContext, PANIC);
478 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.