blob: e48c76d54ed8fc837d79acf17419f7072e99c562 [file] [log] [blame]
The Android Open Source Project478ab6c2009-03-03 19:30:05 -08001/*
2 * Copyright (c) 1990, 1991, 1992, 1994, 1995, 1996
3 * The Regents of the University of California. All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that: (1) source code distributions
7 * retain the above copyright notice and this paragraph in its entirety, (2)
8 * distributions including binary code include the above copyright notice and
9 * this paragraph in its entirety in the documentation or other materials
10 * provided with the distribution, and (3) all advertising materials mentioning
11 * features or use of this software display the following acknowledgement:
12 * ``This product includes software developed by the University of California,
13 * Lawrence Berkeley Laboratory and its contributors.'' Neither the name of
14 * the University nor the names of its contributors may be used to endorse
15 * or promote products derived from this software without specific prior
16 * written permission.
17 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
18 * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
19 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
20 */
21
The Android Open Source Project478ab6c2009-03-03 19:30:05 -080022#ifdef HAVE_CONFIG_H
Haibo Huang165065a2018-07-23 17:26:52 -070023#include <config.h>
The Android Open Source Project478ab6c2009-03-03 19:30:05 -080024#endif
25
Haibo Huang165065a2018-07-23 17:26:52 -070026#include <pcap-types.h>
JP Abgrall511eca32014-02-12 13:46:45 -080027
The Android Open Source Project478ab6c2009-03-03 19:30:05 -080028#include <stdio.h>
29#include <string.h>
30
Haibo Huangee759ce2021-01-05 21:34:29 -080031#ifdef __linux__
32#include <linux/types.h>
33#include <linux/if_packet.h>
34#include <linux/filter.h>
35
36/*
37 * We want our versions of these #defines, not Linux's version.
38 * (The two should be the same; if not, we have a problem; all BPF
39 * implementations *should* be source-compatible supersets of ours.)
40 */
41#undef BPF_STMT
42#undef BPF_JUMP
43#endif
44
The Android Open Source Project478ab6c2009-03-03 19:30:05 -080045#include "pcap-int.h"
46
47#ifdef HAVE_OS_PROTO_H
48#include "os-proto.h"
49#endif
50
Haibo Huangee759ce2021-01-05 21:34:29 -080051#ifdef SKF_AD_OFF
52/*
53 * Symbolic names for offsets that refer to the special Linux BPF locations.
54 */
55static const char *offsets[SKF_AD_MAX] = {
56#ifdef SKF_AD_PROTOCOL
57 [SKF_AD_PROTOCOL] = "proto",
58#endif
59#ifdef SKF_AD_PKTTYPE
60 [SKF_AD_PKTTYPE] = "type",
61#endif
62#ifdef SKF_AD_IFINDEX
63 [SKF_AD_IFINDEX] = "ifidx",
64#endif
65#ifdef SKF_AD_NLATTR
66 [SKF_AD_NLATTR] = "nla",
67#endif
68#ifdef SKF_AD_NLATTR_NEST
69 [SKF_AD_NLATTR_NEST] = "nlan",
70#endif
71#ifdef SKF_AD_MARK
72 [SKF_AD_MARK] = "mark",
73#endif
74#ifdef SKF_AD_QUEUE
75 [SKF_AD_QUEUE] = "queue",
76#endif
77#ifdef SKF_AD_HATYPE
78 [SKF_AD_HATYPE] = "hatype",
79#endif
80#ifdef SKF_AD_RXHASH
81 [SKF_AD_RXHASH] = "rxhash",
82#endif
83#ifdef SKF_AD_CPU
84 [SKF_AD_CPU] = "cpu",
85#endif
86#ifdef SKF_AD_ALU_XOR_X
87 [SKF_AD_ALU_XOR_X] = "xor_x",
88#endif
89#ifdef SKF_AD_VLAN_TAG
90 [SKF_AD_VLAN_TAG] = "vlan_tci",
91#endif
92#ifdef SKF_AD_VLAN_TAG_PRESENT
93 [SKF_AD_VLAN_TAG_PRESENT] = "vlanp",
94#endif
95#ifdef SKF_AD_PAY_OFFSET
96 [SKF_AD_PAY_OFFSET] = "poff",
97#endif
98#ifdef SKF_AD_RANDOM
99 [SKF_AD_RANDOM] = "random",
100#endif
101#ifdef SKF_AD_VLAN_TPID
102 [SKF_AD_VLAN_TPID] = "vlan_tpid"
103#endif
104};
105#endif
106
107static void
108bpf_print_abs_load_operand(char *buf, size_t bufsize, const struct bpf_insn *p)
109{
110#ifdef SKF_AD_OFF
111 const char *sym;
112
113 /*
114 * It's an absolute load.
115 * Is the offset a special Linux offset that we know about?
116 */
117 if (p->k >= (bpf_u_int32)SKF_AD_OFF &&
118 p->k < (bpf_u_int32)(SKF_AD_OFF + SKF_AD_MAX) &&
119 (sym = offsets[p->k - (bpf_u_int32)SKF_AD_OFF]) != NULL) {
120 /*
121 * Yes. Print the offset symbolically.
122 */
123 (void)snprintf(buf, bufsize, "[%s]", sym);
124 } else
125#endif
126 (void)snprintf(buf, bufsize, "[%d]", p->k);
127}
128
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800129char *
Haibo Huang165065a2018-07-23 17:26:52 -0700130bpf_image(const struct bpf_insn *p, int n)
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800131{
Haibo Huang165065a2018-07-23 17:26:52 -0700132 const char *op;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800133 static char image[256];
Haibo Huang165065a2018-07-23 17:26:52 -0700134 char operand_buf[64];
135 const char *operand;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800136
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800137 switch (p->code) {
138
139 default:
140 op = "unimp";
Haibo Huangee759ce2021-01-05 21:34:29 -0800141 (void)snprintf(operand_buf, sizeof operand_buf, "0x%x", p->code);
Haibo Huang165065a2018-07-23 17:26:52 -0700142 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800143 break;
144
145 case BPF_RET|BPF_K:
146 op = "ret";
Haibo Huangee759ce2021-01-05 21:34:29 -0800147 (void)snprintf(operand_buf, sizeof operand_buf, "#%d", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700148 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800149 break;
150
151 case BPF_RET|BPF_A:
152 op = "ret";
Haibo Huang165065a2018-07-23 17:26:52 -0700153 operand = "";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800154 break;
155
156 case BPF_LD|BPF_W|BPF_ABS:
157 op = "ld";
Haibo Huangee759ce2021-01-05 21:34:29 -0800158 bpf_print_abs_load_operand(operand_buf, sizeof operand_buf, p);
Haibo Huang165065a2018-07-23 17:26:52 -0700159 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800160 break;
161
162 case BPF_LD|BPF_H|BPF_ABS:
163 op = "ldh";
Haibo Huangee759ce2021-01-05 21:34:29 -0800164 bpf_print_abs_load_operand(operand_buf, sizeof operand_buf, p);
Haibo Huang165065a2018-07-23 17:26:52 -0700165 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800166 break;
167
168 case BPF_LD|BPF_B|BPF_ABS:
169 op = "ldb";
Haibo Huangee759ce2021-01-05 21:34:29 -0800170 bpf_print_abs_load_operand(operand_buf, sizeof operand_buf, p);
Haibo Huang165065a2018-07-23 17:26:52 -0700171 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800172 break;
173
174 case BPF_LD|BPF_W|BPF_LEN:
175 op = "ld";
Haibo Huang165065a2018-07-23 17:26:52 -0700176 operand = "#pktlen";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800177 break;
178
179 case BPF_LD|BPF_W|BPF_IND:
180 op = "ld";
Haibo Huangee759ce2021-01-05 21:34:29 -0800181 (void)snprintf(operand_buf, sizeof operand_buf, "[x + %d]", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700182 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800183 break;
184
185 case BPF_LD|BPF_H|BPF_IND:
186 op = "ldh";
Haibo Huangee759ce2021-01-05 21:34:29 -0800187 (void)snprintf(operand_buf, sizeof operand_buf, "[x + %d]", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700188 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800189 break;
190
191 case BPF_LD|BPF_B|BPF_IND:
192 op = "ldb";
Haibo Huangee759ce2021-01-05 21:34:29 -0800193 (void)snprintf(operand_buf, sizeof operand_buf, "[x + %d]", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700194 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800195 break;
196
197 case BPF_LD|BPF_IMM:
198 op = "ld";
Haibo Huangee759ce2021-01-05 21:34:29 -0800199 (void)snprintf(operand_buf, sizeof operand_buf, "#0x%x", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700200 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800201 break;
202
203 case BPF_LDX|BPF_IMM:
204 op = "ldx";
Haibo Huangee759ce2021-01-05 21:34:29 -0800205 (void)snprintf(operand_buf, sizeof operand_buf, "#0x%x", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700206 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800207 break;
208
209 case BPF_LDX|BPF_MSH|BPF_B:
210 op = "ldxb";
Haibo Huangee759ce2021-01-05 21:34:29 -0800211 (void)snprintf(operand_buf, sizeof operand_buf, "4*([%d]&0xf)", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700212 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800213 break;
214
215 case BPF_LD|BPF_MEM:
216 op = "ld";
Haibo Huangee759ce2021-01-05 21:34:29 -0800217 (void)snprintf(operand_buf, sizeof operand_buf, "M[%d]", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700218 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800219 break;
220
221 case BPF_LDX|BPF_MEM:
222 op = "ldx";
Haibo Huangee759ce2021-01-05 21:34:29 -0800223 (void)snprintf(operand_buf, sizeof operand_buf, "M[%d]", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700224 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800225 break;
226
227 case BPF_ST:
228 op = "st";
Haibo Huangee759ce2021-01-05 21:34:29 -0800229 (void)snprintf(operand_buf, sizeof operand_buf, "M[%d]", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700230 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800231 break;
232
233 case BPF_STX:
234 op = "stx";
Haibo Huangee759ce2021-01-05 21:34:29 -0800235 (void)snprintf(operand_buf, sizeof operand_buf, "M[%d]", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700236 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800237 break;
238
239 case BPF_JMP|BPF_JA:
240 op = "ja";
Haibo Huangee759ce2021-01-05 21:34:29 -0800241 (void)snprintf(operand_buf, sizeof operand_buf, "%d", n + 1 + p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700242 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800243 break;
244
245 case BPF_JMP|BPF_JGT|BPF_K:
246 op = "jgt";
Haibo Huangee759ce2021-01-05 21:34:29 -0800247 (void)snprintf(operand_buf, sizeof operand_buf, "#0x%x", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700248 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800249 break;
250
251 case BPF_JMP|BPF_JGE|BPF_K:
252 op = "jge";
Haibo Huangee759ce2021-01-05 21:34:29 -0800253 (void)snprintf(operand_buf, sizeof operand_buf, "#0x%x", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700254 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800255 break;
256
257 case BPF_JMP|BPF_JEQ|BPF_K:
258 op = "jeq";
Haibo Huangee759ce2021-01-05 21:34:29 -0800259 (void)snprintf(operand_buf, sizeof operand_buf, "#0x%x", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700260 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800261 break;
262
263 case BPF_JMP|BPF_JSET|BPF_K:
264 op = "jset";
Haibo Huangee759ce2021-01-05 21:34:29 -0800265 (void)snprintf(operand_buf, sizeof operand_buf, "#0x%x", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700266 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800267 break;
268
269 case BPF_JMP|BPF_JGT|BPF_X:
270 op = "jgt";
Haibo Huang165065a2018-07-23 17:26:52 -0700271 operand = "x";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800272 break;
273
274 case BPF_JMP|BPF_JGE|BPF_X:
275 op = "jge";
Haibo Huang165065a2018-07-23 17:26:52 -0700276 operand = "x";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800277 break;
278
279 case BPF_JMP|BPF_JEQ|BPF_X:
280 op = "jeq";
Haibo Huang165065a2018-07-23 17:26:52 -0700281 operand = "x";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800282 break;
283
284 case BPF_JMP|BPF_JSET|BPF_X:
285 op = "jset";
Haibo Huang165065a2018-07-23 17:26:52 -0700286 operand = "x";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800287 break;
288
289 case BPF_ALU|BPF_ADD|BPF_X:
290 op = "add";
Haibo Huang165065a2018-07-23 17:26:52 -0700291 operand = "x";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800292 break;
293
294 case BPF_ALU|BPF_SUB|BPF_X:
295 op = "sub";
Haibo Huang165065a2018-07-23 17:26:52 -0700296 operand = "x";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800297 break;
298
299 case BPF_ALU|BPF_MUL|BPF_X:
300 op = "mul";
Haibo Huang165065a2018-07-23 17:26:52 -0700301 operand = "x";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800302 break;
303
304 case BPF_ALU|BPF_DIV|BPF_X:
305 op = "div";
Haibo Huang165065a2018-07-23 17:26:52 -0700306 operand = "x";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800307 break;
308
Elliott Hughesd8845d72015-10-19 18:07:04 -0700309 case BPF_ALU|BPF_MOD|BPF_X:
310 op = "mod";
Haibo Huang165065a2018-07-23 17:26:52 -0700311 operand = "x";
Elliott Hughesd8845d72015-10-19 18:07:04 -0700312 break;
313
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800314 case BPF_ALU|BPF_AND|BPF_X:
315 op = "and";
Haibo Huang165065a2018-07-23 17:26:52 -0700316 operand = "x";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800317 break;
318
319 case BPF_ALU|BPF_OR|BPF_X:
320 op = "or";
Haibo Huang165065a2018-07-23 17:26:52 -0700321 operand = "x";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800322 break;
323
Elliott Hughesd8845d72015-10-19 18:07:04 -0700324 case BPF_ALU|BPF_XOR|BPF_X:
325 op = "xor";
Haibo Huang165065a2018-07-23 17:26:52 -0700326 operand = "x";
Elliott Hughesd8845d72015-10-19 18:07:04 -0700327 break;
328
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800329 case BPF_ALU|BPF_LSH|BPF_X:
330 op = "lsh";
Haibo Huang165065a2018-07-23 17:26:52 -0700331 operand = "x";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800332 break;
333
334 case BPF_ALU|BPF_RSH|BPF_X:
335 op = "rsh";
Haibo Huang165065a2018-07-23 17:26:52 -0700336 operand = "x";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800337 break;
338
339 case BPF_ALU|BPF_ADD|BPF_K:
340 op = "add";
Haibo Huangee759ce2021-01-05 21:34:29 -0800341 (void)snprintf(operand_buf, sizeof operand_buf, "#%d", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700342 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800343 break;
344
345 case BPF_ALU|BPF_SUB|BPF_K:
346 op = "sub";
Haibo Huangee759ce2021-01-05 21:34:29 -0800347 (void)snprintf(operand_buf, sizeof operand_buf, "#%d", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700348 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800349 break;
350
351 case BPF_ALU|BPF_MUL|BPF_K:
352 op = "mul";
Haibo Huangee759ce2021-01-05 21:34:29 -0800353 (void)snprintf(operand_buf, sizeof operand_buf, "#%d", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700354 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800355 break;
356
357 case BPF_ALU|BPF_DIV|BPF_K:
358 op = "div";
Haibo Huangee759ce2021-01-05 21:34:29 -0800359 (void)snprintf(operand_buf, sizeof operand_buf, "#%d", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700360 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800361 break;
362
Elliott Hughesd8845d72015-10-19 18:07:04 -0700363 case BPF_ALU|BPF_MOD|BPF_K:
364 op = "mod";
Haibo Huangee759ce2021-01-05 21:34:29 -0800365 (void)snprintf(operand_buf, sizeof operand_buf, "#%d", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700366 operand = operand_buf;
Elliott Hughesd8845d72015-10-19 18:07:04 -0700367 break;
368
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800369 case BPF_ALU|BPF_AND|BPF_K:
370 op = "and";
Haibo Huangee759ce2021-01-05 21:34:29 -0800371 (void)snprintf(operand_buf, sizeof operand_buf, "#0x%x", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700372 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800373 break;
374
375 case BPF_ALU|BPF_OR|BPF_K:
376 op = "or";
Haibo Huangee759ce2021-01-05 21:34:29 -0800377 (void)snprintf(operand_buf, sizeof operand_buf, "#0x%x", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700378 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800379 break;
380
Elliott Hughesd8845d72015-10-19 18:07:04 -0700381 case BPF_ALU|BPF_XOR|BPF_K:
382 op = "xor";
Haibo Huangee759ce2021-01-05 21:34:29 -0800383 (void)snprintf(operand_buf, sizeof operand_buf, "#0x%x", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700384 operand = operand_buf;
Elliott Hughesd8845d72015-10-19 18:07:04 -0700385 break;
386
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800387 case BPF_ALU|BPF_LSH|BPF_K:
388 op = "lsh";
Haibo Huangee759ce2021-01-05 21:34:29 -0800389 (void)snprintf(operand_buf, sizeof operand_buf, "#%d", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700390 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800391 break;
392
393 case BPF_ALU|BPF_RSH|BPF_K:
394 op = "rsh";
Haibo Huangee759ce2021-01-05 21:34:29 -0800395 (void)snprintf(operand_buf, sizeof operand_buf, "#%d", p->k);
Haibo Huang165065a2018-07-23 17:26:52 -0700396 operand = operand_buf;
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800397 break;
398
399 case BPF_ALU|BPF_NEG:
400 op = "neg";
Haibo Huang165065a2018-07-23 17:26:52 -0700401 operand = "";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800402 break;
403
404 case BPF_MISC|BPF_TAX:
405 op = "tax";
Haibo Huang165065a2018-07-23 17:26:52 -0700406 operand = "";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800407 break;
408
409 case BPF_MISC|BPF_TXA:
410 op = "txa";
Haibo Huang165065a2018-07-23 17:26:52 -0700411 operand = "";
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800412 break;
413 }
JP Abgrall511eca32014-02-12 13:46:45 -0800414 if (BPF_CLASS(p->code) == BPF_JMP && BPF_OP(p->code) != BPF_JA) {
Haibo Huangee759ce2021-01-05 21:34:29 -0800415 (void)snprintf(image, sizeof image,
JP Abgrall511eca32014-02-12 13:46:45 -0800416 "(%03d) %-8s %-16s jt %d\tjf %d",
417 n, op, operand, n + 1 + p->jt, n + 1 + p->jf);
418 } else {
Haibo Huangee759ce2021-01-05 21:34:29 -0800419 (void)snprintf(image, sizeof image,
JP Abgrall511eca32014-02-12 13:46:45 -0800420 "(%03d) %-8s %s",
421 n, op, operand);
422 }
The Android Open Source Project478ab6c2009-03-03 19:30:05 -0800423 return image;
424}