# HG changeset patch # User Mychaela Falconia # Date 1613149741 0 # Node ID 84d1c31d0fadc1a7a00a819f4dad6b514fb2c3ae # Parent d368051576d0ce3634741d9a653aaca4589119d3 first round of refactoring for selection among multiple readers diff -r d368051576d0 -r 84d1c31d0fad libcommon/cardconnect.c --- a/libcommon/cardconnect.c Fri Feb 12 16:19:11 2021 +0000 +++ b/libcommon/cardconnect.c Fri Feb 12 17:09:01 2021 +0000 @@ -7,7 +7,7 @@ SCARDCONTEXT hContext; SCARDHANDLE hCard; -char *reader_name_buf; +char *reader_list, *selected_reader; setup_pcsc_context() { @@ -22,7 +22,7 @@ return(0); } -get_reader_name() +get_reader_list() { LONG rv; DWORD dwReaders; @@ -40,33 +40,40 @@ SCardReleaseContext(hContext); exit(1); } - reader_name_buf = malloc(dwReaders); - if (!reader_name_buf) { + reader_list = malloc(dwReaders); + if (!reader_list) { perror("malloc for readers list"); SCardReleaseContext(hContext); exit(1); } - reader_name_buf[0] = '\0'; - rv = SCardListReaders(hContext, NULL, reader_name_buf, &dwReaders); + reader_list[0] = '\0'; + rv = SCardListReaders(hContext, NULL, reader_list, &dwReaders); if (rv != SCARD_S_SUCCESS) { fprintf(stderr, "SCardListReaders 2nd call: %s\n", pcsc_stringify_error(rv)); SCardReleaseContext(hContext); exit(1); } - if (reader_name_buf[0] == '\0') { - fprintf(stderr, - "error: list returned by SCardListReaders() begins with a NUL byte\n"); - SCardReleaseContext(hContext); - exit(1); + return(0); +} + +select_reader_num(select_num) + unsigned select_num; +{ + char *cp; + unsigned num; + + for (cp = reader_list, num = 0; *cp; num++) { + if (num == select_num) { + selected_reader = cp; + return(0); + } + cp += strlen(cp) + 1; } - if (!memchr(reader_name_buf, 0, dwReaders)) { - fprintf(stderr, -"error: list returned by SCardListReaders() does not contain a NUL byte\n"); - SCardReleaseContext(hContext); - exit(1); - } - return(0); + fprintf(stderr, + "error: requested reader #%u, but only %u readers found\n", + select_num, num); + exit(1); } connect_to_card() @@ -74,7 +81,7 @@ LONG rv; DWORD dwActiveProtocol; - rv = SCardConnect(hContext, reader_name_buf, SCARD_SHARE_EXCLUSIVE, + rv = SCardConnect(hContext, selected_reader, SCARD_SHARE_EXCLUSIVE, SCARD_PROTOCOL_T0, &hCard, &dwActiveProtocol); if (rv != SCARD_S_SUCCESS) { fprintf(stderr, "SCardConnect: %s\n", pcsc_stringify_error(rv)); diff -r d368051576d0 -r 84d1c31d0fad libcommon/cardif.h --- a/libcommon/cardif.h Fri Feb 12 16:19:11 2021 +0000 +++ b/libcommon/cardif.h Fri Feb 12 17:09:01 2021 +0000 @@ -2,4 +2,4 @@ extern SCARDCONTEXT hContext; extern SCARDHANDLE hCard; -extern char *reader_name_buf; +extern char *reader_list, *selected_reader; diff -r d368051576d0 -r 84d1c31d0fad misc/fc-pcsc-atr.c --- a/misc/fc-pcsc-atr.c Fri Feb 12 16:19:11 2021 +0000 +++ b/misc/fc-pcsc-atr.c Fri Feb 12 17:09:01 2021 +0000 @@ -10,8 +10,9 @@ int rc; setup_pcsc_context(); - get_reader_name(); - printf("Card reader name: %s\n", reader_name_buf); + get_reader_list(); + select_reader_num(0); + printf("Card reader name: %s\n", selected_reader); connect_to_card(); rc = retrieve_atr(); if (rc) diff -r d368051576d0 -r 84d1c31d0fad simtool/main.c --- a/simtool/main.c Fri Feb 12 16:19:11 2021 +0000 +++ b/simtool/main.c Fri Feb 12 17:09:01 2021 +0000 @@ -12,9 +12,10 @@ int rc; setup_pcsc_context(); - get_reader_name(); + get_reader_list(); + select_reader_num(0); if (argc < 2) - printf("Card reader name: %s\n", reader_name_buf); + printf("Card reader name: %s\n", selected_reader); connect_to_card(); if (argc >= 2) { rc = dispatch_ready_argv(argc - 1, argv + 1); diff -r d368051576d0 -r 84d1c31d0fad uicc/main.c --- a/uicc/main.c Fri Feb 12 16:19:11 2021 +0000 +++ b/uicc/main.c Fri Feb 12 17:09:01 2021 +0000 @@ -12,9 +12,10 @@ int rc; setup_pcsc_context(); - get_reader_name(); + get_reader_list(); + select_reader_num(0); if (argc < 2) - printf("Card reader name: %s\n", reader_name_buf); + printf("Card reader name: %s\n", selected_reader); connect_to_card(); if (argc >= 2) { rc = dispatch_ready_argv(argc - 1, argv + 1);