annotate simtool/sstdump.c @ 48:9a21f4353158

fc-simtool sst-dump implemented
author Mychaela Falconia <falcon@freecalypso.org>
date Sat, 13 Feb 2021 03:09:44 +0000
parents
children bbc2821288aa
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
48
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
1 /*
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
2 * This module implements the sst-dump command,
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
3 * providing a more readable form of the SIM Service Table.
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
4 */
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
5
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
6 #include <sys/types.h>
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
7 #include <stdio.h>
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
8 #include "simresp.h"
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
9 #include "curfile.h"
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
10 #include "file_id.h"
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
11
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
12 cmd_sst_dump()
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
13 {
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
14 int rc;
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
15 unsigned byte, pos, code, nserv;
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
16
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
17 rc = select_op(DF_GSM);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
18 if (rc < 0)
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
19 return(rc);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
20 rc = select_op(EF_SST);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
21 if (rc < 0)
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
22 return(rc);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
23 rc = parse_ef_select_response();
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
24 if (rc < 0)
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
25 return(rc);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
26 if (curfile_structure != 0x00) {
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
27 fprintf(stderr, "error: EF_SST is not transparent\n");
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
28 return(-1);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
29 }
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
30 if (curfile_total_size < 2) {
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
31 fprintf(stderr,
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
32 "error: EF_SST is shorter than spec minimum of 2 bytes\n");
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
33 return(-1);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
34 }
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
35 if (curfile_total_size > 256) {
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
36 fprintf(stderr,
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
37 "error: EF_SST is longer than our 256 byte limit\n");
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
38 return(-1);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
39 }
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
40 rc = readbin_op(0, curfile_total_size);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
41 if (rc < 0)
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
42 return(rc);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
43 nserv = 1;
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
44 for (byte = 0; byte < curfile_total_size; byte++) {
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
45 for (pos = 0; pos < 8; pos += 2) {
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
46 code = (sim_resp_data[byte] >> pos) & 3;
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
47 if (code == 3)
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
48 printf("#%u: activated\n", nserv);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
49 else if (code == 1)
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
50 printf("#%u: allocated\n", nserv);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
51 nserv++;
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
52 }
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
53 }
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
54 return(0);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
55 }