annotate simtool/sstprog.c @ 211:31cd62f91522

fc-simtool write-spn command implemented
author Mychaela Falconia <falcon@freecalypso.org>
date Sun, 07 Mar 2021 06:41:40 +0000
parents eb16c8841486
children
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 /*
209
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
2 * This module implements the write-sst command for admin-level
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
3 * programming of SIM cards.
48
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>
209
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
7 #include <ctype.h>
48
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
8 #include <stdio.h>
209
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
9 #include <stdlib.h>
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
10 #include <string.h>
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
11 #include <strings.h>
48
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
12 #include "curfile.h"
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
13 #include "file_id.h"
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
14
209
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
15 extern FILE *open_script_input_file();
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
16
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
17 cmd_write_sst(argc, argv)
116
9c16cf1a79af fc-simtool sst: support output redirection
Mychaela Falconia <falcon@freecalypso.org>
parents: 60
diff changeset
18 char **argv;
48
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
19 {
209
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
20 u_char sst[255];
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
21 FILE *inf;
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
22 int lineno, rc;
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
23 char linebuf[1024], *cp, *np;
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
24 unsigned num, code, max_serv;
48
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
25
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
26 rc = select_op(DF_GSM);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
27 if (rc < 0)
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
28 return(rc);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
29 rc = select_op(EF_SST);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
30 if (rc < 0)
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
31 return(rc);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
32 rc = parse_ef_select_response();
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
33 if (rc < 0)
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
34 return(rc);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
35 if (curfile_structure != 0x00) {
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
36 fprintf(stderr, "error: EF_SST is not transparent\n");
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
37 return(-1);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
38 }
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
39 if (curfile_total_size < 2) {
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
40 fprintf(stderr,
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
41 "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
42 return(-1);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
43 }
209
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
44 if (curfile_total_size > 255) {
48
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
45 fprintf(stderr,
209
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
46 "error: EF_SST is longer than our 255 byte limit\n");
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
47 return(-1);
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
48 }
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
49 memset(sst, 0, curfile_total_size);
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
50 max_serv = curfile_total_size * 4;
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
51 inf = open_script_input_file(argv[1]);
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
52 if (!inf) {
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
53 perror(argv[1]);
48
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
54 return(-1);
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
55 }
209
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
56 for (lineno = 1; fgets(linebuf, sizeof linebuf, inf); lineno++) {
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
57 if (!index(linebuf, '\n')) {
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
58 fprintf(stderr,
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
59 "%s line %d: too long or missing newline\n",
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
60 argv[1], lineno);
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
61 fclose(inf);
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
62 return(-1);
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
63 }
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
64 for (cp = linebuf; ; ) {
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
65 while (isspace(*cp))
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
66 cp++;
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
67 if (*cp == '\0' || *cp == '#')
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
68 break;
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
69 if (!isdigit(*cp)) {
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
70 inv_syntax: fprintf(stderr, "%s line %d: invalid syntax\n",
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
71 argv[1], lineno);
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
72 fclose(inf);
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
73 return(-1);
49
bbc2821288aa fc-simtool sst-dump: much more compact output
Mychaela Falconia <falcon@freecalypso.org>
parents: 48
diff changeset
74 }
209
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
75 num = strtoul(cp, 0, 10);
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
76 while (isdigit(*cp))
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
77 cp++;
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
78 if (*cp == '^') {
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
79 cp++;
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
80 code = 1;
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
81 } else
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
82 code = 3;
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
83 if (*cp && !isspace(*cp))
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
84 goto inv_syntax;
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
85 if (num < 1 || num > max_serv) {
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
86 fprintf(stderr,
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
87 "%s line %d: service number is out of range\n",
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
88 argv[1], lineno);
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
89 fclose(inf);
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
90 return(-1);
49
bbc2821288aa fc-simtool sst-dump: much more compact output
Mychaela Falconia <falcon@freecalypso.org>
parents: 48
diff changeset
91 }
209
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
92 num--;
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
93 sst[num >> 2] |= code << ((num & 3) << 1);
48
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
94 }
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
95 }
209
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
96 fclose(inf);
eb16c8841486 fc-simtool write-sst command implemented
Mychaela Falconia <falcon@freecalypso.org>
parents: 116
diff changeset
97 return update_bin_op(0, sst, curfile_total_size);
48
9a21f4353158 fc-simtool sst-dump implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
98 }