summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/libsectok/atr.c33
-rw-r--r--lib/libsectok/cmdtab.c110
-rw-r--r--lib/libsectok/ifdhandler.c4
-rw-r--r--lib/libsectok/input.c5
-rw-r--r--lib/libsectok/r1r2.c5
-rw-r--r--lib/libsectok/sc7816.c4
-rw-r--r--lib/libsectok/scio.c5
-rw-r--r--lib/libsectok/scrw.c4
-rw-r--r--lib/libsectok/todos_atr.c10
-rw-r--r--lib/libsectok/todos_scrw.h3
10 files changed, 82 insertions, 101 deletions
diff --git a/lib/libsectok/atr.c b/lib/libsectok/atr.c
index 618ba4b7b19..2549f70293a 100644
--- a/lib/libsectok/atr.c
+++ b/lib/libsectok/atr.c
@@ -5,7 +5,7 @@
*
* Jim Rees, University of Michigan CITI
*/
-static char *rcsid = "$Id: atr.c,v 1.1 2001/06/07 15:17:32 rees Exp $";
+static char *rcsid = "$Id: atr.c,v 1.2 2001/06/07 16:09:59 rees Exp $";
#ifdef __palmos__
#include <Common.h>
@@ -134,9 +134,6 @@ parse_atr(int ttyn, int flags, unsigned char *atr, int len, struct scparam *para
printf("inverse conversion\n");
for (i = 0; i < len; i++)
atr[i] = scinvert[atr[i]];
-#ifdef SCPPS
- scsetflags(ttyn, SCOINVRT, SCOINVRT);
-#endif
}
ts = *ap++;
@@ -248,36 +245,8 @@ parse_atr(int ttyn, int flags, unsigned char *atr, int len, struct scparam *para
if (!(flags & SCRTODOS)) {
for (i = 0; bps[i].bps; i++) {
if (((TA1 >> 4) & 0xf) >= bps[i].Fi && (TA1 & 0xf) >= bps[i].Di) {
- int j;
- unsigned char c;
- static unsigned char pps[4] = {0xff, 0x10, 0, 0};
-
- pps[2] = (bps[i].Fi << 4) | bps[i].Di;
- pps[3] = 0;
-
if (flags & SCRV)
printf("speed %ld\n", bps[i].bps);
-
-#ifdef SCPPS
- /* Compute checksum */
- for (j = 0; j < 3; j++)
- pps[3] ^= pps[j];
-
- for (j = 0; j < 4; j++)
- scputc(ttyn, pps[j]);
- for (j = 0; j < 4; j++)
- if (scgetc(ttyn, &c, 100) != SCEOK || c != pps[j])
- break;
- if (j != 4)
- continue;
- if (scsetspeed(ttyn, bps[i].bps) < 0) {
- /* We already sent the pps, can't back out now, so fail. */
- if (flags & SCRV)
- printf("scsetspeed %ld failed\n", bps[i].bps);
- param->t = -1;
- return len;
- }
-#endif
Fi = bps[i].Fi;
Di = bps[i].Di;
break;
diff --git a/lib/libsectok/cmdtab.c b/lib/libsectok/cmdtab.c
index 5985ee11cd6..62b626c6e66 100644
--- a/lib/libsectok/cmdtab.c
+++ b/lib/libsectok/cmdtab.c
@@ -2,7 +2,7 @@
* See copyright notice at end of file
*/
-static char *rcsid = "$Id: cmdtab.c,v 1.1 2001/06/07 15:17:32 rees Exp $";
+static char *rcsid = "$Id: cmdtab.c,v 1.2 2001/06/07 16:09:59 rees Exp $";
#ifdef __palmos__
#include <Common.h>
@@ -22,67 +22,67 @@ struct cmd {
char *name;
} cmdtab[] = {
/* 7816-4 */
- 0x0e, 0, "erase binary",
- 0x20, 0, "verify",
- 0x70, 0, "manage channel",
- 0x82, 0, "ext auth",
- 0x84, 1, "get challenge",
- 0x88, 0, "int auth",
- 0xa4, 0, "select",
- 0xb0, 1, "read binary",
- 0xb2, 1, "read record",
- 0xc0, 1, "get response",
- 0xc2, 0, "envelope",
- 0xca, 0, "get data",
- 0xd0, 0, "write binary",
- 0xd2, 0, "write record",
- 0xd6, 0, "update binary",
- 0xda, 0, "put data",
- 0xdc, 0, "update record",
- 0xe2, 0, "append record",
+ {0x0e, 0, "erase binary"},
+ {0x20, 0, "verify"},
+ {0x70, 0, "manage channel"},
+ {0x82, 0, "ext auth"},
+ {0x84, 1, "get challenge"},
+ {0x88, 0, "int auth"},
+ {0xa4, 0, "select"},
+ {0xb0, 1, "read binary"},
+ {0xb2, 1, "read record"},
+ {0xc0, 1, "get response"},
+ {0xc2, 0, "envelope"},
+ {0xca, 0, "get data"},
+ {0xd0, 0, "write binary"},
+ {0xd2, 0, "write record"},
+ {0xd6, 0, "update binary"},
+ {0xda, 0, "put data"},
+ {0xdc, 0, "update record"},
+ {0xe2, 0, "append record"},
/* Webcard */
- 0xfe, 0, "ip7816",
+ {0xfe, 0, "ip7816"},
/* Cyberflex Access */
- 0x04, 0, "invalidate",
- 0x08, 0, "manage instance",
- 0x0a, 0, "manage program",
- 0x0c, 0, "execute method",
- 0x22, 0, "logout all",
- 0x24, 0, "change PIN",
- 0x2a, 0, "verify key",
- 0x2c, 0, "unblock",
- 0x44, 0, "rehabilitate",
- 0xa8, 1, "directory",
- 0xe0, 0, "create",
- 0xe4, 0, "delete",
- 0xfa, 0, "change java atr",
- 0xfc, 0, "change acl",
-/* 0xfe, 1, "get acl",*/
+ {0x04, 0, "invalidate"},
+ {0x08, 0, "manage instance"},
+ {0x0a, 0, "manage program"},
+ {0x0c, 0, "execute method"},
+ {0x22, 0, "logout all"},
+ {0x24, 0, "change PIN"},
+ {0x2a, 0, "verify key"},
+ {0x2c, 0, "unblock"},
+ {0x44, 0, "rehabilitate"},
+ {0xa8, 1, "directory"},
+ {0xe0, 0, "create"},
+ {0xe4, 0, "delete"},
+ {0xfa, 0, "change java atr"},
+ {0xfc, 0, "change acl"},
+/* {0xfe, 1, "get acl"},*/
/* GSM */
- 0x26, 0, "disable PIN",
- 0x28, 0, "enable PIN",
- 0x30, 0, "decrease",
- 0x32, 0, "increase",
- 0xf2, 1, "get status",
+ {0x26, 0, "disable PIN"},
+ {0x28, 0, "enable PIN"},
+ {0x30, 0, "decrease"},
+ {0x32, 0, "increase"},
+ {0xf2, 1, "get status"},
/* Visa cash / open platform */
- 0x50, 0, "init update",
- 0x80, 0, "install default app",
+ {0x50, 0, "init update"},
+ {0x80, 0, "install default app"},
#ifdef PAYFLEX
/* Payflex */
- 0x52, 0, "credit",
- 0x54, 0, "debit",
- 0x56, 0, "replace debit",
- 0x58, 0, "token debit",
- 0x5a, 0, "token purchase",
- 0x5c, 0, "update currency",
- 0x8a, 0, "cert credit",
- 0x8c, 0, "cert debit",
- 0x8e, 0, "generate diversified key",
- 0xd8, 0, "load key",
- 0xde, 0, "update max amount",
- 0xf4, 0, "load exe",
+ {0x52, 0, "credit"},
+ {0x54, 0, "debit"},
+ {0x56, 0, "replace debit"},
+ {0x58, 0, "token debit"},
+ {0x5a, 0, "token purchase"},
+ {0x5c, 0, "update currency"},
+ {0x8a, 0, "cert credit"},
+ {0x8c, 0, "cert debit"},
+ {0x8e, 0, "generate diversified key"},
+ {0xd8, 0, "load key"},
+ {0xde, 0, "update max amount"},
+ {0xf4, 0, "load exe"},
#endif /* PAYFLEX */
- 0, 0, NULL
+ {0, 0, NULL}
};
struct cmd *
diff --git a/lib/libsectok/ifdhandler.c b/lib/libsectok/ifdhandler.c
index 296e8a60e12..11e8901bafe 100644
--- a/lib/libsectok/ifdhandler.c
+++ b/lib/libsectok/ifdhandler.c
@@ -5,7 +5,7 @@
*
* Jim Rees, University of Michigan CITI, August 2000
*/
-static char *rcsid = "$Id: ifdhandler.c,v 1.1 2001/06/07 15:17:32 rees Exp $";
+static char *rcsid = "$Id: ifdhandler.c,v 1.2 2001/06/07 16:09:59 rees Exp $";
#include <sys/types.h>
#include <stdio.h>
@@ -190,7 +190,7 @@ IFD_Transmit_to_ICC(struct SCARD_IO_HEADER SendPci,
struct SCARD_IO_HEADER *RecvPci)
{
unsigned char buf[255+2];
- int n, p3, sw1, sw2;
+ int n, sw1, sw2;
#ifdef DEBUG
printf("p3 %x ilen %x *olen %x\n", ibuf[4], ilen, *olen);
diff --git a/lib/libsectok/input.c b/lib/libsectok/input.c
index df0043238a6..c93fa9dee0e 100644
--- a/lib/libsectok/input.c
+++ b/lib/libsectok/input.c
@@ -5,10 +5,13 @@
*
* Jim Rees, University of Michigan, July 2000
*/
-static char *rcsid = "$Id: input.c,v 1.1 2001/06/07 15:17:33 rees Exp $";
+static char *rcsid = "$Id: input.c,v 1.2 2001/06/07 16:09:59 rees Exp $";
#include <stdio.h>
#include <ctype.h>
+#include <string.h>
+
+#include "sectok.h"
#ifdef TEST
main(ac, av)
diff --git a/lib/libsectok/r1r2.c b/lib/libsectok/r1r2.c
index c9c4c075c95..af079c0ab92 100644
--- a/lib/libsectok/r1r2.c
+++ b/lib/libsectok/r1r2.c
@@ -3,7 +3,7 @@
*
* See copyright notice at end of file
*/
-static char *rcsid = "$Id: r1r2.c,v 1.1 2001/06/07 15:17:33 rees Exp $";
+static char *rcsid = "$Id: r1r2.c,v 1.2 2001/06/07 16:10:00 rees Exp $";
#ifdef __palmos__
#define NULL 0
@@ -94,7 +94,6 @@ char *
scr1r2s(int r1, int r2)
{
int i;
- char *s;
static char buf[64];
for (i = 0; r1r2s[i].s; i++)
@@ -124,7 +123,7 @@ fdump_reply(FILE *f, unsigned char *p, int n, int r1, int r2)
int
dump_reply(unsigned char *p, int n, int r1, int r2)
{
- fdump_reply(stdout, p, n, r1, r2);
+ return fdump_reply(stdout, p, n, r1, r2);
}
#endif
diff --git a/lib/libsectok/sc7816.c b/lib/libsectok/sc7816.c
index 8b0464f3667..6a3fc3df04b 100644
--- a/lib/libsectok/sc7816.c
+++ b/lib/libsectok/sc7816.c
@@ -7,10 +7,12 @@
* Mukesh Agrawal
* University of Michigan CITI, August 2000
*/
-static char *rcsid = "$Id: sc7816.c,v 1.1 2001/06/07 15:17:33 rees Exp $";
+static char *rcsid = "$Id: sc7816.c,v 1.2 2001/06/07 16:10:00 rees Exp $";
#include <sys/types.h>
#include <sys/time.h>
+#include <stdlib.h>
+#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <dlfcn.h>
diff --git a/lib/libsectok/scio.c b/lib/libsectok/scio.c
index 8d5ee9cd9d6..682eafff8b0 100644
--- a/lib/libsectok/scio.c
+++ b/lib/libsectok/scio.c
@@ -5,7 +5,7 @@
*
* Jim Rees, University of Michigan, October 1997
*/
-static char *rcsid = "$Id: scio.c,v 1.1 2001/06/07 15:17:33 rees Exp $";
+static char *rcsid = "$Id: scio.c,v 1.2 2001/06/07 16:10:00 rees Exp $";
#include <sys/ioctl.h>
#include <sys/file.h>
@@ -24,6 +24,9 @@ static char *rcsid = "$Id: scio.c,v 1.1 2001/06/07 15:17:33 rees Exp $";
#include "sectok.h"
#include "todos_scrw.h"
+int todos_scfdopen(int ttyn, int fd, int flags, int *ep);
+int todos_sccts(int ttyn);
+
#ifdef __linux
static char ttynametmpl[] = "/dev/cua%01d";
#elif _AIX
diff --git a/lib/libsectok/scrw.c b/lib/libsectok/scrw.c
index 57180c34954..b71b329b218 100644
--- a/lib/libsectok/scrw.c
+++ b/lib/libsectok/scrw.c
@@ -5,7 +5,7 @@
*
* Jim Rees, University of Michigan, October 1997
*/
-static char *rcsid = "$Id: scrw.c,v 1.1 2001/06/07 15:17:33 rees Exp $";
+static char *rcsid = "$Id: scrw.c,v 1.2 2001/06/07 16:10:00 rees Exp $";
#ifdef __palmos__
#include <Common.h>
@@ -49,7 +49,7 @@ int todos_scioT1(int ttyn, int cla, int ins, int p1, int p2, int ilen, unsigned
int
todos_scxreset(int ttyn, int flags, unsigned char *atr, int *ep)
{
- unsigned char *ap, buf[33];
+ unsigned char buf[33];
int n, err;
if (ep)
diff --git a/lib/libsectok/todos_atr.c b/lib/libsectok/todos_atr.c
index 151428fb13f..1619da0548b 100644
--- a/lib/libsectok/todos_atr.c
+++ b/lib/libsectok/todos_atr.c
@@ -5,7 +5,7 @@
*
* Jim Rees, University of Michigan CITI
*/
-static char *rcsid = "$Id: todos_atr.c,v 1.1 2001/06/07 15:17:33 rees Exp $";
+static char *rcsid = "$Id: todos_atr.c,v 1.2 2001/06/07 16:10:00 rees Exp $";
#ifdef __palmos__
#include <Common.h>
@@ -23,6 +23,10 @@ static char *rcsid = "$Id: todos_atr.c,v 1.1 2001/06/07 15:17:33 rees Exp $";
#include "sectok.h"
#include "todos_scrw.h"
+#ifdef __unix__
+#define SCPPS
+#endif
+
/*
* 7816 says ATR will appear within 40000 clocks (12 msec)
* BUT some cards violate the spec and require more time
@@ -129,9 +133,9 @@ static struct bps {
int
todos_get_atr(int ttyn, int flags, unsigned char *atr, struct scparam *param)
{
- int len, i, c, t, ts, t0, tck, nhb, pbn;
+ int len, i, t, ts, t0, tck, nhb, pbn;
int F, D, Fi, Di, N, etu, WI;
- unsigned char *ap, *hb;
+ unsigned char *ap;
unsigned char tpb[8][4];
int hiproto = 0;
diff --git a/lib/libsectok/todos_scrw.h b/lib/libsectok/todos_scrw.h
index 65a6366f28b..ccc3b0e0a00 100644
--- a/lib/libsectok/todos_scrw.h
+++ b/lib/libsectok/todos_scrw.h
@@ -1,7 +1,7 @@
/*
* See copyright notice at end of file
*
- * $Id: todos_scrw.h,v 1.1 2001/06/07 15:17:33 rees Exp $
+ * $Id: todos_scrw.h,v 1.2 2001/06/07 16:10:01 rees Exp $
*/
extern unsigned char todos_scinvert[];
@@ -10,6 +10,7 @@ extern unsigned char todos_scinvert[];
int todos_scopen(int ttyn, int flags, int *ep);
int todos_scsetflags(int ttyn, int flags, int mask);
+int todos_scsetspeed(int ttyn, int speed);
int todos_scrw(int ttyn, int cla, int ins, int p1, int p2, int ilen, unsigned char *ibuf, int olen, unsigned char *obuf, int *sw1p, int *sw2p);
int todos_sccardpresent(int ttyn);
int todos_scdsr(int ttyn);