FreeCalypso > hg > fc-pcsc-tools
view simtool/readops.c @ 74:8562d8508cf2
grcard2-set-{adm,super}-hex commands implemented
It appears that GrcardSIM2 cards allow arbitrary 64-bit keys
for ADM and SUPER ADM, not necessarily consisting of ASCII digits
like the specs require for standard PIN and PUK, and pySim-prog.py
in fact sets the ADM key to 4444444444444444 in hex by default,
which is not an ASCII digit string. If the cards allow such keys,
we need to support them too.
| author | Mychaela Falconia <falcon@freecalypso.org> |
|---|---|
| date | Tue, 16 Feb 2021 04:10:36 +0000 |
| parents | 2071b28cd0c7 |
| children |
line wrap: on
line source
#include <sys/types.h> #include <stdio.h> #include <stdlib.h> #include "simresp.h" readbin_op(offset, len) unsigned offset, len; { u_char cmd[5]; int rc; /* READ BINARY command APDU */ cmd[0] = 0xA0; cmd[1] = 0xB0; cmd[2] = offset >> 8; cmd[3] = offset; cmd[4] = len; rc = apdu_exchange(cmd, 5); if (rc < 0) return(rc); if (sim_resp_sw != 0x9000) { fprintf(stderr, "bad SW response to READ BINARY: %04X\n", sim_resp_sw); return(-1); } if (sim_resp_data_len != len) { fprintf(stderr, "error: READ BINARY returned %u bytes, expected %u\n", sim_resp_data_len, len); return(-1); } return(0); } readrec_op(recno, mode, len) unsigned recno, mode, len; { u_char cmd[5]; int rc; /* READ RECORD command APDU */ cmd[0] = 0xA0; cmd[1] = 0xB2; cmd[2] = recno; cmd[3] = mode; cmd[4] = len; rc = apdu_exchange(cmd, 5); if (rc < 0) return(rc); if (sim_resp_sw != 0x9000) { fprintf(stderr, "bad SW response to READ RECORD: %04X\n", sim_resp_sw); return(-1); } if (sim_resp_data_len != len) { fprintf(stderr, "error: READ RECORD returned %u bytes, expected %u\n", sim_resp_data_len, len); return(-1); } return(0); }
