FreeCalypso > hg > fc-sim-tools
comparison uicc/readef.c @ 89:db131929ee96
fc-uicc-tool: extended readef ported over from fc-simtool
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 11 Apr 2021 04:17:58 +0000 |
parents | simtool/readef.c@49b7e02787c1 |
children |
comparison
equal
deleted
inserted
replaced
88:49b7e02787c1 | 89:db131929ee96 |
---|---|
1 /* | |
2 * This module implements the readef command for dumping the complete | |
3 * content of SIM files. | |
4 */ | |
5 | |
6 #include <sys/types.h> | |
7 #include <ctype.h> | |
8 #include <stdio.h> | |
9 #include <stdlib.h> | |
10 #include "simresp.h" | |
11 #include "efstruct.h" | |
12 | |
13 static void | |
14 hexdump_with_offset(outf, extoff) | |
15 FILE *outf; | |
16 unsigned extoff; | |
17 { | |
18 unsigned off, cc, n, c; | |
19 | |
20 for (off = 0; off < sim_resp_data_len; off += cc) { | |
21 fprintf(outf, "%04X:", extoff + off); | |
22 cc = 16; | |
23 if (sim_resp_data_len - off < cc) | |
24 cc = sim_resp_data_len - off; | |
25 for (n = 0; n < 16; n++) { | |
26 if (n == 0 || n == 8) | |
27 putc(' ', outf); | |
28 putc(' ', outf); | |
29 if (n < cc) | |
30 fprintf(outf, "%02X", sim_resp_data[off + n]); | |
31 else { | |
32 putc(' ', outf); | |
33 putc(' ', outf); | |
34 } | |
35 } | |
36 putc(' ', outf); | |
37 putc(' ', outf); | |
38 for (n = 0; n < cc; n++) { | |
39 c = sim_resp_data[off + n]; | |
40 if (c < 0x20 || c > 0x7E) | |
41 c = '.'; | |
42 putc(c, outf); | |
43 } | |
44 putc('\n', outf); | |
45 } | |
46 } | |
47 | |
48 static | |
49 readef_transparent(efs, outf) | |
50 struct ef_struct *efs; | |
51 FILE *outf; | |
52 { | |
53 unsigned off, cc; | |
54 int rc; | |
55 | |
56 for (off = 0; off < efs->total_size; off += cc) { | |
57 cc = efs->total_size - off; | |
58 if (cc > 256) | |
59 cc = 256; | |
60 rc = readbin_op(off, cc); | |
61 if (rc < 0) | |
62 return(rc); | |
63 hexdump_with_offset(outf, off); | |
64 } | |
65 return(0); | |
66 } | |
67 | |
68 static | |
69 readef_records(efs, outf) | |
70 struct ef_struct *efs; | |
71 FILE *outf; | |
72 { | |
73 unsigned recno; | |
74 int rc; | |
75 | |
76 for (recno = 1; recno <= efs->record_count; recno++) { | |
77 fprintf(outf, "Record #%u:\n", recno); | |
78 rc = readrec_op(recno, 0x04, efs->record_len); | |
79 if (rc < 0) | |
80 return(rc); | |
81 display_sim_resp_in_hex(outf); | |
82 } | |
83 return(0); | |
84 } | |
85 | |
86 cmd_readef(argc, argv, outf) | |
87 char **argv; | |
88 FILE *outf; | |
89 { | |
90 int file_id, rc; | |
91 struct ef_struct efs; | |
92 | |
93 if (isxdigit(argv[1][0]) && isxdigit(argv[1][1]) && | |
94 isxdigit(argv[1][2]) && isxdigit(argv[1][3]) && !argv[1][4]) | |
95 file_id = strtoul(argv[1], 0, 16); | |
96 else | |
97 file_id = find_symbolic_file_name(argv[1]); | |
98 if (file_id < 0) { | |
99 fprintf(stderr, | |
100 "error: file ID argument is not a hex value or a recognized symbolic name\n"); | |
101 return(-1); | |
102 } | |
103 rc = select_op(file_id); | |
104 if (rc < 0) | |
105 return(rc); | |
106 rc = select_resp_get_ef_struct(&efs); | |
107 if (rc < 0) | |
108 return(rc); | |
109 switch (efs.structure) { | |
110 case 0x01: | |
111 fprintf(outf, "Transparent EF of %u byte(s)\n", efs.total_size); | |
112 return readef_transparent(&efs, outf); | |
113 case 0x02: | |
114 fprintf(outf, "%u records of %u bytes (linear fixed)\n", | |
115 efs.record_count, efs.record_len); | |
116 return readef_records(&efs, outf); | |
117 case 0x06: | |
118 fprintf(outf, "%u records of %u bytes (cyclic)\n", | |
119 efs.record_count, efs.record_len); | |
120 return readef_records(&efs, outf); | |
121 } | |
122 } |