YKPIV: Make sure that context is established only if it is invalid.

This commit is contained in:
Alessio Di Mauro
2015-11-10 11:12:21 +01:00
parent c49f1f0c51
commit f2a3a3acc1
+10 -8
View File
@@ -103,7 +103,7 @@ ykpiv_rc ykpiv_init(ykpiv_state **state, int verbose) {
}
memset(s, 0, sizeof(ykpiv_state));
s->verbose = verbose;
s->context = -1;
s->context = SCARD_E_INVALID_HANDLE;
*state = s;
return YKPIV_OK;
}
@@ -120,9 +120,9 @@ ykpiv_rc ykpiv_disconnect(ykpiv_state *state) {
state->card = 0;
}
if(state->context) {
if(SCardIsValidContext(state->context) == SCARD_S_SUCCESS) {
SCardReleaseContext(state->context);
state->context = 0;
state->context = SCARD_E_INVALID_HANDLE;
}
return YKPIV_OK;
@@ -205,12 +205,14 @@ ykpiv_rc ykpiv_list_readers(ykpiv_state *state, char *readers, size_t *len) {
unsigned long num_readers = 0;
long rc;
rc = SCardEstablishContext(SCARD_SCOPE_SYSTEM, NULL, NULL, &state->context);
if (rc != SCARD_S_SUCCESS) {
if(state->verbose) {
fprintf (stderr, "error: SCardEstablishContext failed, rc=%08lx\n", rc);
if(SCardIsValidContext(state->context) != SCARD_S_SUCCESS) {
rc = SCardEstablishContext(SCARD_SCOPE_SYSTEM, NULL, NULL, &state->context);
if (rc != SCARD_S_SUCCESS) {
if(state->verbose) {
fprintf (stderr, "error: SCardEstablishContext failed, rc=%08lx\n", rc);
}
return YKPIV_PCSC_ERROR;
}
return YKPIV_PCSC_ERROR;
}
rc = SCardListReaders(state->context, NULL, NULL, &num_readers);