FreeCalypso > hg > fc-sim-tools
comparison simtool/a38.c @ 10:ddd767f6e15b
fc-simtool ported over
| author | Mychaela Falconia <falcon@freecalypso.org> |
|---|---|
| date | Sun, 14 Mar 2021 07:11:25 +0000 |
| parents | |
| children |
comparison
equal
deleted
inserted
replaced
| 9:c9ef9e91dd8e | 10:ddd767f6e15b |
|---|---|
| 1 /* | |
| 2 * This module implements the a38 command for exercising | |
| 3 * the SIM's RUN GSM ALGORITHM operation. | |
| 4 */ | |
| 5 | |
| 6 #include <sys/types.h> | |
| 7 #include <ctype.h> | |
| 8 #include <stdio.h> | |
| 9 #include <stdlib.h> | |
| 10 #include "simresp.h" | |
| 11 | |
| 12 cmd_a38(argc, argv, outf) | |
| 13 char **argv; | |
| 14 FILE *outf; | |
| 15 { | |
| 16 u_char cmd[21]; | |
| 17 int rc; | |
| 18 | |
| 19 /* RUN GSM ALGORITHM command APDU */ | |
| 20 cmd[0] = 0xA0; | |
| 21 cmd[1] = 0x88; | |
| 22 cmd[2] = 0; | |
| 23 cmd[3] = 0; | |
| 24 cmd[4] = 16; | |
| 25 rc = decode_hex_data_from_string(argv[1], cmd + 5, 16, 16); | |
| 26 if (rc < 0) | |
| 27 return(rc); | |
| 28 rc = apdu_exchange(cmd, 21); | |
| 29 if (rc < 0) | |
| 30 return(rc); | |
| 31 if (sim_resp_sw != 0x9F0C) { | |
| 32 fprintf(stderr, | |
| 33 "error or unexpected SW response to RUN GSM ALGO: %04X\n", | |
| 34 sim_resp_sw); | |
| 35 return(-1); | |
| 36 } | |
| 37 /* GET RESPONSE follow-up */ | |
| 38 cmd[1] = 0xC0; | |
| 39 cmd[4] = 12; | |
| 40 rc = apdu_exchange(cmd, 5); | |
| 41 if (rc < 0) | |
| 42 return(rc); | |
| 43 if (sim_resp_sw != 0x9000) { | |
| 44 fprintf(stderr, "bad SW resp to GET RESPONSE: %04X\n", | |
| 45 sim_resp_sw); | |
| 46 return(-1); | |
| 47 } | |
| 48 if (sim_resp_data_len != 12) { | |
| 49 fprintf(stderr, | |
| 50 "error: GET RESPONSE returned %u bytes, expected 12\n", | |
| 51 sim_resp_data_len); | |
| 52 return(-1); | |
| 53 } | |
| 54 fprintf(outf, "SRES: %02X %02X %02X %02X\n", sim_resp_data[0], | |
| 55 sim_resp_data[1], sim_resp_data[2], sim_resp_data[3]); | |
| 56 fprintf(outf, "Kc: %02X %02X %02X %02X %02X %02X %02X %02X\n", | |
| 57 sim_resp_data[4], sim_resp_data[5], sim_resp_data[6], | |
| 58 sim_resp_data[7], sim_resp_data[8], sim_resp_data[9], | |
| 59 sim_resp_data[10], sim_resp_data[11]); | |
| 60 return(0); | |
| 61 } |
