2 * netsniff-ng - the packet sniffing beast
3 * By Daniel Borkmann <daniel@netsniff-ng.org>
4 * Copyright 2011 Daniel Borkmann <dborkma@tik.ee.ethz.ch>,
5 * Swiss federal institute of technology (ETH Zurich)
6 * Subject to the GPL, version 2.
9 /* yaac-func-prefix: yy */
24 #include "bpf_parser.tab.h"
29 #define MAX_INSTRUCTIONS 4096
31 int compile_filter
(char *file
, int verbose
, int bypass
, int format
,
34 static int curr_instr
= 0;
36 static struct sock_filter out
[MAX_INSTRUCTIONS
];
38 static char *labels
[MAX_INSTRUCTIONS
];
40 static char *labels_jt
[MAX_INSTRUCTIONS
];
41 static char *labels_jf
[MAX_INSTRUCTIONS
];
42 static char *labels_k
[MAX_INSTRUCTIONS
];
44 #define YYERROR_VERBOSE 0
46 #define YYENABLE_NLS 1
47 #define YYLTYPE_IS_TRIVIAL 1
51 extern
int yylex(void);
52 extern
void yyerror(const char *);
56 static inline
void check_max_instr
(void)
58 if
(curr_instr
>= MAX_INSTRUCTIONS
)
59 panic
("Exceeded maximal number of instructions!\n");
62 static inline
void set_curr_instr
(uint16_t code
, uint8_t jt
, uint8_t jf
, uint32_t k
)
66 out
[curr_instr
].code
= code
;
67 out
[curr_instr
].jt
= jt
;
68 out
[curr_instr
].jf
= jf
;
69 out
[curr_instr
].k
= k
;
74 static inline
void set_curr_label
(char *label
)
78 labels
[curr_instr
] = label
;
85 static inline
void set_jmp_label
(char *label
, int which
)
91 labels_jt
[curr_instr
] = label
;
94 labels_jf
[curr_instr
] = label
;
97 labels_k
[curr_instr
] = label
;
104 static int find_intr_offset_or_panic
(char *label_to_search
)
106 int i
, max
= curr_instr
, ret
= -ENOENT
;
108 bug_on
(!label_to_search
);
110 for
(i
= 0; i
< max
; ++i
) {
111 if
(labels
[i
] != NULL
) {
112 /* Both are \0-terminated! */
113 if
(!strcmp
(label_to_search
, labels
[i
])) {
121 panic
("No such label!\n");
133 %token OP_LDB OP_LDH OP_LD OP_LDX OP_ST OP_STX OP_JMP OP_JEQ OP_JGT OP_JGE
134 %token OP_JSET OP_ADD OP_SUB OP_MUL OP_DIV OP_AND OP_OR OP_XOR OP_LSH OP_RSH
135 %token OP_RET OP_TAX OP_TXA OP_LDXB OP_MOD OP_NEG OP_JNEQ OP_JLT OP_JLE OP_LDI
138 %token K_PKT_LEN K_PROTO K_TYPE K_NLATTR K_NLATTR_NEST K_MARK K_QUEUE K_HATYPE
139 %token K_RXHASH K_CPU K_IFIDX K_VLANT K_VLANP K_POFF
141 %token
':' ',' '[' ']' '(' ')' 'x' 'a' '+' 'M' '*' '&' '#'
145 %type
<number
> number
198 : label
':' { set_curr_label
($1); }
202 : OP_LDB
'[' 'x' '+' number
']' {
203 set_curr_instr
(BPF_LD | BPF_B | BPF_IND
, 0, 0, $5); }
204 | OP_LDB
'[' number
']' {
205 set_curr_instr
(BPF_LD | BPF_B | BPF_ABS
, 0, 0, $3); }
207 set_curr_instr
(BPF_LD | BPF_B | BPF_ABS
, 0, 0,
208 SKF_AD_OFF
+ SKF_AD_PROTOCOL
); }
210 set_curr_instr
(BPF_LD | BPF_B | BPF_ABS
, 0, 0,
211 SKF_AD_OFF
+ SKF_AD_PKTTYPE
); }
213 set_curr_instr
(BPF_LD | BPF_B | BPF_ABS
, 0, 0,
214 SKF_AD_OFF
+ SKF_AD_IFINDEX
); }
216 set_curr_instr
(BPF_LD | BPF_B | BPF_ABS
, 0, 0,
217 SKF_AD_OFF
+ SKF_AD_NLATTR
); }
218 | OP_LDB K_NLATTR_NEST
{
219 set_curr_instr
(BPF_LD | BPF_B | BPF_ABS
, 0, 0,
220 SKF_AD_OFF
+ SKF_AD_NLATTR_NEST
); }
222 set_curr_instr
(BPF_LD | BPF_B | BPF_ABS
, 0, 0,
223 SKF_AD_OFF
+ SKF_AD_MARK
); }
225 set_curr_instr
(BPF_LD | BPF_B | BPF_ABS
, 0, 0,
226 SKF_AD_OFF
+ SKF_AD_QUEUE
); }
228 set_curr_instr
(BPF_LD | BPF_B | BPF_ABS
, 0, 0,
229 SKF_AD_OFF
+ SKF_AD_HATYPE
); }
231 set_curr_instr
(BPF_LD | BPF_B | BPF_ABS
, 0, 0,
232 SKF_AD_OFF
+ SKF_AD_RXHASH
); }
234 set_curr_instr
(BPF_LD | BPF_B | BPF_ABS
, 0, 0,
235 SKF_AD_OFF
+ SKF_AD_CPU
); }
237 set_curr_instr
(BPF_LD | BPF_B | BPF_ABS
, 0, 0,
238 SKF_AD_OFF
+ SKF_AD_VLAN_TAG
); }
240 set_curr_instr
(BPF_LD | BPF_B | BPF_ABS
, 0, 0,
241 SKF_AD_OFF
+ SKF_AD_VLAN_TAG_PRESENT
); }
243 set_curr_instr
(BPF_LD | BPF_B | BPF_ABS
, 0, 0,
244 SKF_AD_OFF
+ SKF_AD_PAY_OFFSET
); }
248 : OP_LDH
'[' 'x' '+' number
']' {
249 set_curr_instr
(BPF_LD | BPF_H | BPF_IND
, 0, 0, $5); }
250 | OP_LDH
'[' number
']' {
251 set_curr_instr
(BPF_LD | BPF_H | BPF_ABS
, 0, 0, $3); }
253 set_curr_instr
(BPF_LD | BPF_H | BPF_ABS
, 0, 0,
254 SKF_AD_OFF
+ SKF_AD_PROTOCOL
); }
256 set_curr_instr
(BPF_LD | BPF_H | BPF_ABS
, 0, 0,
257 SKF_AD_OFF
+ SKF_AD_PKTTYPE
); }
259 set_curr_instr
(BPF_LD | BPF_H | BPF_ABS
, 0, 0,
260 SKF_AD_OFF
+ SKF_AD_IFINDEX
); }
262 set_curr_instr
(BPF_LD | BPF_H | BPF_ABS
, 0, 0,
263 SKF_AD_OFF
+ SKF_AD_NLATTR
); }
264 | OP_LDH K_NLATTR_NEST
{
265 set_curr_instr
(BPF_LD | BPF_H | BPF_ABS
, 0, 0,
266 SKF_AD_OFF
+ SKF_AD_NLATTR_NEST
); }
268 set_curr_instr
(BPF_LD | BPF_H | BPF_ABS
, 0, 0,
269 SKF_AD_OFF
+ SKF_AD_MARK
); }
271 set_curr_instr
(BPF_LD | BPF_H | BPF_ABS
, 0, 0,
272 SKF_AD_OFF
+ SKF_AD_QUEUE
); }
274 set_curr_instr
(BPF_LD | BPF_H | BPF_ABS
, 0, 0,
275 SKF_AD_OFF
+ SKF_AD_HATYPE
); }
277 set_curr_instr
(BPF_LD | BPF_H | BPF_ABS
, 0, 0,
278 SKF_AD_OFF
+ SKF_AD_RXHASH
); }
280 set_curr_instr
(BPF_LD | BPF_H | BPF_ABS
, 0, 0,
281 SKF_AD_OFF
+ SKF_AD_CPU
); }
283 set_curr_instr
(BPF_LD | BPF_H | BPF_ABS
, 0, 0,
284 SKF_AD_OFF
+ SKF_AD_VLAN_TAG
); }
286 set_curr_instr
(BPF_LD | BPF_H | BPF_ABS
, 0, 0,
287 SKF_AD_OFF
+ SKF_AD_VLAN_TAG_PRESENT
); }
289 set_curr_instr
(BPF_LD | BPF_H | BPF_ABS
, 0, 0,
290 SKF_AD_OFF
+ SKF_AD_PAY_OFFSET
); }
295 set_curr_instr
(BPF_LD | BPF_IMM
, 0, 0, $2); }
300 set_curr_instr
(BPF_LD | BPF_IMM
, 0, 0, $3); }
302 set_curr_instr
(BPF_LD | BPF_W | BPF_LEN
, 0, 0, 0); }
304 set_curr_instr
(BPF_LD | BPF_W | BPF_ABS
, 0, 0,
305 SKF_AD_OFF
+ SKF_AD_PROTOCOL
); }
307 set_curr_instr
(BPF_LD | BPF_W | BPF_ABS
, 0, 0,
308 SKF_AD_OFF
+ SKF_AD_PKTTYPE
); }
310 set_curr_instr
(BPF_LD | BPF_W | BPF_ABS
, 0, 0,
311 SKF_AD_OFF
+ SKF_AD_IFINDEX
); }
313 set_curr_instr
(BPF_LD | BPF_W | BPF_ABS
, 0, 0,
314 SKF_AD_OFF
+ SKF_AD_NLATTR
); }
315 | OP_LD K_NLATTR_NEST
{
316 set_curr_instr
(BPF_LD | BPF_W | BPF_ABS
, 0, 0,
317 SKF_AD_OFF
+ SKF_AD_NLATTR_NEST
); }
319 set_curr_instr
(BPF_LD | BPF_W | BPF_ABS
, 0, 0,
320 SKF_AD_OFF
+ SKF_AD_MARK
); }
322 set_curr_instr
(BPF_LD | BPF_W | BPF_ABS
, 0, 0,
323 SKF_AD_OFF
+ SKF_AD_QUEUE
); }
325 set_curr_instr
(BPF_LD | BPF_W | BPF_ABS
, 0, 0,
326 SKF_AD_OFF
+ SKF_AD_HATYPE
); }
328 set_curr_instr
(BPF_LD | BPF_W | BPF_ABS
, 0, 0,
329 SKF_AD_OFF
+ SKF_AD_RXHASH
); }
331 set_curr_instr
(BPF_LD | BPF_W | BPF_ABS
, 0, 0,
332 SKF_AD_OFF
+ SKF_AD_CPU
); }
334 set_curr_instr
(BPF_LD | BPF_W | BPF_ABS
, 0, 0,
335 SKF_AD_OFF
+ SKF_AD_VLAN_TAG
); }
337 set_curr_instr
(BPF_LD | BPF_W | BPF_ABS
, 0, 0,
338 SKF_AD_OFF
+ SKF_AD_VLAN_TAG_PRESENT
); }
340 set_curr_instr
(BPF_LD | BPF_W | BPF_ABS
, 0, 0,
341 SKF_AD_OFF
+ SKF_AD_PAY_OFFSET
); }
342 | OP_LD
'M' '[' number
']' {
343 set_curr_instr
(BPF_LD | BPF_MEM
, 0, 0, $4); }
344 | OP_LD
'[' 'x' '+' number
']' {
345 set_curr_instr
(BPF_LD | BPF_W | BPF_IND
, 0, 0, $5); }
346 | OP_LD
'[' number
']' {
347 set_curr_instr
(BPF_LD | BPF_W | BPF_ABS
, 0, 0, $3); }
352 set_curr_instr
(BPF_LDX | BPF_IMM
, 0, 0, $2); }
356 : OP_LDX
'#' number
{
357 set_curr_instr
(BPF_LDX | BPF_IMM
, 0, 0, $3); }
358 | OP_LDX
'M' '[' number
']' {
359 set_curr_instr
(BPF_LDX | BPF_MEM
, 0, 0, $4); }
360 | OP_LDXB number
'*' '(' '[' number
']' '&' number
')' {
361 if
($2 != 4 ||
$9 != 0xf) {
362 panic
("ldxb offset not supported!\n");
364 set_curr_instr
(BPF_LDX | BPF_MSH | BPF_B
, 0, 0, $6); } }
365 | OP_LDX number
'*' '(' '[' number
']' '&' number
')' {
366 if
($2 != 4 ||
$9 != 0xf) {
367 panic
("ldxb offset not supported!\n");
369 set_curr_instr
(BPF_LDX | BPF_MSH | BPF_B
, 0, 0, $6); } }
373 : OP_ST
'M' '[' number
']' {
374 set_curr_instr
(BPF_ST
, 0, 0, $4); }
378 : OP_STX
'M' '[' number
']' {
379 set_curr_instr
(BPF_STX
, 0, 0, $4); }
384 set_jmp_label
($2, JKL
);
385 set_curr_instr
(BPF_JMP | BPF_JA
, 0, 0, 0); }
389 : OP_JEQ
'#' number
',' label
',' label
{
390 set_jmp_label
($5, JTL
);
391 set_jmp_label
($7, JFL
);
392 set_curr_instr
(BPF_JMP | BPF_JEQ | BPF_K
, 0, 0, $3); }
393 | OP_JEQ
'x' ',' label
',' label
{
394 set_jmp_label
($4, JTL
);
395 set_jmp_label
($6, JFL
);
396 set_curr_instr
(BPF_JMP | BPF_JEQ | BPF_X
, 0, 0, 0); }
397 | OP_JEQ
'#' number
',' label
{
398 set_jmp_label
($5, JTL
);
399 set_curr_instr
(BPF_JMP | BPF_JEQ | BPF_K
, 0, 0, $3); }
400 | OP_JEQ
'x' ',' label
{
401 set_jmp_label
($4, JTL
);
402 set_curr_instr
(BPF_JMP | BPF_JEQ | BPF_X
, 0, 0, 0); }
406 : OP_JNEQ
'#' number
',' label
{
407 set_jmp_label
($5, JFL
);
408 set_curr_instr
(BPF_JMP | BPF_JEQ | BPF_K
, 0, 0, $3); }
409 | OP_JNEQ
'x' ',' label
{
410 set_jmp_label
($4, JFL
);
411 set_curr_instr
(BPF_JMP | BPF_JEQ | BPF_X
, 0, 0, 0); }
415 : OP_JLT
'#' number
',' label
{
416 set_jmp_label
($5, JFL
);
417 set_curr_instr
(BPF_JMP | BPF_JGE | BPF_K
, 0, 0, $3); }
418 | OP_JLT
'x' ',' label
{
419 set_jmp_label
($4, JFL
);
420 set_curr_instr
(BPF_JMP | BPF_JGE | BPF_X
, 0, 0, 0); }
424 : OP_JLE
'#' number
',' label
{
425 set_jmp_label
($5, JFL
);
426 set_curr_instr
(BPF_JMP | BPF_JGT | BPF_K
, 0, 0, $3); }
427 | OP_JLE
'x' ',' label
{
428 set_jmp_label
($4, JFL
);
429 set_curr_instr
(BPF_JMP | BPF_JGT | BPF_X
, 0, 0, 0); }
433 : OP_JGT
'#' number
',' label
',' label
{
434 set_jmp_label
($5, JTL
);
435 set_jmp_label
($7, JFL
);
436 set_curr_instr
(BPF_JMP | BPF_JGT | BPF_K
, 0, 0, $3); }
437 | OP_JGT
'x' ',' label
',' label
{
438 set_jmp_label
($4, JTL
);
439 set_jmp_label
($6, JFL
);
440 set_curr_instr
(BPF_JMP | BPF_JGT | BPF_X
, 0, 0, 0); }
441 | OP_JGT
'#' number
',' label
{
442 set_jmp_label
($5, JTL
);
443 set_curr_instr
(BPF_JMP | BPF_JGT | BPF_K
, 0, 0, $3); }
444 | OP_JGT
'x' ',' label
{
445 set_jmp_label
($4, JTL
);
446 set_curr_instr
(BPF_JMP | BPF_JGT | BPF_X
, 0, 0, 0); }
450 : OP_JGE
'#' number
',' label
',' label
{
451 set_jmp_label
($5, JTL
);
452 set_jmp_label
($7, JFL
);
453 set_curr_instr
(BPF_JMP | BPF_JGE | BPF_K
, 0, 0, $3); }
454 | OP_JGE
'x' ',' label
',' label
{
455 set_jmp_label
($4, JTL
);
456 set_jmp_label
($6, JFL
);
457 set_curr_instr
(BPF_JMP | BPF_JGE | BPF_X
, 0, 0, 0); }
458 | OP_JGE
'#' number
',' label
{
459 set_jmp_label
($5, JTL
);
460 set_curr_instr
(BPF_JMP | BPF_JGE | BPF_K
, 0, 0, $3); }
461 | OP_JGE
'x' ',' label
{
462 set_jmp_label
($4, JTL
);
463 set_curr_instr
(BPF_JMP | BPF_JGE | BPF_X
, 0, 0, 0); }
467 : OP_JSET
'#' number
',' label
',' label
{
468 set_jmp_label
($5, JTL
);
469 set_jmp_label
($7, JFL
);
470 set_curr_instr
(BPF_JMP | BPF_JSET | BPF_K
, 0, 0, $3); }
471 | OP_JSET
'x' ',' label
',' label
{
472 set_jmp_label
($4, JTL
);
473 set_jmp_label
($6, JFL
);
474 set_curr_instr
(BPF_JMP | BPF_JSET | BPF_X
, 0, 0, 0); }
475 | OP_JSET
'#' number
',' label
{
476 set_jmp_label
($5, JTL
);
477 set_curr_instr
(BPF_JMP | BPF_JSET | BPF_K
, 0, 0, $3); }
478 | OP_JSET
'x' ',' label
{
479 set_jmp_label
($4, JTL
);
480 set_curr_instr
(BPF_JMP | BPF_JSET | BPF_X
, 0, 0, 0); }
484 : OP_ADD
'#' number
{
485 set_curr_instr
(BPF_ALU | BPF_ADD | BPF_K
, 0, 0, $3); }
487 set_curr_instr
(BPF_ALU | BPF_ADD | BPF_X
, 0, 0, 0); }
491 : OP_SUB
'#' number
{
492 set_curr_instr
(BPF_ALU | BPF_SUB | BPF_K
, 0, 0, $3); }
494 set_curr_instr
(BPF_ALU | BPF_SUB | BPF_X
, 0, 0, 0); }
498 : OP_MUL
'#' number
{
499 set_curr_instr
(BPF_ALU | BPF_MUL | BPF_K
, 0, 0, $3); }
501 set_curr_instr
(BPF_ALU | BPF_MUL | BPF_X
, 0, 0, 0); }
505 : OP_DIV
'#' number
{
506 set_curr_instr
(BPF_ALU | BPF_DIV | BPF_K
, 0, 0, $3); }
508 set_curr_instr
(BPF_ALU | BPF_DIV | BPF_X
, 0, 0, 0); }
512 : OP_MOD
'#' number
{
513 set_curr_instr
(BPF_ALU | BPF_MOD | BPF_K
, 0, 0, $3); }
515 set_curr_instr
(BPF_ALU | BPF_MOD | BPF_X
, 0, 0, 0); }
520 set_curr_instr
(BPF_ALU | BPF_NEG
, 0, 0, 0); }
524 : OP_AND
'#' number
{
525 set_curr_instr
(BPF_ALU | BPF_AND | BPF_K
, 0, 0, $3); }
527 set_curr_instr
(BPF_ALU | BPF_AND | BPF_X
, 0, 0, 0); }
532 set_curr_instr
(BPF_ALU | BPF_OR | BPF_K
, 0, 0, $3); }
534 set_curr_instr
(BPF_ALU | BPF_OR | BPF_X
, 0, 0, 0); }
538 : OP_XOR
'#' number
{
539 set_curr_instr
(BPF_ALU | BPF_XOR | BPF_K
, 0, 0, $3); }
541 set_curr_instr
(BPF_ALU | BPF_XOR | BPF_X
, 0, 0, 0); }
545 : OP_LSH
'#' number
{
546 set_curr_instr
(BPF_ALU | BPF_LSH | BPF_K
, 0, 0, $3); }
548 set_curr_instr
(BPF_ALU | BPF_LSH | BPF_X
, 0, 0, 0); }
552 : OP_RSH
'#' number
{
553 set_curr_instr
(BPF_ALU | BPF_RSH | BPF_K
, 0, 0, $3); }
555 set_curr_instr
(BPF_ALU | BPF_RSH | BPF_X
, 0, 0, 0); }
560 set_curr_instr
(BPF_RET | BPF_A
, 0, 0, 0); }
562 set_curr_instr
(BPF_RET | BPF_X
, 0, 0, 0); }
563 | OP_RET
'#' number
{
564 set_curr_instr
(BPF_RET | BPF_K
, 0, 0, $3); }
569 set_curr_instr
(BPF_MISC | BPF_TAX
, 0, 0, 0); }
574 set_curr_instr
(BPF_MISC | BPF_TXA
, 0, 0, 0); }
579 static void stage_1_inline
(void)
584 static void stage_2_label_reduce
(void)
586 int i
, max
= curr_instr
, off
;
588 /* 1. reduce k jumps */
589 for
(i
= 0; i
< max
; ++i
) {
590 if
(labels_k
[i
] != NULL
) {
591 off
= find_intr_offset_or_panic
(labels_k
[i
]);
592 out
[i
].k
= (uint32_t) (off
- i
- 1);
596 /* 1. reduce jt jumps */
597 for
(i
= 0; i
< max
; ++i
) {
598 if
(labels_jt
[i
] != NULL
) {
599 off
= find_intr_offset_or_panic
(labels_jt
[i
]);
600 out
[i
].jt
= (uint8_t) (off
- i
-1);
604 /* 1. reduce jf jumps */
605 for
(i
= 0; i
< max
; ++i
) {
606 if
(labels_jf
[i
] != NULL
) {
607 off
= find_intr_offset_or_panic
(labels_jf
[i
]);
608 out
[i
].jf
= (uint8_t) (off
- i
- 1);
613 static void pretty_printer_c
(const struct sock_fprog
*prog
)
617 for
(i
= 0; i
< prog
->len
; ++i
) {
618 printf
("{ 0x%x, %u, %u, 0x%08x },\n",
619 prog
->filter
[i
].code
, prog
->filter
[i
].jt
,
620 prog
->filter
[i
].jf
, prog
->filter
[i
].k
);
624 static void pretty_printer_xt_bpf
(const struct sock_fprog
*prog
)
628 printf
("%d,", prog
->len
);
629 for
(i
= 0; i
< prog
->len
; ++i
) {
630 printf
("%u %u %u %u,",
631 prog
->filter
[i
].code
, prog
->filter
[i
].jt
,
632 prog
->filter
[i
].jf
, prog
->filter
[i
].k
);
638 static void pretty_printer_tcpdump
(const struct sock_fprog
*prog
)
642 for
(i
= 0; i
< prog
->len
; ++i
) {
643 printf
("%u %u %u %u\n",
644 prog
->filter
[i
].code
, prog
->filter
[i
].jt
,
645 prog
->filter
[i
].jf
, prog
->filter
[i
].k
);
649 static void pretty_printer
(const struct sock_fprog
*prog
, int format
)
653 pretty_printer_c
(prog
);
656 pretty_printer_xt_bpf
(prog
);
659 pretty_printer_tcpdump
(prog
);
666 int compile_filter
(char *file
, int verbose
, int bypass
, int format
,
670 struct sock_fprog res
;
673 memset
(tmp_file
, 0, sizeof
(tmp_file
));
676 char cmd
[256], *dir
, *base
, *a
, *b
;
678 dir
= dirname
((a
= xstrdup
(file
)));
679 base
= basename
((b
= xstrdup
(file
)));
681 slprintf
(tmp_file
, sizeof
(tmp_file
), "%s/.tmp-%u-%s", dir
, rand
(), base
);
682 slprintf
(cmd
, sizeof
(cmd
), "cpp -I" PREFIX_STRING
683 "/etc/netsniff-ng/ %s > %s", file
, tmp_file
);
691 if
(!strncmp
("-", file
, strlen
("-")))
694 yyin
= fopen
(file
, "r");
696 panic
("Cannot open file!\n");
698 memset
(out
, 0, sizeof
(out
));
699 memset
(labels
, 0, sizeof
(labels
));
700 memset
(labels_jf
, 0, sizeof
(labels_jf
));
701 memset
(labels_jt
, 0, sizeof
(labels_jt
));
702 memset
(labels_k
, 0, sizeof
(labels_k
));
705 stage_2_label_reduce
();
708 res.len
= curr_instr
;
711 printf
("Generated program:\n");
717 printf
("Validating: ");
721 if
(__bpf_validate
(&res
) == 0) {
723 printf
("Semantic error! BPF validation failed!\n");
725 panic
("Semantic error! BPF validation failed! "
726 "Try -V for debugging output!\n");
727 } else if
(verbose
) {
728 printf
("is runnable!\n");
735 pretty_printer
(&res
, format
);
737 for
(i
= 0; i
< res.len
; ++i
) {
751 void yyerror(const char *err
)
753 panic
("Syntax error at line %d: %s! %s!\n",
754 yylineno
, yytext
, err
);