52 #define USE_AUTOALLOCATE
54 #define BLUE "\33[34m"
56 #define BRIGHT_RED "\33[01;31m"
57 #define GREEN "\33[32m"
58 #define NORMAL "\33[0m"
59 #define MAGENTA "\33[35m"
61 static void test_rv(LONG rv,
SCARDCONTEXT hContext,
int dont_panic)
78 int main(
int argc,
char **argv)
83 DWORD dwReaderLen, dwState, dwProt, dwAtrLen;
84 DWORD dwPref, dwReaders = 0;
85 char *pcReaders = NULL, *mszReaders;
86 #ifdef USE_AUTOALLOCATE
87 unsigned char *pbAtr = NULL;
92 unsigned char as_char[100];
97 unsigned char *pbAttr = NULL;
109 DWORD send_length, length;
114 printf(
"\nMUSCLE PC/SC Lite unitary test Program\n\n");
116 printf(MAGENTA
"THIS PROGRAM IS NOT DESIGNED AS A TESTING TOOL FOR END USERS!\n");
117 printf(
"Do NOT use it unless you really know what you do.\n\n" NORMAL);
119 printf(
"Testing SCardEstablishContext\t: ");
121 test_rv(rv, hContext, PANIC);
123 printf(
"Testing SCardIsValidContext\t: ");
125 test_rv(rv, hContext, PANIC);
127 printf(
"Testing SCardIsValidContext\t: ");
129 test_rv(rv, hContext, DONT_PANIC);
131 printf(
"Testing SCardListReaderGroups\t: ");
132 #ifdef USE_AUTOALLOCATE
137 test_rv(rv, hContext, PANIC);
139 printf(
"Testing SCardListReaderGroups\t: ");
140 mszGroups = calloc(dwGroups,
sizeof(
char));
143 test_rv(rv, hContext, PANIC);
149 for (i = 0; i+1 < dwGroups; i++)
152 printf(GREEN
"Group %02d: %s\n" NORMAL, p, &mszGroups[i]);
153 while (mszGroups[++i] != 0) ;
156 #ifdef USE_AUTOALLOCATE
157 printf(
"Testing SCardFreeMemory\t\t: ");
159 test_rv(rv, hContext, PANIC);
166 printf(
"Testing SCardListReaders\t: ");
168 test_rv(rv, hContext, DONT_PANIC);
171 printf(
"Testing SCardGetStatusChange \n");
172 printf(
"Please insert a working reader\t: ");
173 (void)fflush(stdout);
174 rgReaderStates[0].szReader =
"\\\\?PnP?\\Notification";
178 test_rv(rv, hContext, PANIC);
181 printf(
"Testing SCardListReaders\t: ");
182 #ifdef USE_AUTOALLOCATE
187 test_rv(rv, hContext, PANIC);
189 printf(
"Testing SCardListReaders\t: ");
190 mszReaders = calloc(dwReaders,
sizeof(
char));
193 test_rv(rv, hContext, DONT_PANIC);
199 for (i = 0; i+1 < dwReaders; i++)
202 printf(GREEN
"Reader %02d: %s\n" NORMAL, p, &mszReaders[i]);
204 while (mszReaders[++i] != 0) ;
213 printf(
"Enter the reader number\t\t: ");
214 r = fgets(input,
sizeof(input), stdin);
218 iReader = atoi(input);
220 if (iReader > p || iReader <= 0)
221 printf(
"Invalid Value - try again\n");
223 while (iReader > p || iReader <= 0);
227 rgReaderStates[0].szReader = &mszReaders[iList[iReader]];
230 printf(
"Waiting for card insertion\t: ");
231 (void)fflush(stdout);
233 test_rv(rv, hContext, PANIC);
236 printf(
"\nA reader has been connected/disconnected\n");
237 goto wait_for_card_again;
240 printf(
"Testing SCardConnect\t\t: ");
241 rv =
SCardConnect(hContext, &mszReaders[iList[iReader]],
244 test_rv(rv, hContext, PANIC);
258 printf(
"Unknown protocol\n");
263 printf(
"Select file:");
265 memcpy(bSendBuffer,
"\x00\xA4\x00\x00\x02\x3F\x00", send_length);
266 for (i=0; i<send_length; i++)
267 printf(
" %02X", bSendBuffer[i]);
269 length =
sizeof(bRecvBuffer);
271 printf(
"Testing SCardTransmit\t\t: ");
272 rv =
SCardTransmit(hCard, pioSendPci, bSendBuffer, send_length,
273 &ioRecvPci, bRecvBuffer, &length);
274 test_rv(rv, hContext, PANIC);
275 printf(
" card response:" GREEN);
276 for (i=0; i<length; i++)
277 printf(
" %02X", bRecvBuffer[i]);
280 printf(
"Testing SCardControl\t\t: ");
283 char buffer[1024] =
"Foobar";
284 DWORD cbRecvLength =
sizeof(buffer);
286 rv =
SCardControl(hCard, buffer, 7, buffer, &cbRecvLength);
290 char buffer[1024] = { 0x02 };
291 DWORD cbRecvLength =
sizeof(buffer);
294 sizeof(buffer), &cbRecvLength);
297 for (i=0; i<cbRecvLength; i++)
298 printf(
"%c", buffer[i]);
303 test_rv(rv, hContext, DONT_PANIC);
305 printf(
"Testing SCardGetAttrib\t\t: ");
306 #ifdef USE_AUTOALLOCATE
312 test_rv(rv, hContext, DONT_PANIC);
315 printf(
"SCARD_ATTR_DEVICE_FRIENDLY_NAME length: " GREEN
"%ld\n" NORMAL, pcbAttrLen);
316 pbAttr = malloc(pcbAttrLen);
319 printf(
"Testing SCardGetAttrib\t\t: ");
322 test_rv(rv, hContext, DONT_PANIC);
324 printf(
"SCARD_ATTR_DEVICE_FRIENDLY_NAME: " GREEN
"%s\n" NORMAL, pbAttr);
326 #ifdef USE_AUTOALLOCATE
327 printf(
"Testing SCardFreeMemory\t\t: ");
329 test_rv(rv, hContext, PANIC);
335 printf(
"Testing SCardGetAttrib\t\t: ");
336 #ifdef USE_AUTOALLOCATE
342 test_rv(rv, hContext, DONT_PANIC);
345 printf(
"SCARD_ATTR_ATR_STRING length: " GREEN
"%ld\n" NORMAL, pcbAttrLen);
346 pbAttr = malloc(pcbAttrLen);
349 printf(
"Testing SCardGetAttrib\t\t: ");
352 test_rv(rv, hContext, DONT_PANIC);
355 printf(
"SCARD_ATTR_ATR_STRING length: " GREEN
"%ld\n" NORMAL, pcbAttrLen);
356 printf(
"SCARD_ATTR_ATR_STRING: " GREEN);
357 for (i = 0; i < pcbAttrLen; i++)
358 printf(
"%02X ", pbAttr[i]);
362 #ifdef USE_AUTOALLOCATE
363 printf(
"Testing SCardFreeMemory\t\t: ");
365 test_rv(rv, hContext, PANIC);
371 printf(
"Testing SCardGetAttrib\t\t: ");
372 dwBufLen =
sizeof(buf);
374 test_rv(rv, hContext, DONT_PANIC);
376 printf(
"Vendor IFD version\t\t: " GREEN
"0x%08lX\n" NORMAL,
379 printf(
"Testing SCardGetAttrib\t\t: ");
380 dwBufLen =
sizeof(buf);
382 test_rv(rv, hContext, DONT_PANIC);
385 if (dwBufLen ==
sizeof(uint32_t))
386 printf(
"Max message length\t\t: " GREEN
"%d\n" NORMAL,
389 printf(RED
"Wrong size" NORMAL);
392 printf(
"Testing SCardGetAttrib\t\t: ");
393 dwBufLen =
sizeof(buf);
395 test_rv(rv, hContext, DONT_PANIC);
397 printf(
"Vendor name\t\t\t: " GREEN
"%s\n" NORMAL, buf.as_char);
399 printf(
"Testing SCardSetAttrib\t\t: ");
401 test_rv(rv, hContext, DONT_PANIC);
403 printf(
"Testing SCardStatus\t\t: ");
405 #ifdef USE_AUTOALLOCATE
408 rv =
SCardStatus(hCard, (LPSTR)&pcReaders, &dwReaderLen, &dwState, &dwProt,
409 (LPBYTE)&pbAtr, &dwAtrLen);
412 pcReaders = malloc(
sizeof(
char) * 100);
415 rv =
SCardStatus(hCard, pcReaders, &dwReaderLen, &dwState, &dwProt,
418 test_rv(rv, hContext, PANIC);
420 printf(
"Current Reader Name\t\t: " GREEN
"%s\n" NORMAL, pcReaders);
421 printf(
"Current Reader State\t\t: " GREEN
"0x%.4lx\n" NORMAL, dwState);
422 printf(
"Current Reader Protocol\t\t: T=" GREEN
"%ld\n" NORMAL, dwProt - 1);
423 printf(
"Current Reader ATR Size\t\t: " GREEN
"%ld" NORMAL
" bytes\n",
425 printf(
"Current Reader ATR Value\t: " GREEN);
427 for (i = 0; i < dwAtrLen; i++)
429 printf(
"%02X ", pbAtr[i]);
433 #ifdef USE_AUTOALLOCATE
434 printf(
"Testing SCardFreeMemory\t\t: ");
436 test_rv(rv, hContext, PANIC);
437 printf(
"Testing SCardFreeMemory\t\t: ");
439 test_rv(rv, hContext, PANIC);
451 printf(
"Press enter: ");
453 printf(
"Testing SCardReconnect\t\t: ");
456 test_rv(rv, hContext, PANIC);
458 printf(
"Testing SCardDisconnect\t\t: ");
460 test_rv(rv, hContext, PANIC);
462 #ifdef USE_AUTOALLOCATE
463 printf(
"Testing SCardFreeMemory\t\t: ");
465 test_rv(rv, hContext, PANIC);
470 printf(
"Testing SCardReleaseContext\t: ");
472 test_rv(rv, hContext, PANIC);
475 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.