X-Git-Url: http://www.average.org/gitweb/?p=pam_pcsc_cr.git;a=blobdiff_plain;f=pcsc_cr.c;h=48c79f8443e29a8942f7469409f6e8a96eb98acf;hp=03a05d090583ce962d5217dda8f294a66a69141f;hb=d428f25cb05d2def10d08cd0e34fe5fe4d4b45fc;hpb=740b870a7a4d1936991d856f5427e4c10c2c849a diff --git a/pcsc_cr.c b/pcsc_cr.c index 03a05d0..48c79f8 100644 --- a/pcsc_cr.c +++ b/pcsc_cr.c @@ -1,3 +1,6 @@ +#ifdef HAVE_CONFIG_H +# include "config.h" +#endif #include #include #include @@ -34,7 +37,8 @@ static LONG find_hb(BYTE *atr, DWORD atrsize, BYTE **hb, LPDWORD hbsize) return SCARD_S_SUCCESS; } -long pcsc_cr(unsigned char *chal, int csize, unsigned char *resp, int *rsize) +long pcsc_cr(const unsigned char *chal, const int csize, + unsigned char *resp, int *rsize) { struct token_interface *type; LONG rc; @@ -84,8 +88,17 @@ long pcsc_cr(unsigned char *chal, int csize, unsigned char *resp, int *rsize) (void)SCardDisconnect(hCard, SCARD_LEAVE_CARD); } if (rc) goto free_out; +#if 0 + char serial[16]; + memset(serial, 'z', sizeof(serial)); + serial[sizeof(serial) - 1] - '\0'; + lrsize = sizeof(serial); + rc = type->getserial(hCard, &serial, &lrsize); + if (rc) goto disc_free_out; + printf("Serial is %s\n", serial); +#endif lrsize = *rsize; - rc = type->trancieve(hCard, chal, csize, resp, &lrsize); + rc = type->trancieve(hCard, (BYTE*)chal, csize, resp, &lrsize); if (rc) goto disc_free_out; *rsize = lrsize; rc = type->epilogue(hCard); @@ -100,7 +113,7 @@ char *pcsc_errstr(long err) { return pcsc_stringify_error(err); } -int pcsc_option(char *option) +int pcsc_option(const char *option) { char *name, *key, *val; int i, rc = -1;