annotate rvinterf/libprint/gpf_tst.c @ 977:511e2b85c115

fc-loadtool: implement flash lock-state command
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 01 Dec 2023 07:51:01 +0000
parents 4d2e6a2dd1a1
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
939
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
1 /*
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
2 * This libprint module (one public function plus many internal subfunctions)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
3 * implements printing/formatting of GPF TST interface packets, which can be
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
4 * traces, sysprims, protocol stack primitives or unrecognized packet format.
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
5 */
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
6
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
7 #include <sys/types.h>
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
8 #include <ctype.h>
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
9 #include <stdio.h>
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
10 #include <stdlib.h>
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
11 #include <string.h>
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
12 #include <strings.h>
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
13
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
14 static int
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
15 basic_checks(rxpkt, rxpkt_len)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
16 u_char *rxpkt;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
17 unsigned rxpkt_len;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
18 {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
19 int i, c;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
20
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
21 if (rxpkt_len < 17)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
22 return(0);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
23 /* check version bits in the header byte */
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
24 if ((rxpkt[1] & 0xC0) != 0x80)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
25 return(0);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
26 /* check the length */
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
27 c = rxpkt[2] | rxpkt[3] << 8;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
28 if (c + 4 != rxpkt_len)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
29 return(0);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
30 /* ensure that the "from" and "to" are printable ASCII */
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
31 for (i = 8; i < 16; i++) {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
32 c = rxpkt[i];
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
33 if (c < ' ' || c > '~')
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
34 return(0);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
35 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
36 /* basic checks pass */
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
37 return(1);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
38 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
39
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
40 static int
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
41 psprim_extra_checks(rxpkt, rxpkt_len)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
42 u_char *rxpkt;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
43 unsigned rxpkt_len;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
44 {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
45 int i, c;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
46
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
47 if (rxpkt_len < 24)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
48 return(0);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
49 /* "original rcvr" field needs to be printable ASCII */
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
50 for (i = 16; i < 20; i++) {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
51 c = rxpkt[i];
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
52 if (c < ' ' || c > '~')
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
53 return(0);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
54 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
55 /* checks pass */
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
56 return(1);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
57 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
58
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
59 static void
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
60 print_malformed(rxpkt, rxpkt_len, extra_prefix, outfunc_head, outfunc_cont)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
61 u_char *rxpkt;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
62 unsigned rxpkt_len;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
63 char *extra_prefix;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
64 void (*outfunc_head)(), (*outfunc_cont)();
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
65 {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
66 char headline[80];
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
67
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
68 sprintf(headline, "%sGPF unrecognized packet format", extra_prefix);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
69 outfunc_head(headline);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
70 packet_hex_dump(rxpkt, rxpkt_len, outfunc_cont);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
71 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
72
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
73 static void
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
74 print_malloc_fail(rxpkt, rxpkt_len, extra_prefix, outfunc_head, outfunc_cont)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
75 u_char *rxpkt;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
76 unsigned rxpkt_len;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
77 char *extra_prefix;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
78 void (*outfunc_head)(), (*outfunc_cont)();
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
79 {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
80 char headline[80];
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
81
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
82 sprintf(headline, "%sGPF packet, failed malloc in formatting",
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
83 extra_prefix);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
84 outfunc_head(headline);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
85 packet_hex_dump(rxpkt, rxpkt_len, outfunc_cont);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
86 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
87
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
88 static int
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
89 entity_name_well_formed(p)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
90 char *p;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
91 {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
92 int i, len;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
93
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
94 if (!isupper(p[0]))
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
95 return(0);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
96 for (i = 0; i < 4; i++)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
97 if (!isalnum(p[i]))
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
98 break;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
99 len = i;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
100 for (; i < 4; i++)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
101 if (p[i] != ' ')
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
102 return(0);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
103 return(len);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
104 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
105
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
106 static void
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
107 print_entity_name(raw, outp)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
108 char *raw, **outp;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
109 {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
110 int len;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
111
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
112 len = entity_name_well_formed(raw);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
113 if (len) {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
114 sprintf(*outp, "%.*s", len, raw);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
115 *outp += len;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
116 } else {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
117 sprintf(*outp, "\"%.4s\"", raw);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
118 *outp += 6;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
119 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
120 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
121
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
122 static void
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
123 print_common_hdr(rxpkt, outp, typestr, extra_prefix)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
124 u_char *rxpkt;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
125 char **outp, *typestr, *extra_prefix;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
126 {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
127 sprintf(*outp, "%sGPF %s id=%02X ts=%02X%02X%02X%02X ", extra_prefix,
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
128 typestr, rxpkt[1], rxpkt[7], rxpkt[6], rxpkt[5], rxpkt[4]);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
129 *outp = index(*outp, '\0');
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
130 print_entity_name(rxpkt + 8, outp);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
131 *(*outp)++ = '-';
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
132 *(*outp)++ = '>';
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
133 print_entity_name(rxpkt + 12, outp);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
134 *(*outp)++ = ' ';
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
135 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
136
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
137 static void
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
138 format_text(rxpkt, rxpkt_len, start_off, outp)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
139 u_char *rxpkt;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
140 unsigned rxpkt_len, start_off;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
141 char *outp;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
142 {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
143 *outp++ = '\"';
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
144 safe_print_trace(rxpkt + start_off, rxpkt_len - start_off, outp);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
145 outp = index(outp, '\0');
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
146 *outp++ = '\"';
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
147 *outp = '\0';
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
148 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
149
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
150 static void
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
151 format_compressed_trace(rxpkt, rxpkt_len, start_off, outp)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
152 u_char *rxpkt;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
153 unsigned rxpkt_len, start_off;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
154 char *outp;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
155 {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
156 int i;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
157
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
158 i = start_off + 1;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
159 sprintf(outp, "%d", rxpkt[i+1] << 8 | rxpkt[i]);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
160 outp = index(outp, '\0');
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
161 i += 4;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
162 for (; i < rxpkt_len; i++) {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
163 sprintf(outp, " %02X", rxpkt[i]);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
164 outp += 3;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
165 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
166 *outp = '\0';
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
167 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
168
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
169 static void
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
170 format_trace(rxpkt, rxpkt_len, extra_prefix, outfunc_head, outfunc_cont)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
171 u_char *rxpkt;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
172 unsigned rxpkt_len;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
173 char *extra_prefix;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
174 void (*outfunc_head)(), (*outfunc_cont)();
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
175 {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
176 char *outbuf, *outp;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
177 int i;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
178
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
179 outbuf = malloc(rxpkt_len * 4 + strlen(extra_prefix) + 1);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
180 if (!outbuf) {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
181 print_malloc_fail(rxpkt, rxpkt_len, extra_prefix, outfunc_head,
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
182 outfunc_cont);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
183 return;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
184 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
185 outp = outbuf;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
186 print_common_hdr(rxpkt, &outp, "trace", extra_prefix);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
187 i = 16;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
188 if (rxpkt[i] < 0x20) {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
189 sprintf(outp, "tc=%02X ", rxpkt[i]);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
190 outp += 6;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
191 i++;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
192 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
193 if (rxpkt_len - i >= 5 && rxpkt[i] == '%' &&
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
194 !rxpkt[i+3] && !rxpkt[i+4])
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
195 format_compressed_trace(rxpkt, rxpkt_len, i, outp);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
196 else
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
197 format_text(rxpkt, rxpkt_len, i, outp);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
198 outfunc_head(outbuf);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
199 free(outbuf);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
200 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
201
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
202 static void
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
203 format_sysprim(rxpkt, rxpkt_len, extra_prefix, outfunc_head, outfunc_cont)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
204 u_char *rxpkt;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
205 unsigned rxpkt_len;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
206 char *extra_prefix;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
207 void (*outfunc_head)(), (*outfunc_cont)();
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
208 {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
209 char *outbuf, *outp;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
210
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
211 outbuf = malloc(rxpkt_len * 4 + strlen(extra_prefix) + 1);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
212 if (!outbuf) {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
213 print_malloc_fail(rxpkt, rxpkt_len, extra_prefix, outfunc_head,
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
214 outfunc_cont);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
215 return;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
216 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
217 outp = outbuf;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
218 print_common_hdr(rxpkt, &outp, "sysprim", extra_prefix);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
219 format_text(rxpkt, rxpkt_len, 16, outp);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
220 outfunc_head(outbuf);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
221 free(outbuf);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
222 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
223
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
224 static void
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
225 format_psprim(rxpkt, rxpkt_len, extra_prefix, outfunc_head, outfunc_cont)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
226 u_char *rxpkt;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
227 unsigned rxpkt_len;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
228 char *extra_prefix;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
229 void (*outfunc_head)(), (*outfunc_cont)();
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
230 {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
231 char headline[80];
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
232 char *outp = headline;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
233
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
234 print_common_hdr(rxpkt, &outp, "PSprim", extra_prefix);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
235 /* original destination */
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
236 *outp++ = '(';
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
237 print_entity_name(rxpkt + 16, &outp);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
238 *outp++ = ')';
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
239 /* opcode and data length */
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
240 sprintf(outp, " %02X%02X%02X%02X len=%u",
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
241 rxpkt[23], rxpkt[22], rxpkt[21], rxpkt[20], rxpkt_len - 24);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
242 outfunc_head(headline);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
243 packet_hex_dump(rxpkt + 24, rxpkt_len - 24, outfunc_cont);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
244 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
245
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
246 void
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
247 format_gpf_packet(rxpkt, rxpkt_len, extra_prefix, outfunc_head, outfunc_cont)
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
248 u_char *rxpkt;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
249 unsigned rxpkt_len;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
250 char *extra_prefix;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
251 void (*outfunc_head)(), (*outfunc_cont)();
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
252 {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
253 if (!basic_checks(rxpkt, rxpkt_len)) {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
254 print_malformed(rxpkt, rxpkt_len, extra_prefix, outfunc_head,
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
255 outfunc_cont);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
256 return;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
257 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
258 /* dispatch by type */
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
259 switch (rxpkt[1] & 0x30) {
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
260 case 0x10:
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
261 /* PS primitive */
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
262 if (psprim_extra_checks(rxpkt, rxpkt_len))
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
263 format_psprim(rxpkt, rxpkt_len, extra_prefix,
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
264 outfunc_head, outfunc_cont);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
265 else
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
266 print_malformed(rxpkt, rxpkt_len, extra_prefix,
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
267 outfunc_head, outfunc_cont);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
268 return;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
269 case 0x20:
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
270 /* trace */
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
271 format_trace(rxpkt, rxpkt_len, extra_prefix, outfunc_head,
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
272 outfunc_cont);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
273 return;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
274 case 0x30:
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
275 /* system primitive */
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
276 format_sysprim(rxpkt, rxpkt_len, extra_prefix, outfunc_head,
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
277 outfunc_cont);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
278 return;
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
279 default:
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
280 print_malformed(rxpkt, rxpkt_len, extra_prefix, outfunc_head,
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
281 outfunc_cont);
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
282 }
4d2e6a2dd1a1 libprint: implement libg23 replacement
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
283 }