xref: /linux/lib/test_bpf.c (revision b24413180f5600bcb3bb70fbed5cf186b60864bd)
1 /*
2  * Testsuite for BPF interpreter and BPF JIT compiler
3  *
4  * Copyright (c) 2011-2014 PLUMgrid, http://plumgrid.com
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of version 2 of the GNU General Public
8  * License as published by the Free Software Foundation.
9  *
10  * This program is distributed in the hope that it will be useful, but
11  * WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13  * General Public License for more details.
14  */
15 
16 #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
17 
18 #include <linux/init.h>
19 #include <linux/module.h>
20 #include <linux/filter.h>
21 #include <linux/bpf.h>
22 #include <linux/skbuff.h>
23 #include <linux/netdevice.h>
24 #include <linux/if_vlan.h>
25 #include <linux/random.h>
26 #include <linux/highmem.h>
27 
28 /* General test specific settings */
29 #define MAX_SUBTESTS	3
30 #define MAX_TESTRUNS	10000
31 #define MAX_DATA	128
32 #define MAX_INSNS	512
33 #define MAX_K		0xffffFFFF
34 
35 /* Few constants used to init test 'skb' */
36 #define SKB_TYPE	3
37 #define SKB_MARK	0x1234aaaa
38 #define SKB_HASH	0x1234aaab
39 #define SKB_QUEUE_MAP	123
40 #define SKB_VLAN_TCI	0xffff
41 #define SKB_DEV_IFINDEX	577
42 #define SKB_DEV_TYPE	588
43 
44 /* Redefine REGs to make tests less verbose */
45 #define R0		BPF_REG_0
46 #define R1		BPF_REG_1
47 #define R2		BPF_REG_2
48 #define R3		BPF_REG_3
49 #define R4		BPF_REG_4
50 #define R5		BPF_REG_5
51 #define R6		BPF_REG_6
52 #define R7		BPF_REG_7
53 #define R8		BPF_REG_8
54 #define R9		BPF_REG_9
55 #define R10		BPF_REG_10
56 
57 /* Flags that can be passed to test cases */
58 #define FLAG_NO_DATA		BIT(0)
59 #define FLAG_EXPECTED_FAIL	BIT(1)
60 #define FLAG_SKB_FRAG		BIT(2)
61 
62 enum {
63 	CLASSIC  = BIT(6),	/* Old BPF instructions only. */
64 	INTERNAL = BIT(7),	/* Extended instruction set.  */
65 };
66 
67 #define TEST_TYPE_MASK		(CLASSIC | INTERNAL)
68 
69 struct bpf_test {
70 	const char *descr;
71 	union {
72 		struct sock_filter insns[MAX_INSNS];
73 		struct bpf_insn insns_int[MAX_INSNS];
74 		struct {
75 			void *insns;
76 			unsigned int len;
77 		} ptr;
78 	} u;
79 	__u8 aux;
80 	__u8 data[MAX_DATA];
81 	struct {
82 		int data_size;
83 		__u32 result;
84 	} test[MAX_SUBTESTS];
85 	int (*fill_helper)(struct bpf_test *self);
86 	__u8 frag_data[MAX_DATA];
87 	int stack_depth; /* for eBPF only, since tests don't call verifier */
88 };
89 
90 /* Large test cases need separate allocation and fill handler. */
91 
92 static int bpf_fill_maxinsns1(struct bpf_test *self)
93 {
94 	unsigned int len = BPF_MAXINSNS;
95 	struct sock_filter *insn;
96 	__u32 k = ~0;
97 	int i;
98 
99 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
100 	if (!insn)
101 		return -ENOMEM;
102 
103 	for (i = 0; i < len; i++, k--)
104 		insn[i] = __BPF_STMT(BPF_RET | BPF_K, k);
105 
106 	self->u.ptr.insns = insn;
107 	self->u.ptr.len = len;
108 
109 	return 0;
110 }
111 
112 static int bpf_fill_maxinsns2(struct bpf_test *self)
113 {
114 	unsigned int len = BPF_MAXINSNS;
115 	struct sock_filter *insn;
116 	int i;
117 
118 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
119 	if (!insn)
120 		return -ENOMEM;
121 
122 	for (i = 0; i < len; i++)
123 		insn[i] = __BPF_STMT(BPF_RET | BPF_K, 0xfefefefe);
124 
125 	self->u.ptr.insns = insn;
126 	self->u.ptr.len = len;
127 
128 	return 0;
129 }
130 
131 static int bpf_fill_maxinsns3(struct bpf_test *self)
132 {
133 	unsigned int len = BPF_MAXINSNS;
134 	struct sock_filter *insn;
135 	struct rnd_state rnd;
136 	int i;
137 
138 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
139 	if (!insn)
140 		return -ENOMEM;
141 
142 	prandom_seed_state(&rnd, 3141592653589793238ULL);
143 
144 	for (i = 0; i < len - 1; i++) {
145 		__u32 k = prandom_u32_state(&rnd);
146 
147 		insn[i] = __BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, k);
148 	}
149 
150 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_A, 0);
151 
152 	self->u.ptr.insns = insn;
153 	self->u.ptr.len = len;
154 
155 	return 0;
156 }
157 
158 static int bpf_fill_maxinsns4(struct bpf_test *self)
159 {
160 	unsigned int len = BPF_MAXINSNS + 1;
161 	struct sock_filter *insn;
162 	int i;
163 
164 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
165 	if (!insn)
166 		return -ENOMEM;
167 
168 	for (i = 0; i < len; i++)
169 		insn[i] = __BPF_STMT(BPF_RET | BPF_K, 0xfefefefe);
170 
171 	self->u.ptr.insns = insn;
172 	self->u.ptr.len = len;
173 
174 	return 0;
175 }
176 
177 static int bpf_fill_maxinsns5(struct bpf_test *self)
178 {
179 	unsigned int len = BPF_MAXINSNS;
180 	struct sock_filter *insn;
181 	int i;
182 
183 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
184 	if (!insn)
185 		return -ENOMEM;
186 
187 	insn[0] = __BPF_JUMP(BPF_JMP | BPF_JA, len - 2, 0, 0);
188 
189 	for (i = 1; i < len - 1; i++)
190 		insn[i] = __BPF_STMT(BPF_RET | BPF_K, 0xfefefefe);
191 
192 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_K, 0xabababab);
193 
194 	self->u.ptr.insns = insn;
195 	self->u.ptr.len = len;
196 
197 	return 0;
198 }
199 
200 static int bpf_fill_maxinsns6(struct bpf_test *self)
201 {
202 	unsigned int len = BPF_MAXINSNS;
203 	struct sock_filter *insn;
204 	int i;
205 
206 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
207 	if (!insn)
208 		return -ENOMEM;
209 
210 	for (i = 0; i < len - 1; i++)
211 		insn[i] = __BPF_STMT(BPF_LD | BPF_W | BPF_ABS, SKF_AD_OFF +
212 				     SKF_AD_VLAN_TAG_PRESENT);
213 
214 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_A, 0);
215 
216 	self->u.ptr.insns = insn;
217 	self->u.ptr.len = len;
218 
219 	return 0;
220 }
221 
222 static int bpf_fill_maxinsns7(struct bpf_test *self)
223 {
224 	unsigned int len = BPF_MAXINSNS;
225 	struct sock_filter *insn;
226 	int i;
227 
228 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
229 	if (!insn)
230 		return -ENOMEM;
231 
232 	for (i = 0; i < len - 4; i++)
233 		insn[i] = __BPF_STMT(BPF_LD | BPF_W | BPF_ABS, SKF_AD_OFF +
234 				     SKF_AD_CPU);
235 
236 	insn[len - 4] = __BPF_STMT(BPF_MISC | BPF_TAX, 0);
237 	insn[len - 3] = __BPF_STMT(BPF_LD | BPF_W | BPF_ABS, SKF_AD_OFF +
238 				   SKF_AD_CPU);
239 	insn[len - 2] = __BPF_STMT(BPF_ALU | BPF_SUB | BPF_X, 0);
240 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_A, 0);
241 
242 	self->u.ptr.insns = insn;
243 	self->u.ptr.len = len;
244 
245 	return 0;
246 }
247 
248 static int bpf_fill_maxinsns8(struct bpf_test *self)
249 {
250 	unsigned int len = BPF_MAXINSNS;
251 	struct sock_filter *insn;
252 	int i, jmp_off = len - 3;
253 
254 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
255 	if (!insn)
256 		return -ENOMEM;
257 
258 	insn[0] = __BPF_STMT(BPF_LD | BPF_IMM, 0xffffffff);
259 
260 	for (i = 1; i < len - 1; i++)
261 		insn[i] = __BPF_JUMP(BPF_JMP | BPF_JGT, 0xffffffff, jmp_off--, 0);
262 
263 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_A, 0);
264 
265 	self->u.ptr.insns = insn;
266 	self->u.ptr.len = len;
267 
268 	return 0;
269 }
270 
271 static int bpf_fill_maxinsns9(struct bpf_test *self)
272 {
273 	unsigned int len = BPF_MAXINSNS;
274 	struct bpf_insn *insn;
275 	int i;
276 
277 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
278 	if (!insn)
279 		return -ENOMEM;
280 
281 	insn[0] = BPF_JMP_IMM(BPF_JA, 0, 0, len - 2);
282 	insn[1] = BPF_ALU32_IMM(BPF_MOV, R0, 0xcbababab);
283 	insn[2] = BPF_EXIT_INSN();
284 
285 	for (i = 3; i < len - 2; i++)
286 		insn[i] = BPF_ALU32_IMM(BPF_MOV, R0, 0xfefefefe);
287 
288 	insn[len - 2] = BPF_EXIT_INSN();
289 	insn[len - 1] = BPF_JMP_IMM(BPF_JA, 0, 0, -(len - 1));
290 
291 	self->u.ptr.insns = insn;
292 	self->u.ptr.len = len;
293 
294 	return 0;
295 }
296 
297 static int bpf_fill_maxinsns10(struct bpf_test *self)
298 {
299 	unsigned int len = BPF_MAXINSNS, hlen = len - 2;
300 	struct bpf_insn *insn;
301 	int i;
302 
303 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
304 	if (!insn)
305 		return -ENOMEM;
306 
307 	for (i = 0; i < hlen / 2; i++)
308 		insn[i] = BPF_JMP_IMM(BPF_JA, 0, 0, hlen - 2 - 2 * i);
309 	for (i = hlen - 1; i > hlen / 2; i--)
310 		insn[i] = BPF_JMP_IMM(BPF_JA, 0, 0, hlen - 1 - 2 * i);
311 
312 	insn[hlen / 2] = BPF_JMP_IMM(BPF_JA, 0, 0, hlen / 2 - 1);
313 	insn[hlen]     = BPF_ALU32_IMM(BPF_MOV, R0, 0xabababac);
314 	insn[hlen + 1] = BPF_EXIT_INSN();
315 
316 	self->u.ptr.insns = insn;
317 	self->u.ptr.len = len;
318 
319 	return 0;
320 }
321 
322 static int __bpf_fill_ja(struct bpf_test *self, unsigned int len,
323 			 unsigned int plen)
324 {
325 	struct sock_filter *insn;
326 	unsigned int rlen;
327 	int i, j;
328 
329 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
330 	if (!insn)
331 		return -ENOMEM;
332 
333 	rlen = (len % plen) - 1;
334 
335 	for (i = 0; i + plen < len; i += plen)
336 		for (j = 0; j < plen; j++)
337 			insn[i + j] = __BPF_JUMP(BPF_JMP | BPF_JA,
338 						 plen - 1 - j, 0, 0);
339 	for (j = 0; j < rlen; j++)
340 		insn[i + j] = __BPF_JUMP(BPF_JMP | BPF_JA, rlen - 1 - j,
341 					 0, 0);
342 
343 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_K, 0xababcbac);
344 
345 	self->u.ptr.insns = insn;
346 	self->u.ptr.len = len;
347 
348 	return 0;
349 }
350 
351 static int bpf_fill_maxinsns11(struct bpf_test *self)
352 {
353 	/* Hits 70 passes on x86_64, so cannot get JITed there. */
354 	return __bpf_fill_ja(self, BPF_MAXINSNS, 68);
355 }
356 
357 static int bpf_fill_ja(struct bpf_test *self)
358 {
359 	/* Hits exactly 11 passes on x86_64 JIT. */
360 	return __bpf_fill_ja(self, 12, 9);
361 }
362 
363 static int bpf_fill_ld_abs_get_processor_id(struct bpf_test *self)
364 {
365 	unsigned int len = BPF_MAXINSNS;
366 	struct sock_filter *insn;
367 	int i;
368 
369 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
370 	if (!insn)
371 		return -ENOMEM;
372 
373 	for (i = 0; i < len - 1; i += 2) {
374 		insn[i] = __BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 0);
375 		insn[i + 1] = __BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
376 					 SKF_AD_OFF + SKF_AD_CPU);
377 	}
378 
379 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_K, 0xbee);
380 
381 	self->u.ptr.insns = insn;
382 	self->u.ptr.len = len;
383 
384 	return 0;
385 }
386 
387 #define PUSH_CNT 68
388 /* test: {skb->data[0], vlan_push} x 68 + {skb->data[0], vlan_pop} x 68 */
389 static int bpf_fill_ld_abs_vlan_push_pop(struct bpf_test *self)
390 {
391 	unsigned int len = BPF_MAXINSNS;
392 	struct bpf_insn *insn;
393 	int i = 0, j, k = 0;
394 
395 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
396 	if (!insn)
397 		return -ENOMEM;
398 
399 	insn[i++] = BPF_MOV64_REG(R6, R1);
400 loop:
401 	for (j = 0; j < PUSH_CNT; j++) {
402 		insn[i++] = BPF_LD_ABS(BPF_B, 0);
403 		insn[i] = BPF_JMP_IMM(BPF_JNE, R0, 0x34, len - i - 2);
404 		i++;
405 		insn[i++] = BPF_MOV64_REG(R1, R6);
406 		insn[i++] = BPF_MOV64_IMM(R2, 1);
407 		insn[i++] = BPF_MOV64_IMM(R3, 2);
408 		insn[i++] = BPF_RAW_INSN(BPF_JMP | BPF_CALL, 0, 0, 0,
409 					 bpf_skb_vlan_push_proto.func - __bpf_call_base);
410 		insn[i] = BPF_JMP_IMM(BPF_JNE, R0, 0, len - i - 2);
411 		i++;
412 	}
413 
414 	for (j = 0; j < PUSH_CNT; j++) {
415 		insn[i++] = BPF_LD_ABS(BPF_B, 0);
416 		insn[i] = BPF_JMP_IMM(BPF_JNE, R0, 0x34, len - i - 2);
417 		i++;
418 		insn[i++] = BPF_MOV64_REG(R1, R6);
419 		insn[i++] = BPF_RAW_INSN(BPF_JMP | BPF_CALL, 0, 0, 0,
420 					 bpf_skb_vlan_pop_proto.func - __bpf_call_base);
421 		insn[i] = BPF_JMP_IMM(BPF_JNE, R0, 0, len - i - 2);
422 		i++;
423 	}
424 	if (++k < 5)
425 		goto loop;
426 
427 	for (; i < len - 1; i++)
428 		insn[i] = BPF_ALU32_IMM(BPF_MOV, R0, 0xbef);
429 
430 	insn[len - 1] = BPF_EXIT_INSN();
431 
432 	self->u.ptr.insns = insn;
433 	self->u.ptr.len = len;
434 
435 	return 0;
436 }
437 
438 static int bpf_fill_jump_around_ld_abs(struct bpf_test *self)
439 {
440 	unsigned int len = BPF_MAXINSNS;
441 	struct bpf_insn *insn;
442 	int i = 0;
443 
444 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
445 	if (!insn)
446 		return -ENOMEM;
447 
448 	insn[i++] = BPF_MOV64_REG(R6, R1);
449 	insn[i++] = BPF_LD_ABS(BPF_B, 0);
450 	insn[i] = BPF_JMP_IMM(BPF_JEQ, R0, 10, len - i - 2);
451 	i++;
452 	while (i < len - 1)
453 		insn[i++] = BPF_LD_ABS(BPF_B, 1);
454 	insn[i] = BPF_EXIT_INSN();
455 
456 	self->u.ptr.insns = insn;
457 	self->u.ptr.len = len;
458 
459 	return 0;
460 }
461 
462 static int __bpf_fill_stxdw(struct bpf_test *self, int size)
463 {
464 	unsigned int len = BPF_MAXINSNS;
465 	struct bpf_insn *insn;
466 	int i;
467 
468 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
469 	if (!insn)
470 		return -ENOMEM;
471 
472 	insn[0] = BPF_ALU32_IMM(BPF_MOV, R0, 1);
473 	insn[1] = BPF_ST_MEM(size, R10, -40, 42);
474 
475 	for (i = 2; i < len - 2; i++)
476 		insn[i] = BPF_STX_XADD(size, R10, R0, -40);
477 
478 	insn[len - 2] = BPF_LDX_MEM(size, R0, R10, -40);
479 	insn[len - 1] = BPF_EXIT_INSN();
480 
481 	self->u.ptr.insns = insn;
482 	self->u.ptr.len = len;
483 	self->stack_depth = 40;
484 
485 	return 0;
486 }
487 
488 static int bpf_fill_stxw(struct bpf_test *self)
489 {
490 	return __bpf_fill_stxdw(self, BPF_W);
491 }
492 
493 static int bpf_fill_stxdw(struct bpf_test *self)
494 {
495 	return __bpf_fill_stxdw(self, BPF_DW);
496 }
497 
498 static struct bpf_test tests[] = {
499 	{
500 		"TAX",
501 		.u.insns = {
502 			BPF_STMT(BPF_LD | BPF_IMM, 1),
503 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
504 			BPF_STMT(BPF_LD | BPF_IMM, 2),
505 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
506 			BPF_STMT(BPF_ALU | BPF_NEG, 0), /* A == -3 */
507 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
508 			BPF_STMT(BPF_LD | BPF_LEN, 0),
509 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
510 			BPF_STMT(BPF_MISC | BPF_TAX, 0), /* X == len - 3 */
511 			BPF_STMT(BPF_LD | BPF_B | BPF_IND, 1),
512 			BPF_STMT(BPF_RET | BPF_A, 0)
513 		},
514 		CLASSIC,
515 		{ 10, 20, 30, 40, 50 },
516 		{ { 2, 10 }, { 3, 20 }, { 4, 30 } },
517 	},
518 	{
519 		"TXA",
520 		.u.insns = {
521 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
522 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
523 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
524 			BPF_STMT(BPF_RET | BPF_A, 0) /* A == len * 2 */
525 		},
526 		CLASSIC,
527 		{ 10, 20, 30, 40, 50 },
528 		{ { 1, 2 }, { 3, 6 }, { 4, 8 } },
529 	},
530 	{
531 		"ADD_SUB_MUL_K",
532 		.u.insns = {
533 			BPF_STMT(BPF_LD | BPF_IMM, 1),
534 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 2),
535 			BPF_STMT(BPF_LDX | BPF_IMM, 3),
536 			BPF_STMT(BPF_ALU | BPF_SUB | BPF_X, 0),
537 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 0xffffffff),
538 			BPF_STMT(BPF_ALU | BPF_MUL | BPF_K, 3),
539 			BPF_STMT(BPF_RET | BPF_A, 0)
540 		},
541 		CLASSIC | FLAG_NO_DATA,
542 		{ },
543 		{ { 0, 0xfffffffd } }
544 	},
545 	{
546 		"DIV_MOD_KX",
547 		.u.insns = {
548 			BPF_STMT(BPF_LD | BPF_IMM, 8),
549 			BPF_STMT(BPF_ALU | BPF_DIV | BPF_K, 2),
550 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
551 			BPF_STMT(BPF_LD | BPF_IMM, 0xffffffff),
552 			BPF_STMT(BPF_ALU | BPF_DIV | BPF_X, 0),
553 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
554 			BPF_STMT(BPF_LD | BPF_IMM, 0xffffffff),
555 			BPF_STMT(BPF_ALU | BPF_DIV | BPF_K, 0x70000000),
556 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
557 			BPF_STMT(BPF_LD | BPF_IMM, 0xffffffff),
558 			BPF_STMT(BPF_ALU | BPF_MOD | BPF_X, 0),
559 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
560 			BPF_STMT(BPF_LD | BPF_IMM, 0xffffffff),
561 			BPF_STMT(BPF_ALU | BPF_MOD | BPF_K, 0x70000000),
562 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
563 			BPF_STMT(BPF_RET | BPF_A, 0)
564 		},
565 		CLASSIC | FLAG_NO_DATA,
566 		{ },
567 		{ { 0, 0x20000000 } }
568 	},
569 	{
570 		"AND_OR_LSH_K",
571 		.u.insns = {
572 			BPF_STMT(BPF_LD | BPF_IMM, 0xff),
573 			BPF_STMT(BPF_ALU | BPF_AND | BPF_K, 0xf0),
574 			BPF_STMT(BPF_ALU | BPF_LSH | BPF_K, 27),
575 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
576 			BPF_STMT(BPF_LD | BPF_IMM, 0xf),
577 			BPF_STMT(BPF_ALU | BPF_OR | BPF_K, 0xf0),
578 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
579 			BPF_STMT(BPF_RET | BPF_A, 0)
580 		},
581 		CLASSIC | FLAG_NO_DATA,
582 		{ },
583 		{ { 0, 0x800000ff }, { 1, 0x800000ff } },
584 	},
585 	{
586 		"LD_IMM_0",
587 		.u.insns = {
588 			BPF_STMT(BPF_LD | BPF_IMM, 0), /* ld #0 */
589 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0, 1, 0),
590 			BPF_STMT(BPF_RET | BPF_K, 0),
591 			BPF_STMT(BPF_RET | BPF_K, 1),
592 		},
593 		CLASSIC,
594 		{ },
595 		{ { 1, 1 } },
596 	},
597 	{
598 		"LD_IND",
599 		.u.insns = {
600 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
601 			BPF_STMT(BPF_LD | BPF_H | BPF_IND, MAX_K),
602 			BPF_STMT(BPF_RET | BPF_K, 1)
603 		},
604 		CLASSIC,
605 		{ },
606 		{ { 1, 0 }, { 10, 0 }, { 60, 0 } },
607 	},
608 	{
609 		"LD_ABS",
610 		.u.insns = {
611 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS, 1000),
612 			BPF_STMT(BPF_RET | BPF_K, 1)
613 		},
614 		CLASSIC,
615 		{ },
616 		{ { 1, 0 }, { 10, 0 }, { 60, 0 } },
617 	},
618 	{
619 		"LD_ABS_LL",
620 		.u.insns = {
621 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, SKF_LL_OFF),
622 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
623 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, SKF_LL_OFF + 1),
624 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
625 			BPF_STMT(BPF_RET | BPF_A, 0)
626 		},
627 		CLASSIC,
628 		{ 1, 2, 3 },
629 		{ { 1, 0 }, { 2, 3 } },
630 	},
631 	{
632 		"LD_IND_LL",
633 		.u.insns = {
634 			BPF_STMT(BPF_LD | BPF_IMM, SKF_LL_OFF - 1),
635 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
636 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
637 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
638 			BPF_STMT(BPF_LD | BPF_B | BPF_IND, 0),
639 			BPF_STMT(BPF_RET | BPF_A, 0)
640 		},
641 		CLASSIC,
642 		{ 1, 2, 3, 0xff },
643 		{ { 1, 1 }, { 3, 3 }, { 4, 0xff } },
644 	},
645 	{
646 		"LD_ABS_NET",
647 		.u.insns = {
648 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, SKF_NET_OFF),
649 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
650 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, SKF_NET_OFF + 1),
651 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
652 			BPF_STMT(BPF_RET | BPF_A, 0)
653 		},
654 		CLASSIC,
655 		{ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3 },
656 		{ { 15, 0 }, { 16, 3 } },
657 	},
658 	{
659 		"LD_IND_NET",
660 		.u.insns = {
661 			BPF_STMT(BPF_LD | BPF_IMM, SKF_NET_OFF - 15),
662 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
663 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
664 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
665 			BPF_STMT(BPF_LD | BPF_B | BPF_IND, 0),
666 			BPF_STMT(BPF_RET | BPF_A, 0)
667 		},
668 		CLASSIC,
669 		{ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3 },
670 		{ { 14, 0 }, { 15, 1 }, { 17, 3 } },
671 	},
672 	{
673 		"LD_PKTTYPE",
674 		.u.insns = {
675 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
676 				 SKF_AD_OFF + SKF_AD_PKTTYPE),
677 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, SKB_TYPE, 1, 0),
678 			BPF_STMT(BPF_RET | BPF_K, 1),
679 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
680 				 SKF_AD_OFF + SKF_AD_PKTTYPE),
681 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, SKB_TYPE, 1, 0),
682 			BPF_STMT(BPF_RET | BPF_K, 1),
683 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
684 				 SKF_AD_OFF + SKF_AD_PKTTYPE),
685 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, SKB_TYPE, 1, 0),
686 			BPF_STMT(BPF_RET | BPF_K, 1),
687 			BPF_STMT(BPF_RET | BPF_A, 0)
688 		},
689 		CLASSIC,
690 		{ },
691 		{ { 1, 3 }, { 10, 3 } },
692 	},
693 	{
694 		"LD_MARK",
695 		.u.insns = {
696 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
697 				 SKF_AD_OFF + SKF_AD_MARK),
698 			BPF_STMT(BPF_RET | BPF_A, 0)
699 		},
700 		CLASSIC,
701 		{ },
702 		{ { 1, SKB_MARK}, { 10, SKB_MARK} },
703 	},
704 	{
705 		"LD_RXHASH",
706 		.u.insns = {
707 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
708 				 SKF_AD_OFF + SKF_AD_RXHASH),
709 			BPF_STMT(BPF_RET | BPF_A, 0)
710 		},
711 		CLASSIC,
712 		{ },
713 		{ { 1, SKB_HASH}, { 10, SKB_HASH} },
714 	},
715 	{
716 		"LD_QUEUE",
717 		.u.insns = {
718 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
719 				 SKF_AD_OFF + SKF_AD_QUEUE),
720 			BPF_STMT(BPF_RET | BPF_A, 0)
721 		},
722 		CLASSIC,
723 		{ },
724 		{ { 1, SKB_QUEUE_MAP }, { 10, SKB_QUEUE_MAP } },
725 	},
726 	{
727 		"LD_PROTOCOL",
728 		.u.insns = {
729 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 1),
730 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 20, 1, 0),
731 			BPF_STMT(BPF_RET | BPF_K, 0),
732 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
733 				 SKF_AD_OFF + SKF_AD_PROTOCOL),
734 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
735 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 2),
736 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 30, 1, 0),
737 			BPF_STMT(BPF_RET | BPF_K, 0),
738 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
739 			BPF_STMT(BPF_RET | BPF_A, 0)
740 		},
741 		CLASSIC,
742 		{ 10, 20, 30 },
743 		{ { 10, ETH_P_IP }, { 100, ETH_P_IP } },
744 	},
745 	{
746 		"LD_VLAN_TAG",
747 		.u.insns = {
748 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
749 				 SKF_AD_OFF + SKF_AD_VLAN_TAG),
750 			BPF_STMT(BPF_RET | BPF_A, 0)
751 		},
752 		CLASSIC,
753 		{ },
754 		{
755 			{ 1, SKB_VLAN_TCI & ~VLAN_TAG_PRESENT },
756 			{ 10, SKB_VLAN_TCI & ~VLAN_TAG_PRESENT }
757 		},
758 	},
759 	{
760 		"LD_VLAN_TAG_PRESENT",
761 		.u.insns = {
762 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
763 				 SKF_AD_OFF + SKF_AD_VLAN_TAG_PRESENT),
764 			BPF_STMT(BPF_RET | BPF_A, 0)
765 		},
766 		CLASSIC,
767 		{ },
768 		{
769 			{ 1, !!(SKB_VLAN_TCI & VLAN_TAG_PRESENT) },
770 			{ 10, !!(SKB_VLAN_TCI & VLAN_TAG_PRESENT) }
771 		},
772 	},
773 	{
774 		"LD_IFINDEX",
775 		.u.insns = {
776 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
777 				 SKF_AD_OFF + SKF_AD_IFINDEX),
778 			BPF_STMT(BPF_RET | BPF_A, 0)
779 		},
780 		CLASSIC,
781 		{ },
782 		{ { 1, SKB_DEV_IFINDEX }, { 10, SKB_DEV_IFINDEX } },
783 	},
784 	{
785 		"LD_HATYPE",
786 		.u.insns = {
787 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
788 				 SKF_AD_OFF + SKF_AD_HATYPE),
789 			BPF_STMT(BPF_RET | BPF_A, 0)
790 		},
791 		CLASSIC,
792 		{ },
793 		{ { 1, SKB_DEV_TYPE }, { 10, SKB_DEV_TYPE } },
794 	},
795 	{
796 		"LD_CPU",
797 		.u.insns = {
798 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
799 				 SKF_AD_OFF + SKF_AD_CPU),
800 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
801 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
802 				 SKF_AD_OFF + SKF_AD_CPU),
803 			BPF_STMT(BPF_ALU | BPF_SUB | BPF_X, 0),
804 			BPF_STMT(BPF_RET | BPF_A, 0)
805 		},
806 		CLASSIC,
807 		{ },
808 		{ { 1, 0 }, { 10, 0 } },
809 	},
810 	{
811 		"LD_NLATTR",
812 		.u.insns = {
813 			BPF_STMT(BPF_LDX | BPF_IMM, 2),
814 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
815 			BPF_STMT(BPF_LDX | BPF_IMM, 3),
816 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
817 				 SKF_AD_OFF + SKF_AD_NLATTR),
818 			BPF_STMT(BPF_RET | BPF_A, 0)
819 		},
820 		CLASSIC,
821 #ifdef __BIG_ENDIAN
822 		{ 0xff, 0xff, 0, 4, 0, 2, 0, 4, 0, 3 },
823 #else
824 		{ 0xff, 0xff, 4, 0, 2, 0, 4, 0, 3, 0 },
825 #endif
826 		{ { 4, 0 }, { 20, 6 } },
827 	},
828 	{
829 		"LD_NLATTR_NEST",
830 		.u.insns = {
831 			BPF_STMT(BPF_LD | BPF_IMM, 2),
832 			BPF_STMT(BPF_LDX | BPF_IMM, 3),
833 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
834 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
835 			BPF_STMT(BPF_LD | BPF_IMM, 2),
836 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
837 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
838 			BPF_STMT(BPF_LD | BPF_IMM, 2),
839 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
840 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
841 			BPF_STMT(BPF_LD | BPF_IMM, 2),
842 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
843 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
844 			BPF_STMT(BPF_LD | BPF_IMM, 2),
845 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
846 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
847 			BPF_STMT(BPF_LD | BPF_IMM, 2),
848 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
849 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
850 			BPF_STMT(BPF_LD | BPF_IMM, 2),
851 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
852 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
853 			BPF_STMT(BPF_LD | BPF_IMM, 2),
854 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
855 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
856 			BPF_STMT(BPF_RET | BPF_A, 0)
857 		},
858 		CLASSIC,
859 #ifdef __BIG_ENDIAN
860 		{ 0xff, 0xff, 0, 12, 0, 1, 0, 4, 0, 2, 0, 4, 0, 3 },
861 #else
862 		{ 0xff, 0xff, 12, 0, 1, 0, 4, 0, 2, 0, 4, 0, 3, 0 },
863 #endif
864 		{ { 4, 0 }, { 20, 10 } },
865 	},
866 	{
867 		"LD_PAYLOAD_OFF",
868 		.u.insns = {
869 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
870 				 SKF_AD_OFF + SKF_AD_PAY_OFFSET),
871 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
872 				 SKF_AD_OFF + SKF_AD_PAY_OFFSET),
873 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
874 				 SKF_AD_OFF + SKF_AD_PAY_OFFSET),
875 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
876 				 SKF_AD_OFF + SKF_AD_PAY_OFFSET),
877 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
878 				 SKF_AD_OFF + SKF_AD_PAY_OFFSET),
879 			BPF_STMT(BPF_RET | BPF_A, 0)
880 		},
881 		CLASSIC,
882 		/* 00:00:00:00:00:00 > 00:00:00:00:00:00, ethtype IPv4 (0x0800),
883 		 * length 98: 127.0.0.1 > 127.0.0.1: ICMP echo request,
884 		 * id 9737, seq 1, length 64
885 		 */
886 		{ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
887 		  0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
888 		  0x08, 0x00,
889 		  0x45, 0x00, 0x00, 0x54, 0xac, 0x8b, 0x40, 0x00, 0x40,
890 		  0x01, 0x90, 0x1b, 0x7f, 0x00, 0x00, 0x01 },
891 		{ { 30, 0 }, { 100, 42 } },
892 	},
893 	{
894 		"LD_ANC_XOR",
895 		.u.insns = {
896 			BPF_STMT(BPF_LD | BPF_IMM, 10),
897 			BPF_STMT(BPF_LDX | BPF_IMM, 300),
898 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
899 				 SKF_AD_OFF + SKF_AD_ALU_XOR_X),
900 			BPF_STMT(BPF_RET | BPF_A, 0)
901 		},
902 		CLASSIC,
903 		{ },
904 		{ { 4, 10 ^ 300 }, { 20, 10 ^ 300 } },
905 	},
906 	{
907 		"SPILL_FILL",
908 		.u.insns = {
909 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
910 			BPF_STMT(BPF_LD | BPF_IMM, 2),
911 			BPF_STMT(BPF_ALU | BPF_RSH, 1),
912 			BPF_STMT(BPF_ALU | BPF_XOR | BPF_X, 0),
913 			BPF_STMT(BPF_ST, 1), /* M1 = 1 ^ len */
914 			BPF_STMT(BPF_ALU | BPF_XOR | BPF_K, 0x80000000),
915 			BPF_STMT(BPF_ST, 2), /* M2 = 1 ^ len ^ 0x80000000 */
916 			BPF_STMT(BPF_STX, 15), /* M3 = len */
917 			BPF_STMT(BPF_LDX | BPF_MEM, 1),
918 			BPF_STMT(BPF_LD | BPF_MEM, 2),
919 			BPF_STMT(BPF_ALU | BPF_XOR | BPF_X, 0),
920 			BPF_STMT(BPF_LDX | BPF_MEM, 15),
921 			BPF_STMT(BPF_ALU | BPF_XOR | BPF_X, 0),
922 			BPF_STMT(BPF_RET | BPF_A, 0)
923 		},
924 		CLASSIC,
925 		{ },
926 		{ { 1, 0x80000001 }, { 2, 0x80000002 }, { 60, 0x80000000 ^ 60 } }
927 	},
928 	{
929 		"JEQ",
930 		.u.insns = {
931 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
932 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 2),
933 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_X, 0, 0, 1),
934 			BPF_STMT(BPF_RET | BPF_K, 1),
935 			BPF_STMT(BPF_RET | BPF_K, MAX_K)
936 		},
937 		CLASSIC,
938 		{ 3, 3, 3, 3, 3 },
939 		{ { 1, 0 }, { 3, 1 }, { 4, MAX_K } },
940 	},
941 	{
942 		"JGT",
943 		.u.insns = {
944 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
945 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 2),
946 			BPF_JUMP(BPF_JMP | BPF_JGT | BPF_X, 0, 0, 1),
947 			BPF_STMT(BPF_RET | BPF_K, 1),
948 			BPF_STMT(BPF_RET | BPF_K, MAX_K)
949 		},
950 		CLASSIC,
951 		{ 4, 4, 4, 3, 3 },
952 		{ { 2, 0 }, { 3, 1 }, { 4, MAX_K } },
953 	},
954 	{
955 		"JGE (jt 0), test 1",
956 		.u.insns = {
957 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
958 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 2),
959 			BPF_JUMP(BPF_JMP | BPF_JGE | BPF_X, 0, 0, 1),
960 			BPF_STMT(BPF_RET | BPF_K, 1),
961 			BPF_STMT(BPF_RET | BPF_K, MAX_K)
962 		},
963 		CLASSIC,
964 		{ 4, 4, 4, 3, 3 },
965 		{ { 2, 0 }, { 3, 1 }, { 4, 1 } },
966 	},
967 	{
968 		"JGE (jt 0), test 2",
969 		.u.insns = {
970 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
971 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 2),
972 			BPF_JUMP(BPF_JMP | BPF_JGE | BPF_X, 0, 0, 1),
973 			BPF_STMT(BPF_RET | BPF_K, 1),
974 			BPF_STMT(BPF_RET | BPF_K, MAX_K)
975 		},
976 		CLASSIC,
977 		{ 4, 4, 5, 3, 3 },
978 		{ { 4, 1 }, { 5, 1 }, { 6, MAX_K } },
979 	},
980 	{
981 		"JGE",
982 		.u.insns = {
983 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
984 			BPF_STMT(BPF_LD | BPF_B | BPF_IND, MAX_K),
985 			BPF_JUMP(BPF_JMP | BPF_JGE | BPF_K, 1, 1, 0),
986 			BPF_STMT(BPF_RET | BPF_K, 10),
987 			BPF_JUMP(BPF_JMP | BPF_JGE | BPF_K, 2, 1, 0),
988 			BPF_STMT(BPF_RET | BPF_K, 20),
989 			BPF_JUMP(BPF_JMP | BPF_JGE | BPF_K, 3, 1, 0),
990 			BPF_STMT(BPF_RET | BPF_K, 30),
991 			BPF_JUMP(BPF_JMP | BPF_JGE | BPF_K, 4, 1, 0),
992 			BPF_STMT(BPF_RET | BPF_K, 40),
993 			BPF_STMT(BPF_RET | BPF_K, MAX_K)
994 		},
995 		CLASSIC,
996 		{ 1, 2, 3, 4, 5 },
997 		{ { 1, 20 }, { 3, 40 }, { 5, MAX_K } },
998 	},
999 	{
1000 		"JSET",
1001 		.u.insns = {
1002 			BPF_JUMP(BPF_JMP | BPF_JA, 0, 0, 0),
1003 			BPF_JUMP(BPF_JMP | BPF_JA, 1, 1, 1),
1004 			BPF_JUMP(BPF_JMP | BPF_JA, 0, 0, 0),
1005 			BPF_JUMP(BPF_JMP | BPF_JA, 0, 0, 0),
1006 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
1007 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
1008 			BPF_STMT(BPF_ALU | BPF_SUB | BPF_K, 4),
1009 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
1010 			BPF_STMT(BPF_LD | BPF_W | BPF_IND, 0),
1011 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 1, 0, 1),
1012 			BPF_STMT(BPF_RET | BPF_K, 10),
1013 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0x80000000, 0, 1),
1014 			BPF_STMT(BPF_RET | BPF_K, 20),
1015 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0xffffff, 1, 0),
1016 			BPF_STMT(BPF_RET | BPF_K, 30),
1017 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0xffffff, 1, 0),
1018 			BPF_STMT(BPF_RET | BPF_K, 30),
1019 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0xffffff, 1, 0),
1020 			BPF_STMT(BPF_RET | BPF_K, 30),
1021 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0xffffff, 1, 0),
1022 			BPF_STMT(BPF_RET | BPF_K, 30),
1023 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0xffffff, 1, 0),
1024 			BPF_STMT(BPF_RET | BPF_K, 30),
1025 			BPF_STMT(BPF_RET | BPF_K, MAX_K)
1026 		},
1027 		CLASSIC,
1028 		{ 0, 0xAA, 0x55, 1 },
1029 		{ { 4, 10 }, { 5, 20 }, { 6, MAX_K } },
1030 	},
1031 	{
1032 		"tcpdump port 22",
1033 		.u.insns = {
1034 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 12),
1035 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x86dd, 0, 8), /* IPv6 */
1036 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 20),
1037 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x84, 2, 0),
1038 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x6, 1, 0),
1039 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x11, 0, 17),
1040 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 54),
1041 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 22, 14, 0),
1042 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 56),
1043 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 22, 12, 13),
1044 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x0800, 0, 12), /* IPv4 */
1045 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 23),
1046 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x84, 2, 0),
1047 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x6, 1, 0),
1048 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x11, 0, 8),
1049 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 20),
1050 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0x1fff, 6, 0),
1051 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 14),
1052 			BPF_STMT(BPF_LD | BPF_H | BPF_IND, 14),
1053 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 22, 2, 0),
1054 			BPF_STMT(BPF_LD | BPF_H | BPF_IND, 16),
1055 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 22, 0, 1),
1056 			BPF_STMT(BPF_RET | BPF_K, 0xffff),
1057 			BPF_STMT(BPF_RET | BPF_K, 0),
1058 		},
1059 		CLASSIC,
1060 		/* 3c:07:54:43:e5:76 > 10:bf:48:d6:43:d6, ethertype IPv4(0x0800)
1061 		 * length 114: 10.1.1.149.49700 > 10.1.2.10.22: Flags [P.],
1062 		 * seq 1305692979:1305693027, ack 3650467037, win 65535,
1063 		 * options [nop,nop,TS val 2502645400 ecr 3971138], length 48
1064 		 */
1065 		{ 0x10, 0xbf, 0x48, 0xd6, 0x43, 0xd6,
1066 		  0x3c, 0x07, 0x54, 0x43, 0xe5, 0x76,
1067 		  0x08, 0x00,
1068 		  0x45, 0x10, 0x00, 0x64, 0x75, 0xb5,
1069 		  0x40, 0x00, 0x40, 0x06, 0xad, 0x2e, /* IP header */
1070 		  0x0a, 0x01, 0x01, 0x95, /* ip src */
1071 		  0x0a, 0x01, 0x02, 0x0a, /* ip dst */
1072 		  0xc2, 0x24,
1073 		  0x00, 0x16 /* dst port */ },
1074 		{ { 10, 0 }, { 30, 0 }, { 100, 65535 } },
1075 	},
1076 	{
1077 		"tcpdump complex",
1078 		.u.insns = {
1079 			/* tcpdump -nei eth0 'tcp port 22 and (((ip[2:2] -
1080 			 * ((ip[0]&0xf)<<2)) - ((tcp[12]&0xf0)>>2)) != 0) and
1081 			 * (len > 115 or len < 30000000000)' -d
1082 			 */
1083 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 12),
1084 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x86dd, 30, 0),
1085 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x800, 0, 29),
1086 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 23),
1087 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x6, 0, 27),
1088 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 20),
1089 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0x1fff, 25, 0),
1090 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 14),
1091 			BPF_STMT(BPF_LD | BPF_H | BPF_IND, 14),
1092 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 22, 2, 0),
1093 			BPF_STMT(BPF_LD | BPF_H | BPF_IND, 16),
1094 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 22, 0, 20),
1095 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 16),
1096 			BPF_STMT(BPF_ST, 1),
1097 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 14),
1098 			BPF_STMT(BPF_ALU | BPF_AND | BPF_K, 0xf),
1099 			BPF_STMT(BPF_ALU | BPF_LSH | BPF_K, 2),
1100 			BPF_STMT(BPF_MISC | BPF_TAX, 0x5), /* libpcap emits K on TAX */
1101 			BPF_STMT(BPF_LD | BPF_MEM, 1),
1102 			BPF_STMT(BPF_ALU | BPF_SUB | BPF_X, 0),
1103 			BPF_STMT(BPF_ST, 5),
1104 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 14),
1105 			BPF_STMT(BPF_LD | BPF_B | BPF_IND, 26),
1106 			BPF_STMT(BPF_ALU | BPF_AND | BPF_K, 0xf0),
1107 			BPF_STMT(BPF_ALU | BPF_RSH | BPF_K, 2),
1108 			BPF_STMT(BPF_MISC | BPF_TAX, 0x9), /* libpcap emits K on TAX */
1109 			BPF_STMT(BPF_LD | BPF_MEM, 5),
1110 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_X, 0, 4, 0),
1111 			BPF_STMT(BPF_LD | BPF_LEN, 0),
1112 			BPF_JUMP(BPF_JMP | BPF_JGT | BPF_K, 0x73, 1, 0),
1113 			BPF_JUMP(BPF_JMP | BPF_JGE | BPF_K, 0xfc23ac00, 1, 0),
1114 			BPF_STMT(BPF_RET | BPF_K, 0xffff),
1115 			BPF_STMT(BPF_RET | BPF_K, 0),
1116 		},
1117 		CLASSIC,
1118 		{ 0x10, 0xbf, 0x48, 0xd6, 0x43, 0xd6,
1119 		  0x3c, 0x07, 0x54, 0x43, 0xe5, 0x76,
1120 		  0x08, 0x00,
1121 		  0x45, 0x10, 0x00, 0x64, 0x75, 0xb5,
1122 		  0x40, 0x00, 0x40, 0x06, 0xad, 0x2e, /* IP header */
1123 		  0x0a, 0x01, 0x01, 0x95, /* ip src */
1124 		  0x0a, 0x01, 0x02, 0x0a, /* ip dst */
1125 		  0xc2, 0x24,
1126 		  0x00, 0x16 /* dst port */ },
1127 		{ { 10, 0 }, { 30, 0 }, { 100, 65535 } },
1128 	},
1129 	{
1130 		"RET_A",
1131 		.u.insns = {
1132 			/* check that unitialized X and A contain zeros */
1133 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
1134 			BPF_STMT(BPF_RET | BPF_A, 0)
1135 		},
1136 		CLASSIC,
1137 		{ },
1138 		{ {1, 0}, {2, 0} },
1139 	},
1140 	{
1141 		"INT: ADD trivial",
1142 		.u.insns_int = {
1143 			BPF_ALU64_IMM(BPF_MOV, R1, 1),
1144 			BPF_ALU64_IMM(BPF_ADD, R1, 2),
1145 			BPF_ALU64_IMM(BPF_MOV, R2, 3),
1146 			BPF_ALU64_REG(BPF_SUB, R1, R2),
1147 			BPF_ALU64_IMM(BPF_ADD, R1, -1),
1148 			BPF_ALU64_IMM(BPF_MUL, R1, 3),
1149 			BPF_ALU64_REG(BPF_MOV, R0, R1),
1150 			BPF_EXIT_INSN(),
1151 		},
1152 		INTERNAL,
1153 		{ },
1154 		{ { 0, 0xfffffffd } }
1155 	},
1156 	{
1157 		"INT: MUL_X",
1158 		.u.insns_int = {
1159 			BPF_ALU64_IMM(BPF_MOV, R0, -1),
1160 			BPF_ALU64_IMM(BPF_MOV, R1, -1),
1161 			BPF_ALU64_IMM(BPF_MOV, R2, 3),
1162 			BPF_ALU64_REG(BPF_MUL, R1, R2),
1163 			BPF_JMP_IMM(BPF_JEQ, R1, 0xfffffffd, 1),
1164 			BPF_EXIT_INSN(),
1165 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
1166 			BPF_EXIT_INSN(),
1167 		},
1168 		INTERNAL,
1169 		{ },
1170 		{ { 0, 1 } }
1171 	},
1172 	{
1173 		"INT: MUL_X2",
1174 		.u.insns_int = {
1175 			BPF_ALU32_IMM(BPF_MOV, R0, -1),
1176 			BPF_ALU32_IMM(BPF_MOV, R1, -1),
1177 			BPF_ALU32_IMM(BPF_MOV, R2, 3),
1178 			BPF_ALU64_REG(BPF_MUL, R1, R2),
1179 			BPF_ALU64_IMM(BPF_RSH, R1, 8),
1180 			BPF_JMP_IMM(BPF_JEQ, R1, 0x2ffffff, 1),
1181 			BPF_EXIT_INSN(),
1182 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
1183 			BPF_EXIT_INSN(),
1184 		},
1185 		INTERNAL,
1186 		{ },
1187 		{ { 0, 1 } }
1188 	},
1189 	{
1190 		"INT: MUL32_X",
1191 		.u.insns_int = {
1192 			BPF_ALU32_IMM(BPF_MOV, R0, -1),
1193 			BPF_ALU64_IMM(BPF_MOV, R1, -1),
1194 			BPF_ALU32_IMM(BPF_MOV, R2, 3),
1195 			BPF_ALU32_REG(BPF_MUL, R1, R2),
1196 			BPF_ALU64_IMM(BPF_RSH, R1, 8),
1197 			BPF_JMP_IMM(BPF_JEQ, R1, 0xffffff, 1),
1198 			BPF_EXIT_INSN(),
1199 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
1200 			BPF_EXIT_INSN(),
1201 		},
1202 		INTERNAL,
1203 		{ },
1204 		{ { 0, 1 } }
1205 	},
1206 	{
1207 		/* Have to test all register combinations, since
1208 		 * JITing of different registers will produce
1209 		 * different asm code.
1210 		 */
1211 		"INT: ADD 64-bit",
1212 		.u.insns_int = {
1213 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
1214 			BPF_ALU64_IMM(BPF_MOV, R1, 1),
1215 			BPF_ALU64_IMM(BPF_MOV, R2, 2),
1216 			BPF_ALU64_IMM(BPF_MOV, R3, 3),
1217 			BPF_ALU64_IMM(BPF_MOV, R4, 4),
1218 			BPF_ALU64_IMM(BPF_MOV, R5, 5),
1219 			BPF_ALU64_IMM(BPF_MOV, R6, 6),
1220 			BPF_ALU64_IMM(BPF_MOV, R7, 7),
1221 			BPF_ALU64_IMM(BPF_MOV, R8, 8),
1222 			BPF_ALU64_IMM(BPF_MOV, R9, 9),
1223 			BPF_ALU64_IMM(BPF_ADD, R0, 20),
1224 			BPF_ALU64_IMM(BPF_ADD, R1, 20),
1225 			BPF_ALU64_IMM(BPF_ADD, R2, 20),
1226 			BPF_ALU64_IMM(BPF_ADD, R3, 20),
1227 			BPF_ALU64_IMM(BPF_ADD, R4, 20),
1228 			BPF_ALU64_IMM(BPF_ADD, R5, 20),
1229 			BPF_ALU64_IMM(BPF_ADD, R6, 20),
1230 			BPF_ALU64_IMM(BPF_ADD, R7, 20),
1231 			BPF_ALU64_IMM(BPF_ADD, R8, 20),
1232 			BPF_ALU64_IMM(BPF_ADD, R9, 20),
1233 			BPF_ALU64_IMM(BPF_SUB, R0, 10),
1234 			BPF_ALU64_IMM(BPF_SUB, R1, 10),
1235 			BPF_ALU64_IMM(BPF_SUB, R2, 10),
1236 			BPF_ALU64_IMM(BPF_SUB, R3, 10),
1237 			BPF_ALU64_IMM(BPF_SUB, R4, 10),
1238 			BPF_ALU64_IMM(BPF_SUB, R5, 10),
1239 			BPF_ALU64_IMM(BPF_SUB, R6, 10),
1240 			BPF_ALU64_IMM(BPF_SUB, R7, 10),
1241 			BPF_ALU64_IMM(BPF_SUB, R8, 10),
1242 			BPF_ALU64_IMM(BPF_SUB, R9, 10),
1243 			BPF_ALU64_REG(BPF_ADD, R0, R0),
1244 			BPF_ALU64_REG(BPF_ADD, R0, R1),
1245 			BPF_ALU64_REG(BPF_ADD, R0, R2),
1246 			BPF_ALU64_REG(BPF_ADD, R0, R3),
1247 			BPF_ALU64_REG(BPF_ADD, R0, R4),
1248 			BPF_ALU64_REG(BPF_ADD, R0, R5),
1249 			BPF_ALU64_REG(BPF_ADD, R0, R6),
1250 			BPF_ALU64_REG(BPF_ADD, R0, R7),
1251 			BPF_ALU64_REG(BPF_ADD, R0, R8),
1252 			BPF_ALU64_REG(BPF_ADD, R0, R9), /* R0 == 155 */
1253 			BPF_JMP_IMM(BPF_JEQ, R0, 155, 1),
1254 			BPF_EXIT_INSN(),
1255 			BPF_ALU64_REG(BPF_ADD, R1, R0),
1256 			BPF_ALU64_REG(BPF_ADD, R1, R1),
1257 			BPF_ALU64_REG(BPF_ADD, R1, R2),
1258 			BPF_ALU64_REG(BPF_ADD, R1, R3),
1259 			BPF_ALU64_REG(BPF_ADD, R1, R4),
1260 			BPF_ALU64_REG(BPF_ADD, R1, R5),
1261 			BPF_ALU64_REG(BPF_ADD, R1, R6),
1262 			BPF_ALU64_REG(BPF_ADD, R1, R7),
1263 			BPF_ALU64_REG(BPF_ADD, R1, R8),
1264 			BPF_ALU64_REG(BPF_ADD, R1, R9), /* R1 == 456 */
1265 			BPF_JMP_IMM(BPF_JEQ, R1, 456, 1),
1266 			BPF_EXIT_INSN(),
1267 			BPF_ALU64_REG(BPF_ADD, R2, R0),
1268 			BPF_ALU64_REG(BPF_ADD, R2, R1),
1269 			BPF_ALU64_REG(BPF_ADD, R2, R2),
1270 			BPF_ALU64_REG(BPF_ADD, R2, R3),
1271 			BPF_ALU64_REG(BPF_ADD, R2, R4),
1272 			BPF_ALU64_REG(BPF_ADD, R2, R5),
1273 			BPF_ALU64_REG(BPF_ADD, R2, R6),
1274 			BPF_ALU64_REG(BPF_ADD, R2, R7),
1275 			BPF_ALU64_REG(BPF_ADD, R2, R8),
1276 			BPF_ALU64_REG(BPF_ADD, R2, R9), /* R2 == 1358 */
1277 			BPF_JMP_IMM(BPF_JEQ, R2, 1358, 1),
1278 			BPF_EXIT_INSN(),
1279 			BPF_ALU64_REG(BPF_ADD, R3, R0),
1280 			BPF_ALU64_REG(BPF_ADD, R3, R1),
1281 			BPF_ALU64_REG(BPF_ADD, R3, R2),
1282 			BPF_ALU64_REG(BPF_ADD, R3, R3),
1283 			BPF_ALU64_REG(BPF_ADD, R3, R4),
1284 			BPF_ALU64_REG(BPF_ADD, R3, R5),
1285 			BPF_ALU64_REG(BPF_ADD, R3, R6),
1286 			BPF_ALU64_REG(BPF_ADD, R3, R7),
1287 			BPF_ALU64_REG(BPF_ADD, R3, R8),
1288 			BPF_ALU64_REG(BPF_ADD, R3, R9), /* R3 == 4063 */
1289 			BPF_JMP_IMM(BPF_JEQ, R3, 4063, 1),
1290 			BPF_EXIT_INSN(),
1291 			BPF_ALU64_REG(BPF_ADD, R4, R0),
1292 			BPF_ALU64_REG(BPF_ADD, R4, R1),
1293 			BPF_ALU64_REG(BPF_ADD, R4, R2),
1294 			BPF_ALU64_REG(BPF_ADD, R4, R3),
1295 			BPF_ALU64_REG(BPF_ADD, R4, R4),
1296 			BPF_ALU64_REG(BPF_ADD, R4, R5),
1297 			BPF_ALU64_REG(BPF_ADD, R4, R6),
1298 			BPF_ALU64_REG(BPF_ADD, R4, R7),
1299 			BPF_ALU64_REG(BPF_ADD, R4, R8),
1300 			BPF_ALU64_REG(BPF_ADD, R4, R9), /* R4 == 12177 */
1301 			BPF_JMP_IMM(BPF_JEQ, R4, 12177, 1),
1302 			BPF_EXIT_INSN(),
1303 			BPF_ALU64_REG(BPF_ADD, R5, R0),
1304 			BPF_ALU64_REG(BPF_ADD, R5, R1),
1305 			BPF_ALU64_REG(BPF_ADD, R5, R2),
1306 			BPF_ALU64_REG(BPF_ADD, R5, R3),
1307 			BPF_ALU64_REG(BPF_ADD, R5, R4),
1308 			BPF_ALU64_REG(BPF_ADD, R5, R5),
1309 			BPF_ALU64_REG(BPF_ADD, R5, R6),
1310 			BPF_ALU64_REG(BPF_ADD, R5, R7),
1311 			BPF_ALU64_REG(BPF_ADD, R5, R8),
1312 			BPF_ALU64_REG(BPF_ADD, R5, R9), /* R5 == 36518 */
1313 			BPF_JMP_IMM(BPF_JEQ, R5, 36518, 1),
1314 			BPF_EXIT_INSN(),
1315 			BPF_ALU64_REG(BPF_ADD, R6, R0),
1316 			BPF_ALU64_REG(BPF_ADD, R6, R1),
1317 			BPF_ALU64_REG(BPF_ADD, R6, R2),
1318 			BPF_ALU64_REG(BPF_ADD, R6, R3),
1319 			BPF_ALU64_REG(BPF_ADD, R6, R4),
1320 			BPF_ALU64_REG(BPF_ADD, R6, R5),
1321 			BPF_ALU64_REG(BPF_ADD, R6, R6),
1322 			BPF_ALU64_REG(BPF_ADD, R6, R7),
1323 			BPF_ALU64_REG(BPF_ADD, R6, R8),
1324 			BPF_ALU64_REG(BPF_ADD, R6, R9), /* R6 == 109540 */
1325 			BPF_JMP_IMM(BPF_JEQ, R6, 109540, 1),
1326 			BPF_EXIT_INSN(),
1327 			BPF_ALU64_REG(BPF_ADD, R7, R0),
1328 			BPF_ALU64_REG(BPF_ADD, R7, R1),
1329 			BPF_ALU64_REG(BPF_ADD, R7, R2),
1330 			BPF_ALU64_REG(BPF_ADD, R7, R3),
1331 			BPF_ALU64_REG(BPF_ADD, R7, R4),
1332 			BPF_ALU64_REG(BPF_ADD, R7, R5),
1333 			BPF_ALU64_REG(BPF_ADD, R7, R6),
1334 			BPF_ALU64_REG(BPF_ADD, R7, R7),
1335 			BPF_ALU64_REG(BPF_ADD, R7, R8),
1336 			BPF_ALU64_REG(BPF_ADD, R7, R9), /* R7 == 328605 */
1337 			BPF_JMP_IMM(BPF_JEQ, R7, 328605, 1),
1338 			BPF_EXIT_INSN(),
1339 			BPF_ALU64_REG(BPF_ADD, R8, R0),
1340 			BPF_ALU64_REG(BPF_ADD, R8, R1),
1341 			BPF_ALU64_REG(BPF_ADD, R8, R2),
1342 			BPF_ALU64_REG(BPF_ADD, R8, R3),
1343 			BPF_ALU64_REG(BPF_ADD, R8, R4),
1344 			BPF_ALU64_REG(BPF_ADD, R8, R5),
1345 			BPF_ALU64_REG(BPF_ADD, R8, R6),
1346 			BPF_ALU64_REG(BPF_ADD, R8, R7),
1347 			BPF_ALU64_REG(BPF_ADD, R8, R8),
1348 			BPF_ALU64_REG(BPF_ADD, R8, R9), /* R8 == 985799 */
1349 			BPF_JMP_IMM(BPF_JEQ, R8, 985799, 1),
1350 			BPF_EXIT_INSN(),
1351 			BPF_ALU64_REG(BPF_ADD, R9, R0),
1352 			BPF_ALU64_REG(BPF_ADD, R9, R1),
1353 			BPF_ALU64_REG(BPF_ADD, R9, R2),
1354 			BPF_ALU64_REG(BPF_ADD, R9, R3),
1355 			BPF_ALU64_REG(BPF_ADD, R9, R4),
1356 			BPF_ALU64_REG(BPF_ADD, R9, R5),
1357 			BPF_ALU64_REG(BPF_ADD, R9, R6),
1358 			BPF_ALU64_REG(BPF_ADD, R9, R7),
1359 			BPF_ALU64_REG(BPF_ADD, R9, R8),
1360 			BPF_ALU64_REG(BPF_ADD, R9, R9), /* R9 == 2957380 */
1361 			BPF_ALU64_REG(BPF_MOV, R0, R9),
1362 			BPF_EXIT_INSN(),
1363 		},
1364 		INTERNAL,
1365 		{ },
1366 		{ { 0, 2957380 } }
1367 	},
1368 	{
1369 		"INT: ADD 32-bit",
1370 		.u.insns_int = {
1371 			BPF_ALU32_IMM(BPF_MOV, R0, 20),
1372 			BPF_ALU32_IMM(BPF_MOV, R1, 1),
1373 			BPF_ALU32_IMM(BPF_MOV, R2, 2),
1374 			BPF_ALU32_IMM(BPF_MOV, R3, 3),
1375 			BPF_ALU32_IMM(BPF_MOV, R4, 4),
1376 			BPF_ALU32_IMM(BPF_MOV, R5, 5),
1377 			BPF_ALU32_IMM(BPF_MOV, R6, 6),
1378 			BPF_ALU32_IMM(BPF_MOV, R7, 7),
1379 			BPF_ALU32_IMM(BPF_MOV, R8, 8),
1380 			BPF_ALU32_IMM(BPF_MOV, R9, 9),
1381 			BPF_ALU64_IMM(BPF_ADD, R1, 10),
1382 			BPF_ALU64_IMM(BPF_ADD, R2, 10),
1383 			BPF_ALU64_IMM(BPF_ADD, R3, 10),
1384 			BPF_ALU64_IMM(BPF_ADD, R4, 10),
1385 			BPF_ALU64_IMM(BPF_ADD, R5, 10),
1386 			BPF_ALU64_IMM(BPF_ADD, R6, 10),
1387 			BPF_ALU64_IMM(BPF_ADD, R7, 10),
1388 			BPF_ALU64_IMM(BPF_ADD, R8, 10),
1389 			BPF_ALU64_IMM(BPF_ADD, R9, 10),
1390 			BPF_ALU32_REG(BPF_ADD, R0, R1),
1391 			BPF_ALU32_REG(BPF_ADD, R0, R2),
1392 			BPF_ALU32_REG(BPF_ADD, R0, R3),
1393 			BPF_ALU32_REG(BPF_ADD, R0, R4),
1394 			BPF_ALU32_REG(BPF_ADD, R0, R5),
1395 			BPF_ALU32_REG(BPF_ADD, R0, R6),
1396 			BPF_ALU32_REG(BPF_ADD, R0, R7),
1397 			BPF_ALU32_REG(BPF_ADD, R0, R8),
1398 			BPF_ALU32_REG(BPF_ADD, R0, R9), /* R0 == 155 */
1399 			BPF_JMP_IMM(BPF_JEQ, R0, 155, 1),
1400 			BPF_EXIT_INSN(),
1401 			BPF_ALU32_REG(BPF_ADD, R1, R0),
1402 			BPF_ALU32_REG(BPF_ADD, R1, R1),
1403 			BPF_ALU32_REG(BPF_ADD, R1, R2),
1404 			BPF_ALU32_REG(BPF_ADD, R1, R3),
1405 			BPF_ALU32_REG(BPF_ADD, R1, R4),
1406 			BPF_ALU32_REG(BPF_ADD, R1, R5),
1407 			BPF_ALU32_REG(BPF_ADD, R1, R6),
1408 			BPF_ALU32_REG(BPF_ADD, R1, R7),
1409 			BPF_ALU32_REG(BPF_ADD, R1, R8),
1410 			BPF_ALU32_REG(BPF_ADD, R1, R9), /* R1 == 456 */
1411 			BPF_JMP_IMM(BPF_JEQ, R1, 456, 1),
1412 			BPF_EXIT_INSN(),
1413 			BPF_ALU32_REG(BPF_ADD, R2, R0),
1414 			BPF_ALU32_REG(BPF_ADD, R2, R1),
1415 			BPF_ALU32_REG(BPF_ADD, R2, R2),
1416 			BPF_ALU32_REG(BPF_ADD, R2, R3),
1417 			BPF_ALU32_REG(BPF_ADD, R2, R4),
1418 			BPF_ALU32_REG(BPF_ADD, R2, R5),
1419 			BPF_ALU32_REG(BPF_ADD, R2, R6),
1420 			BPF_ALU32_REG(BPF_ADD, R2, R7),
1421 			BPF_ALU32_REG(BPF_ADD, R2, R8),
1422 			BPF_ALU32_REG(BPF_ADD, R2, R9), /* R2 == 1358 */
1423 			BPF_JMP_IMM(BPF_JEQ, R2, 1358, 1),
1424 			BPF_EXIT_INSN(),
1425 			BPF_ALU32_REG(BPF_ADD, R3, R0),
1426 			BPF_ALU32_REG(BPF_ADD, R3, R1),
1427 			BPF_ALU32_REG(BPF_ADD, R3, R2),
1428 			BPF_ALU32_REG(BPF_ADD, R3, R3),
1429 			BPF_ALU32_REG(BPF_ADD, R3, R4),
1430 			BPF_ALU32_REG(BPF_ADD, R3, R5),
1431 			BPF_ALU32_REG(BPF_ADD, R3, R6),
1432 			BPF_ALU32_REG(BPF_ADD, R3, R7),
1433 			BPF_ALU32_REG(BPF_ADD, R3, R8),
1434 			BPF_ALU32_REG(BPF_ADD, R3, R9), /* R3 == 4063 */
1435 			BPF_JMP_IMM(BPF_JEQ, R3, 4063, 1),
1436 			BPF_EXIT_INSN(),
1437 			BPF_ALU32_REG(BPF_ADD, R4, R0),
1438 			BPF_ALU32_REG(BPF_ADD, R4, R1),
1439 			BPF_ALU32_REG(BPF_ADD, R4, R2),
1440 			BPF_ALU32_REG(BPF_ADD, R4, R3),
1441 			BPF_ALU32_REG(BPF_ADD, R4, R4),
1442 			BPF_ALU32_REG(BPF_ADD, R4, R5),
1443 			BPF_ALU32_REG(BPF_ADD, R4, R6),
1444 			BPF_ALU32_REG(BPF_ADD, R4, R7),
1445 			BPF_ALU32_REG(BPF_ADD, R4, R8),
1446 			BPF_ALU32_REG(BPF_ADD, R4, R9), /* R4 == 12177 */
1447 			BPF_JMP_IMM(BPF_JEQ, R4, 12177, 1),
1448 			BPF_EXIT_INSN(),
1449 			BPF_ALU32_REG(BPF_ADD, R5, R0),
1450 			BPF_ALU32_REG(BPF_ADD, R5, R1),
1451 			BPF_ALU32_REG(BPF_ADD, R5, R2),
1452 			BPF_ALU32_REG(BPF_ADD, R5, R3),
1453 			BPF_ALU32_REG(BPF_ADD, R5, R4),
1454 			BPF_ALU32_REG(BPF_ADD, R5, R5),
1455 			BPF_ALU32_REG(BPF_ADD, R5, R6),
1456 			BPF_ALU32_REG(BPF_ADD, R5, R7),
1457 			BPF_ALU32_REG(BPF_ADD, R5, R8),
1458 			BPF_ALU32_REG(BPF_ADD, R5, R9), /* R5 == 36518 */
1459 			BPF_JMP_IMM(BPF_JEQ, R5, 36518, 1),
1460 			BPF_EXIT_INSN(),
1461 			BPF_ALU32_REG(BPF_ADD, R6, R0),
1462 			BPF_ALU32_REG(BPF_ADD, R6, R1),
1463 			BPF_ALU32_REG(BPF_ADD, R6, R2),
1464 			BPF_ALU32_REG(BPF_ADD, R6, R3),
1465 			BPF_ALU32_REG(BPF_ADD, R6, R4),
1466 			BPF_ALU32_REG(BPF_ADD, R6, R5),
1467 			BPF_ALU32_REG(BPF_ADD, R6, R6),
1468 			BPF_ALU32_REG(BPF_ADD, R6, R7),
1469 			BPF_ALU32_REG(BPF_ADD, R6, R8),
1470 			BPF_ALU32_REG(BPF_ADD, R6, R9), /* R6 == 109540 */
1471 			BPF_JMP_IMM(BPF_JEQ, R6, 109540, 1),
1472 			BPF_EXIT_INSN(),
1473 			BPF_ALU32_REG(BPF_ADD, R7, R0),
1474 			BPF_ALU32_REG(BPF_ADD, R7, R1),
1475 			BPF_ALU32_REG(BPF_ADD, R7, R2),
1476 			BPF_ALU32_REG(BPF_ADD, R7, R3),
1477 			BPF_ALU32_REG(BPF_ADD, R7, R4),
1478 			BPF_ALU32_REG(BPF_ADD, R7, R5),
1479 			BPF_ALU32_REG(BPF_ADD, R7, R6),
1480 			BPF_ALU32_REG(BPF_ADD, R7, R7),
1481 			BPF_ALU32_REG(BPF_ADD, R7, R8),
1482 			BPF_ALU32_REG(BPF_ADD, R7, R9), /* R7 == 328605 */
1483 			BPF_JMP_IMM(BPF_JEQ, R7, 328605, 1),
1484 			BPF_EXIT_INSN(),
1485 			BPF_ALU32_REG(BPF_ADD, R8, R0),
1486 			BPF_ALU32_REG(BPF_ADD, R8, R1),
1487 			BPF_ALU32_REG(BPF_ADD, R8, R2),
1488 			BPF_ALU32_REG(BPF_ADD, R8, R3),
1489 			BPF_ALU32_REG(BPF_ADD, R8, R4),
1490 			BPF_ALU32_REG(BPF_ADD, R8, R5),
1491 			BPF_ALU32_REG(BPF_ADD, R8, R6),
1492 			BPF_ALU32_REG(BPF_ADD, R8, R7),
1493 			BPF_ALU32_REG(BPF_ADD, R8, R8),
1494 			BPF_ALU32_REG(BPF_ADD, R8, R9), /* R8 == 985799 */
1495 			BPF_JMP_IMM(BPF_JEQ, R8, 985799, 1),
1496 			BPF_EXIT_INSN(),
1497 			BPF_ALU32_REG(BPF_ADD, R9, R0),
1498 			BPF_ALU32_REG(BPF_ADD, R9, R1),
1499 			BPF_ALU32_REG(BPF_ADD, R9, R2),
1500 			BPF_ALU32_REG(BPF_ADD, R9, R3),
1501 			BPF_ALU32_REG(BPF_ADD, R9, R4),
1502 			BPF_ALU32_REG(BPF_ADD, R9, R5),
1503 			BPF_ALU32_REG(BPF_ADD, R9, R6),
1504 			BPF_ALU32_REG(BPF_ADD, R9, R7),
1505 			BPF_ALU32_REG(BPF_ADD, R9, R8),
1506 			BPF_ALU32_REG(BPF_ADD, R9, R9), /* R9 == 2957380 */
1507 			BPF_ALU32_REG(BPF_MOV, R0, R9),
1508 			BPF_EXIT_INSN(),
1509 		},
1510 		INTERNAL,
1511 		{ },
1512 		{ { 0, 2957380 } }
1513 	},
1514 	{	/* Mainly checking JIT here. */
1515 		"INT: SUB",
1516 		.u.insns_int = {
1517 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
1518 			BPF_ALU64_IMM(BPF_MOV, R1, 1),
1519 			BPF_ALU64_IMM(BPF_MOV, R2, 2),
1520 			BPF_ALU64_IMM(BPF_MOV, R3, 3),
1521 			BPF_ALU64_IMM(BPF_MOV, R4, 4),
1522 			BPF_ALU64_IMM(BPF_MOV, R5, 5),
1523 			BPF_ALU64_IMM(BPF_MOV, R6, 6),
1524 			BPF_ALU64_IMM(BPF_MOV, R7, 7),
1525 			BPF_ALU64_IMM(BPF_MOV, R8, 8),
1526 			BPF_ALU64_IMM(BPF_MOV, R9, 9),
1527 			BPF_ALU64_REG(BPF_SUB, R0, R0),
1528 			BPF_ALU64_REG(BPF_SUB, R0, R1),
1529 			BPF_ALU64_REG(BPF_SUB, R0, R2),
1530 			BPF_ALU64_REG(BPF_SUB, R0, R3),
1531 			BPF_ALU64_REG(BPF_SUB, R0, R4),
1532 			BPF_ALU64_REG(BPF_SUB, R0, R5),
1533 			BPF_ALU64_REG(BPF_SUB, R0, R6),
1534 			BPF_ALU64_REG(BPF_SUB, R0, R7),
1535 			BPF_ALU64_REG(BPF_SUB, R0, R8),
1536 			BPF_ALU64_REG(BPF_SUB, R0, R9),
1537 			BPF_ALU64_IMM(BPF_SUB, R0, 10),
1538 			BPF_JMP_IMM(BPF_JEQ, R0, -55, 1),
1539 			BPF_EXIT_INSN(),
1540 			BPF_ALU64_REG(BPF_SUB, R1, R0),
1541 			BPF_ALU64_REG(BPF_SUB, R1, R2),
1542 			BPF_ALU64_REG(BPF_SUB, R1, R3),
1543 			BPF_ALU64_REG(BPF_SUB, R1, R4),
1544 			BPF_ALU64_REG(BPF_SUB, R1, R5),
1545 			BPF_ALU64_REG(BPF_SUB, R1, R6),
1546 			BPF_ALU64_REG(BPF_SUB, R1, R7),
1547 			BPF_ALU64_REG(BPF_SUB, R1, R8),
1548 			BPF_ALU64_REG(BPF_SUB, R1, R9),
1549 			BPF_ALU64_IMM(BPF_SUB, R1, 10),
1550 			BPF_ALU64_REG(BPF_SUB, R2, R0),
1551 			BPF_ALU64_REG(BPF_SUB, R2, R1),
1552 			BPF_ALU64_REG(BPF_SUB, R2, R3),
1553 			BPF_ALU64_REG(BPF_SUB, R2, R4),
1554 			BPF_ALU64_REG(BPF_SUB, R2, R5),
1555 			BPF_ALU64_REG(BPF_SUB, R2, R6),
1556 			BPF_ALU64_REG(BPF_SUB, R2, R7),
1557 			BPF_ALU64_REG(BPF_SUB, R2, R8),
1558 			BPF_ALU64_REG(BPF_SUB, R2, R9),
1559 			BPF_ALU64_IMM(BPF_SUB, R2, 10),
1560 			BPF_ALU64_REG(BPF_SUB, R3, R0),
1561 			BPF_ALU64_REG(BPF_SUB, R3, R1),
1562 			BPF_ALU64_REG(BPF_SUB, R3, R2),
1563 			BPF_ALU64_REG(BPF_SUB, R3, R4),
1564 			BPF_ALU64_REG(BPF_SUB, R3, R5),
1565 			BPF_ALU64_REG(BPF_SUB, R3, R6),
1566 			BPF_ALU64_REG(BPF_SUB, R3, R7),
1567 			BPF_ALU64_REG(BPF_SUB, R3, R8),
1568 			BPF_ALU64_REG(BPF_SUB, R3, R9),
1569 			BPF_ALU64_IMM(BPF_SUB, R3, 10),
1570 			BPF_ALU64_REG(BPF_SUB, R4, R0),
1571 			BPF_ALU64_REG(BPF_SUB, R4, R1),
1572 			BPF_ALU64_REG(BPF_SUB, R4, R2),
1573 			BPF_ALU64_REG(BPF_SUB, R4, R3),
1574 			BPF_ALU64_REG(BPF_SUB, R4, R5),
1575 			BPF_ALU64_REG(BPF_SUB, R4, R6),
1576 			BPF_ALU64_REG(BPF_SUB, R4, R7),
1577 			BPF_ALU64_REG(BPF_SUB, R4, R8),
1578 			BPF_ALU64_REG(BPF_SUB, R4, R9),
1579 			BPF_ALU64_IMM(BPF_SUB, R4, 10),
1580 			BPF_ALU64_REG(BPF_SUB, R5, R0),
1581 			BPF_ALU64_REG(BPF_SUB, R5, R1),
1582 			BPF_ALU64_REG(BPF_SUB, R5, R2),
1583 			BPF_ALU64_REG(BPF_SUB, R5, R3),
1584 			BPF_ALU64_REG(BPF_SUB, R5, R4),
1585 			BPF_ALU64_REG(BPF_SUB, R5, R6),
1586 			BPF_ALU64_REG(BPF_SUB, R5, R7),
1587 			BPF_ALU64_REG(BPF_SUB, R5, R8),
1588 			BPF_ALU64_REG(BPF_SUB, R5, R9),
1589 			BPF_ALU64_IMM(BPF_SUB, R5, 10),
1590 			BPF_ALU64_REG(BPF_SUB, R6, R0),
1591 			BPF_ALU64_REG(BPF_SUB, R6, R1),
1592 			BPF_ALU64_REG(BPF_SUB, R6, R2),
1593 			BPF_ALU64_REG(BPF_SUB, R6, R3),
1594 			BPF_ALU64_REG(BPF_SUB, R6, R4),
1595 			BPF_ALU64_REG(BPF_SUB, R6, R5),
1596 			BPF_ALU64_REG(BPF_SUB, R6, R7),
1597 			BPF_ALU64_REG(BPF_SUB, R6, R8),
1598 			BPF_ALU64_REG(BPF_SUB, R6, R9),
1599 			BPF_ALU64_IMM(BPF_SUB, R6, 10),
1600 			BPF_ALU64_REG(BPF_SUB, R7, R0),
1601 			BPF_ALU64_REG(BPF_SUB, R7, R1),
1602 			BPF_ALU64_REG(BPF_SUB, R7, R2),
1603 			BPF_ALU64_REG(BPF_SUB, R7, R3),
1604 			BPF_ALU64_REG(BPF_SUB, R7, R4),
1605 			BPF_ALU64_REG(BPF_SUB, R7, R5),
1606 			BPF_ALU64_REG(BPF_SUB, R7, R6),
1607 			BPF_ALU64_REG(BPF_SUB, R7, R8),
1608 			BPF_ALU64_REG(BPF_SUB, R7, R9),
1609 			BPF_ALU64_IMM(BPF_SUB, R7, 10),
1610 			BPF_ALU64_REG(BPF_SUB, R8, R0),
1611 			BPF_ALU64_REG(BPF_SUB, R8, R1),
1612 			BPF_ALU64_REG(BPF_SUB, R8, R2),
1613 			BPF_ALU64_REG(BPF_SUB, R8, R3),
1614 			BPF_ALU64_REG(BPF_SUB, R8, R4),
1615 			BPF_ALU64_REG(BPF_SUB, R8, R5),
1616 			BPF_ALU64_REG(BPF_SUB, R8, R6),
1617 			BPF_ALU64_REG(BPF_SUB, R8, R7),
1618 			BPF_ALU64_REG(BPF_SUB, R8, R9),
1619 			BPF_ALU64_IMM(BPF_SUB, R8, 10),
1620 			BPF_ALU64_REG(BPF_SUB, R9, R0),
1621 			BPF_ALU64_REG(BPF_SUB, R9, R1),
1622 			BPF_ALU64_REG(BPF_SUB, R9, R2),
1623 			BPF_ALU64_REG(BPF_SUB, R9, R3),
1624 			BPF_ALU64_REG(BPF_SUB, R9, R4),
1625 			BPF_ALU64_REG(BPF_SUB, R9, R5),
1626 			BPF_ALU64_REG(BPF_SUB, R9, R6),
1627 			BPF_ALU64_REG(BPF_SUB, R9, R7),
1628 			BPF_ALU64_REG(BPF_SUB, R9, R8),
1629 			BPF_ALU64_IMM(BPF_SUB, R9, 10),
1630 			BPF_ALU64_IMM(BPF_SUB, R0, 10),
1631 			BPF_ALU64_IMM(BPF_NEG, R0, 0),
1632 			BPF_ALU64_REG(BPF_SUB, R0, R1),
1633 			BPF_ALU64_REG(BPF_SUB, R0, R2),
1634 			BPF_ALU64_REG(BPF_SUB, R0, R3),
1635 			BPF_ALU64_REG(BPF_SUB, R0, R4),
1636 			BPF_ALU64_REG(BPF_SUB, R0, R5),
1637 			BPF_ALU64_REG(BPF_SUB, R0, R6),
1638 			BPF_ALU64_REG(BPF_SUB, R0, R7),
1639 			BPF_ALU64_REG(BPF_SUB, R0, R8),
1640 			BPF_ALU64_REG(BPF_SUB, R0, R9),
1641 			BPF_EXIT_INSN(),
1642 		},
1643 		INTERNAL,
1644 		{ },
1645 		{ { 0, 11 } }
1646 	},
1647 	{	/* Mainly checking JIT here. */
1648 		"INT: XOR",
1649 		.u.insns_int = {
1650 			BPF_ALU64_REG(BPF_SUB, R0, R0),
1651 			BPF_ALU64_REG(BPF_XOR, R1, R1),
1652 			BPF_JMP_REG(BPF_JEQ, R0, R1, 1),
1653 			BPF_EXIT_INSN(),
1654 			BPF_ALU64_IMM(BPF_MOV, R0, 10),
1655 			BPF_ALU64_IMM(BPF_MOV, R1, -1),
1656 			BPF_ALU64_REG(BPF_SUB, R1, R1),
1657 			BPF_ALU64_REG(BPF_XOR, R2, R2),
1658 			BPF_JMP_REG(BPF_JEQ, R1, R2, 1),
1659 			BPF_EXIT_INSN(),
1660 			BPF_ALU64_REG(BPF_SUB, R2, R2),
1661 			BPF_ALU64_REG(BPF_XOR, R3, R3),
1662 			BPF_ALU64_IMM(BPF_MOV, R0, 10),
1663 			BPF_ALU64_IMM(BPF_MOV, R1, -1),
1664 			BPF_JMP_REG(BPF_JEQ, R2, R3, 1),
1665 			BPF_EXIT_INSN(),
1666 			BPF_ALU64_REG(BPF_SUB, R3, R3),
1667 			BPF_ALU64_REG(BPF_XOR, R4, R4),
1668 			BPF_ALU64_IMM(BPF_MOV, R2, 1),
1669 			BPF_ALU64_IMM(BPF_MOV, R5, -1),
1670 			BPF_JMP_REG(BPF_JEQ, R3, R4, 1),
1671 			BPF_EXIT_INSN(),
1672 			BPF_ALU64_REG(BPF_SUB, R4, R4),
1673 			BPF_ALU64_REG(BPF_XOR, R5, R5),
1674 			BPF_ALU64_IMM(BPF_MOV, R3, 1),
1675 			BPF_ALU64_IMM(BPF_MOV, R7, -1),
1676 			BPF_JMP_REG(BPF_JEQ, R5, R4, 1),
1677 			BPF_EXIT_INSN(),
1678 			BPF_ALU64_IMM(BPF_MOV, R5, 1),
1679 			BPF_ALU64_REG(BPF_SUB, R5, R5),
1680 			BPF_ALU64_REG(BPF_XOR, R6, R6),
1681 			BPF_ALU64_IMM(BPF_MOV, R1, 1),
1682 			BPF_ALU64_IMM(BPF_MOV, R8, -1),
1683 			BPF_JMP_REG(BPF_JEQ, R5, R6, 1),
1684 			BPF_EXIT_INSN(),
1685 			BPF_ALU64_REG(BPF_SUB, R6, R6),
1686 			BPF_ALU64_REG(BPF_XOR, R7, R7),
1687 			BPF_JMP_REG(BPF_JEQ, R7, R6, 1),
1688 			BPF_EXIT_INSN(),
1689 			BPF_ALU64_REG(BPF_SUB, R7, R7),
1690 			BPF_ALU64_REG(BPF_XOR, R8, R8),
1691 			BPF_JMP_REG(BPF_JEQ, R7, R8, 1),
1692 			BPF_EXIT_INSN(),
1693 			BPF_ALU64_REG(BPF_SUB, R8, R8),
1694 			BPF_ALU64_REG(BPF_XOR, R9, R9),
1695 			BPF_JMP_REG(BPF_JEQ, R9, R8, 1),
1696 			BPF_EXIT_INSN(),
1697 			BPF_ALU64_REG(BPF_SUB, R9, R9),
1698 			BPF_ALU64_REG(BPF_XOR, R0, R0),
1699 			BPF_JMP_REG(BPF_JEQ, R9, R0, 1),
1700 			BPF_EXIT_INSN(),
1701 			BPF_ALU64_REG(BPF_SUB, R1, R1),
1702 			BPF_ALU64_REG(BPF_XOR, R0, R0),
1703 			BPF_JMP_REG(BPF_JEQ, R9, R0, 2),
1704 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
1705 			BPF_EXIT_INSN(),
1706 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
1707 			BPF_EXIT_INSN(),
1708 		},
1709 		INTERNAL,
1710 		{ },
1711 		{ { 0, 1 } }
1712 	},
1713 	{	/* Mainly checking JIT here. */
1714 		"INT: MUL",
1715 		.u.insns_int = {
1716 			BPF_ALU64_IMM(BPF_MOV, R0, 11),
1717 			BPF_ALU64_IMM(BPF_MOV, R1, 1),
1718 			BPF_ALU64_IMM(BPF_MOV, R2, 2),
1719 			BPF_ALU64_IMM(BPF_MOV, R3, 3),
1720 			BPF_ALU64_IMM(BPF_MOV, R4, 4),
1721 			BPF_ALU64_IMM(BPF_MOV, R5, 5),
1722 			BPF_ALU64_IMM(BPF_MOV, R6, 6),
1723 			BPF_ALU64_IMM(BPF_MOV, R7, 7),
1724 			BPF_ALU64_IMM(BPF_MOV, R8, 8),
1725 			BPF_ALU64_IMM(BPF_MOV, R9, 9),
1726 			BPF_ALU64_REG(BPF_MUL, R0, R0),
1727 			BPF_ALU64_REG(BPF_MUL, R0, R1),
1728 			BPF_ALU64_REG(BPF_MUL, R0, R2),
1729 			BPF_ALU64_REG(BPF_MUL, R0, R3),
1730 			BPF_ALU64_REG(BPF_MUL, R0, R4),
1731 			BPF_ALU64_REG(BPF_MUL, R0, R5),
1732 			BPF_ALU64_REG(BPF_MUL, R0, R6),
1733 			BPF_ALU64_REG(BPF_MUL, R0, R7),
1734 			BPF_ALU64_REG(BPF_MUL, R0, R8),
1735 			BPF_ALU64_REG(BPF_MUL, R0, R9),
1736 			BPF_ALU64_IMM(BPF_MUL, R0, 10),
1737 			BPF_JMP_IMM(BPF_JEQ, R0, 439084800, 1),
1738 			BPF_EXIT_INSN(),
1739 			BPF_ALU64_REG(BPF_MUL, R1, R0),
1740 			BPF_ALU64_REG(BPF_MUL, R1, R2),
1741 			BPF_ALU64_REG(BPF_MUL, R1, R3),
1742 			BPF_ALU64_REG(BPF_MUL, R1, R4),
1743 			BPF_ALU64_REG(BPF_MUL, R1, R5),
1744 			BPF_ALU64_REG(BPF_MUL, R1, R6),
1745 			BPF_ALU64_REG(BPF_MUL, R1, R7),
1746 			BPF_ALU64_REG(BPF_MUL, R1, R8),
1747 			BPF_ALU64_REG(BPF_MUL, R1, R9),
1748 			BPF_ALU64_IMM(BPF_MUL, R1, 10),
1749 			BPF_ALU64_REG(BPF_MOV, R2, R1),
1750 			BPF_ALU64_IMM(BPF_RSH, R2, 32),
1751 			BPF_JMP_IMM(BPF_JEQ, R2, 0x5a924, 1),
1752 			BPF_EXIT_INSN(),
1753 			BPF_ALU64_IMM(BPF_LSH, R1, 32),
1754 			BPF_ALU64_IMM(BPF_ARSH, R1, 32),
1755 			BPF_JMP_IMM(BPF_JEQ, R1, 0xebb90000, 1),
1756 			BPF_EXIT_INSN(),
1757 			BPF_ALU64_REG(BPF_MUL, R2, R0),
1758 			BPF_ALU64_REG(BPF_MUL, R2, R1),
1759 			BPF_ALU64_REG(BPF_MUL, R2, R3),
1760 			BPF_ALU64_REG(BPF_MUL, R2, R4),
1761 			BPF_ALU64_REG(BPF_MUL, R2, R5),
1762 			BPF_ALU64_REG(BPF_MUL, R2, R6),
1763 			BPF_ALU64_REG(BPF_MUL, R2, R7),
1764 			BPF_ALU64_REG(BPF_MUL, R2, R8),
1765 			BPF_ALU64_REG(BPF_MUL, R2, R9),
1766 			BPF_ALU64_IMM(BPF_MUL, R2, 10),
1767 			BPF_ALU64_IMM(BPF_RSH, R2, 32),
1768 			BPF_ALU64_REG(BPF_MOV, R0, R2),
1769 			BPF_EXIT_INSN(),
1770 		},
1771 		INTERNAL,
1772 		{ },
1773 		{ { 0, 0x35d97ef2 } }
1774 	},
1775 	{	/* Mainly checking JIT here. */
1776 		"MOV REG64",
1777 		.u.insns_int = {
1778 			BPF_LD_IMM64(R0, 0xffffffffffffffffLL),
1779 			BPF_MOV64_REG(R1, R0),
1780 			BPF_MOV64_REG(R2, R1),
1781 			BPF_MOV64_REG(R3, R2),
1782 			BPF_MOV64_REG(R4, R3),
1783 			BPF_MOV64_REG(R5, R4),
1784 			BPF_MOV64_REG(R6, R5),
1785 			BPF_MOV64_REG(R7, R6),
1786 			BPF_MOV64_REG(R8, R7),
1787 			BPF_MOV64_REG(R9, R8),
1788 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
1789 			BPF_ALU64_IMM(BPF_MOV, R1, 0),
1790 			BPF_ALU64_IMM(BPF_MOV, R2, 0),
1791 			BPF_ALU64_IMM(BPF_MOV, R3, 0),
1792 			BPF_ALU64_IMM(BPF_MOV, R4, 0),
1793 			BPF_ALU64_IMM(BPF_MOV, R5, 0),
1794 			BPF_ALU64_IMM(BPF_MOV, R6, 0),
1795 			BPF_ALU64_IMM(BPF_MOV, R7, 0),
1796 			BPF_ALU64_IMM(BPF_MOV, R8, 0),
1797 			BPF_ALU64_IMM(BPF_MOV, R9, 0),
1798 			BPF_ALU64_REG(BPF_ADD, R0, R0),
1799 			BPF_ALU64_REG(BPF_ADD, R0, R1),
1800 			BPF_ALU64_REG(BPF_ADD, R0, R2),
1801 			BPF_ALU64_REG(BPF_ADD, R0, R3),
1802 			BPF_ALU64_REG(BPF_ADD, R0, R4),
1803 			BPF_ALU64_REG(BPF_ADD, R0, R5),
1804 			BPF_ALU64_REG(BPF_ADD, R0, R6),
1805 			BPF_ALU64_REG(BPF_ADD, R0, R7),
1806 			BPF_ALU64_REG(BPF_ADD, R0, R8),
1807 			BPF_ALU64_REG(BPF_ADD, R0, R9),
1808 			BPF_ALU64_IMM(BPF_ADD, R0, 0xfefe),
1809 			BPF_EXIT_INSN(),
1810 		},
1811 		INTERNAL,
1812 		{ },
1813 		{ { 0, 0xfefe } }
1814 	},
1815 	{	/* Mainly checking JIT here. */
1816 		"MOV REG32",
1817 		.u.insns_int = {
1818 			BPF_LD_IMM64(R0, 0xffffffffffffffffLL),
1819 			BPF_MOV64_REG(R1, R0),
1820 			BPF_MOV64_REG(R2, R1),
1821 			BPF_MOV64_REG(R3, R2),
1822 			BPF_MOV64_REG(R4, R3),
1823 			BPF_MOV64_REG(R5, R4),
1824 			BPF_MOV64_REG(R6, R5),
1825 			BPF_MOV64_REG(R7, R6),
1826 			BPF_MOV64_REG(R8, R7),
1827 			BPF_MOV64_REG(R9, R8),
1828 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
1829 			BPF_ALU32_IMM(BPF_MOV, R1, 0),
1830 			BPF_ALU32_IMM(BPF_MOV, R2, 0),
1831 			BPF_ALU32_IMM(BPF_MOV, R3, 0),
1832 			BPF_ALU32_IMM(BPF_MOV, R4, 0),
1833 			BPF_ALU32_IMM(BPF_MOV, R5, 0),
1834 			BPF_ALU32_IMM(BPF_MOV, R6, 0),
1835 			BPF_ALU32_IMM(BPF_MOV, R7, 0),
1836 			BPF_ALU32_IMM(BPF_MOV, R8, 0),
1837 			BPF_ALU32_IMM(BPF_MOV, R9, 0),
1838 			BPF_ALU64_REG(BPF_ADD, R0, R0),
1839 			BPF_ALU64_REG(BPF_ADD, R0, R1),
1840 			BPF_ALU64_REG(BPF_ADD, R0, R2),
1841 			BPF_ALU64_REG(BPF_ADD, R0, R3),
1842 			BPF_ALU64_REG(BPF_ADD, R0, R4),
1843 			BPF_ALU64_REG(BPF_ADD, R0, R5),
1844 			BPF_ALU64_REG(BPF_ADD, R0, R6),
1845 			BPF_ALU64_REG(BPF_ADD, R0, R7),
1846 			BPF_ALU64_REG(BPF_ADD, R0, R8),
1847 			BPF_ALU64_REG(BPF_ADD, R0, R9),
1848 			BPF_ALU64_IMM(BPF_ADD, R0, 0xfefe),
1849 			BPF_EXIT_INSN(),
1850 		},
1851 		INTERNAL,
1852 		{ },
1853 		{ { 0, 0xfefe } }
1854 	},
1855 	{	/* Mainly checking JIT here. */
1856 		"LD IMM64",
1857 		.u.insns_int = {
1858 			BPF_LD_IMM64(R0, 0xffffffffffffffffLL),
1859 			BPF_MOV64_REG(R1, R0),
1860 			BPF_MOV64_REG(R2, R1),
1861 			BPF_MOV64_REG(R3, R2),
1862 			BPF_MOV64_REG(R4, R3),
1863 			BPF_MOV64_REG(R5, R4),
1864 			BPF_MOV64_REG(R6, R5),
1865 			BPF_MOV64_REG(R7, R6),
1866 			BPF_MOV64_REG(R8, R7),
1867 			BPF_MOV64_REG(R9, R8),
1868 			BPF_LD_IMM64(R0, 0x0LL),
1869 			BPF_LD_IMM64(R1, 0x0LL),
1870 			BPF_LD_IMM64(R2, 0x0LL),
1871 			BPF_LD_IMM64(R3, 0x0LL),
1872 			BPF_LD_IMM64(R4, 0x0LL),
1873 			BPF_LD_IMM64(R5, 0x0LL),
1874 			BPF_LD_IMM64(R6, 0x0LL),
1875 			BPF_LD_IMM64(R7, 0x0LL),
1876 			BPF_LD_IMM64(R8, 0x0LL),
1877 			BPF_LD_IMM64(R9, 0x0LL),
1878 			BPF_ALU64_REG(BPF_ADD, R0, R0),
1879 			BPF_ALU64_REG(BPF_ADD, R0, R1),
1880 			BPF_ALU64_REG(BPF_ADD, R0, R2),
1881 			BPF_ALU64_REG(BPF_ADD, R0, R3),
1882 			BPF_ALU64_REG(BPF_ADD, R0, R4),
1883 			BPF_ALU64_REG(BPF_ADD, R0, R5),
1884 			BPF_ALU64_REG(BPF_ADD, R0, R6),
1885 			BPF_ALU64_REG(BPF_ADD, R0, R7),
1886 			BPF_ALU64_REG(BPF_ADD, R0, R8),
1887 			BPF_ALU64_REG(BPF_ADD, R0, R9),
1888 			BPF_ALU64_IMM(BPF_ADD, R0, 0xfefe),
1889 			BPF_EXIT_INSN(),
1890 		},
1891 		INTERNAL,
1892 		{ },
1893 		{ { 0, 0xfefe } }
1894 	},
1895 	{
1896 		"INT: ALU MIX",
1897 		.u.insns_int = {
1898 			BPF_ALU64_IMM(BPF_MOV, R0, 11),
1899 			BPF_ALU64_IMM(BPF_ADD, R0, -1),
1900 			BPF_ALU64_IMM(BPF_MOV, R2, 2),
1901 			BPF_ALU64_IMM(BPF_XOR, R2, 3),
1902 			BPF_ALU64_REG(BPF_DIV, R0, R2),
1903 			BPF_JMP_IMM(BPF_JEQ, R0, 10, 1),
1904 			BPF_EXIT_INSN(),
1905 			BPF_ALU64_IMM(BPF_MOD, R0, 3),
1906 			BPF_JMP_IMM(BPF_JEQ, R0, 1, 1),
1907 			BPF_EXIT_INSN(),
1908 			BPF_ALU64_IMM(BPF_MOV, R0, -1),
1909 			BPF_EXIT_INSN(),
1910 		},
1911 		INTERNAL,
1912 		{ },
1913 		{ { 0, -1 } }
1914 	},
1915 	{
1916 		"INT: shifts by register",
1917 		.u.insns_int = {
1918 			BPF_MOV64_IMM(R0, -1234),
1919 			BPF_MOV64_IMM(R1, 1),
1920 			BPF_ALU32_REG(BPF_RSH, R0, R1),
1921 			BPF_JMP_IMM(BPF_JEQ, R0, 0x7ffffd97, 1),
1922 			BPF_EXIT_INSN(),
1923 			BPF_MOV64_IMM(R2, 1),
1924 			BPF_ALU64_REG(BPF_LSH, R0, R2),
1925 			BPF_MOV32_IMM(R4, -1234),
1926 			BPF_JMP_REG(BPF_JEQ, R0, R4, 1),
1927 			BPF_EXIT_INSN(),
1928 			BPF_ALU64_IMM(BPF_AND, R4, 63),
1929 			BPF_ALU64_REG(BPF_LSH, R0, R4), /* R0 <= 46 */
1930 			BPF_MOV64_IMM(R3, 47),
1931 			BPF_ALU64_REG(BPF_ARSH, R0, R3),
1932 			BPF_JMP_IMM(BPF_JEQ, R0, -617, 1),
1933 			BPF_EXIT_INSN(),
1934 			BPF_MOV64_IMM(R2, 1),
1935 			BPF_ALU64_REG(BPF_LSH, R4, R2), /* R4 = 46 << 1 */
1936 			BPF_JMP_IMM(BPF_JEQ, R4, 92, 1),
1937 			BPF_EXIT_INSN(),
1938 			BPF_MOV64_IMM(R4, 4),
1939 			BPF_ALU64_REG(BPF_LSH, R4, R4), /* R4 = 4 << 4 */
1940 			BPF_JMP_IMM(BPF_JEQ, R4, 64, 1),
1941 			BPF_EXIT_INSN(),
1942 			BPF_MOV64_IMM(R4, 5),
1943 			BPF_ALU32_REG(BPF_LSH, R4, R4), /* R4 = 5 << 5 */
1944 			BPF_JMP_IMM(BPF_JEQ, R4, 160, 1),
1945 			BPF_EXIT_INSN(),
1946 			BPF_MOV64_IMM(R0, -1),
1947 			BPF_EXIT_INSN(),
1948 		},
1949 		INTERNAL,
1950 		{ },
1951 		{ { 0, -1 } }
1952 	},
1953 	{
1954 		"INT: DIV + ABS",
1955 		.u.insns_int = {
1956 			BPF_ALU64_REG(BPF_MOV, R6, R1),
1957 			BPF_LD_ABS(BPF_B, 3),
1958 			BPF_ALU64_IMM(BPF_MOV, R2, 2),
1959 			BPF_ALU32_REG(BPF_DIV, R0, R2),
1960 			BPF_ALU64_REG(BPF_MOV, R8, R0),
1961 			BPF_LD_ABS(BPF_B, 4),
1962 			BPF_ALU64_REG(BPF_ADD, R8, R0),
1963 			BPF_LD_IND(BPF_B, R8, -70),
1964 			BPF_EXIT_INSN(),
1965 		},
1966 		INTERNAL,
1967 		{ 10, 20, 30, 40, 50 },
1968 		{ { 4, 0 }, { 5, 10 } }
1969 	},
1970 	{
1971 		"INT: DIV by zero",
1972 		.u.insns_int = {
1973 			BPF_ALU64_REG(BPF_MOV, R6, R1),
1974 			BPF_ALU64_IMM(BPF_MOV, R7, 0),
1975 			BPF_LD_ABS(BPF_B, 3),
1976 			BPF_ALU32_REG(BPF_DIV, R0, R7),
1977 			BPF_EXIT_INSN(),
1978 		},
1979 		INTERNAL,
1980 		{ 10, 20, 30, 40, 50 },
1981 		{ { 3, 0 }, { 4, 0 } }
1982 	},
1983 	{
1984 		"check: missing ret",
1985 		.u.insns = {
1986 			BPF_STMT(BPF_LD | BPF_IMM, 1),
1987 		},
1988 		CLASSIC | FLAG_NO_DATA | FLAG_EXPECTED_FAIL,
1989 		{ },
1990 		{ }
1991 	},
1992 	{
1993 		"check: div_k_0",
1994 		.u.insns = {
1995 			BPF_STMT(BPF_ALU | BPF_DIV | BPF_K, 0),
1996 			BPF_STMT(BPF_RET | BPF_K, 0)
1997 		},
1998 		CLASSIC | FLAG_NO_DATA | FLAG_EXPECTED_FAIL,
1999 		{ },
2000 		{ }
2001 	},
2002 	{
2003 		"check: unknown insn",
2004 		.u.insns = {
2005 			/* seccomp insn, rejected in socket filter */
2006 			BPF_STMT(BPF_LDX | BPF_W | BPF_ABS, 0),
2007 			BPF_STMT(BPF_RET | BPF_K, 0)
2008 		},
2009 		CLASSIC | FLAG_EXPECTED_FAIL,
2010 		{ },
2011 		{ }
2012 	},
2013 	{
2014 		"check: out of range spill/fill",
2015 		.u.insns = {
2016 			BPF_STMT(BPF_STX, 16),
2017 			BPF_STMT(BPF_RET | BPF_K, 0)
2018 		},
2019 		CLASSIC | FLAG_NO_DATA | FLAG_EXPECTED_FAIL,
2020 		{ },
2021 		{ }
2022 	},
2023 	{
2024 		"JUMPS + HOLES",
2025 		.u.insns = {
2026 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2027 			BPF_JUMP(BPF_JMP | BPF_JGE, 0, 13, 15),
2028 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2029 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2030 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2031 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2032 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2033 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2034 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2035 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2036 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2037 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2038 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2039 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2040 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2041 			BPF_JUMP(BPF_JMP | BPF_JEQ, 0x90c2894d, 3, 4),
2042 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2043 			BPF_JUMP(BPF_JMP | BPF_JEQ, 0x90c2894d, 1, 2),
2044 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2045 			BPF_JUMP(BPF_JMP | BPF_JGE, 0, 14, 15),
2046 			BPF_JUMP(BPF_JMP | BPF_JGE, 0, 13, 14),
2047 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2048 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2049 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2050 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2051 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2052 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2053 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2054 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2055 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2056 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2057 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2058 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2059 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2060 			BPF_JUMP(BPF_JMP | BPF_JEQ, 0x2ac28349, 2, 3),
2061 			BPF_JUMP(BPF_JMP | BPF_JEQ, 0x2ac28349, 1, 2),
2062 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2063 			BPF_JUMP(BPF_JMP | BPF_JGE, 0, 14, 15),
2064 			BPF_JUMP(BPF_JMP | BPF_JGE, 0, 13, 14),
2065 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2066 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2067 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2068 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2069 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2070 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2071 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2072 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2073 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2074 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2075 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2076 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2077 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2078 			BPF_JUMP(BPF_JMP | BPF_JEQ, 0x90d2ff41, 2, 3),
2079 			BPF_JUMP(BPF_JMP | BPF_JEQ, 0x90d2ff41, 1, 2),
2080 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
2081 			BPF_STMT(BPF_RET | BPF_A, 0),
2082 			BPF_STMT(BPF_RET | BPF_A, 0),
2083 		},
2084 		CLASSIC,
2085 		{ 0x00, 0x1b, 0x21, 0x3c, 0x9d, 0xf8,
2086 		  0x90, 0xe2, 0xba, 0x0a, 0x56, 0xb4,
2087 		  0x08, 0x00,
2088 		  0x45, 0x00, 0x00, 0x28, 0x00, 0x00,
2089 		  0x20, 0x00, 0x40, 0x11, 0x00, 0x00, /* IP header */
2090 		  0xc0, 0xa8, 0x33, 0x01,
2091 		  0xc0, 0xa8, 0x33, 0x02,
2092 		  0xbb, 0xb6,
2093 		  0xa9, 0xfa,
2094 		  0x00, 0x14, 0x00, 0x00,
2095 		  0xcc, 0xcc, 0xcc, 0xcc, 0xcc, 0xcc,
2096 		  0xcc, 0xcc, 0xcc, 0xcc, 0xcc, 0xcc,
2097 		  0xcc, 0xcc, 0xcc, 0xcc, 0xcc, 0xcc,
2098 		  0xcc, 0xcc, 0xcc, 0xcc, 0xcc, 0xcc,
2099 		  0xcc, 0xcc, 0xcc, 0xcc, 0xcc, 0xcc,
2100 		  0xcc, 0xcc, 0xcc, 0xcc, 0xcc, 0xcc,
2101 		  0xcc, 0xcc, 0xcc, 0xcc, 0xcc, 0xcc,
2102 		  0xcc, 0xcc, 0xcc, 0xcc },
2103 		{ { 88, 0x001b } }
2104 	},
2105 	{
2106 		"check: RET X",
2107 		.u.insns = {
2108 			BPF_STMT(BPF_RET | BPF_X, 0),
2109 		},
2110 		CLASSIC | FLAG_NO_DATA | FLAG_EXPECTED_FAIL,
2111 		{ },
2112 		{ },
2113 	},
2114 	{
2115 		"check: LDX + RET X",
2116 		.u.insns = {
2117 			BPF_STMT(BPF_LDX | BPF_IMM, 42),
2118 			BPF_STMT(BPF_RET | BPF_X, 0),
2119 		},
2120 		CLASSIC | FLAG_NO_DATA | FLAG_EXPECTED_FAIL,
2121 		{ },
2122 		{ },
2123 	},
2124 	{	/* Mainly checking JIT here. */
2125 		"M[]: alt STX + LDX",
2126 		.u.insns = {
2127 			BPF_STMT(BPF_LDX | BPF_IMM, 100),
2128 			BPF_STMT(BPF_STX, 0),
2129 			BPF_STMT(BPF_LDX | BPF_MEM, 0),
2130 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2131 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2132 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2133 			BPF_STMT(BPF_STX, 1),
2134 			BPF_STMT(BPF_LDX | BPF_MEM, 1),
2135 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2136 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2137 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2138 			BPF_STMT(BPF_STX, 2),
2139 			BPF_STMT(BPF_LDX | BPF_MEM, 2),
2140 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2141 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2142 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2143 			BPF_STMT(BPF_STX, 3),
2144 			BPF_STMT(BPF_LDX | BPF_MEM, 3),
2145 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2146 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2147 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2148 			BPF_STMT(BPF_STX, 4),
2149 			BPF_STMT(BPF_LDX | BPF_MEM, 4),
2150 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2151 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2152 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2153 			BPF_STMT(BPF_STX, 5),
2154 			BPF_STMT(BPF_LDX | BPF_MEM, 5),
2155 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2156 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2157 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2158 			BPF_STMT(BPF_STX, 6),
2159 			BPF_STMT(BPF_LDX | BPF_MEM, 6),
2160 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2161 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2162 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2163 			BPF_STMT(BPF_STX, 7),
2164 			BPF_STMT(BPF_LDX | BPF_MEM, 7),
2165 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2166 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2167 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2168 			BPF_STMT(BPF_STX, 8),
2169 			BPF_STMT(BPF_LDX | BPF_MEM, 8),
2170 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2171 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2172 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2173 			BPF_STMT(BPF_STX, 9),
2174 			BPF_STMT(BPF_LDX | BPF_MEM, 9),
2175 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2176 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2177 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2178 			BPF_STMT(BPF_STX, 10),
2179 			BPF_STMT(BPF_LDX | BPF_MEM, 10),
2180 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2181 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2182 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2183 			BPF_STMT(BPF_STX, 11),
2184 			BPF_STMT(BPF_LDX | BPF_MEM, 11),
2185 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2186 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2187 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2188 			BPF_STMT(BPF_STX, 12),
2189 			BPF_STMT(BPF_LDX | BPF_MEM, 12),
2190 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2191 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2192 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2193 			BPF_STMT(BPF_STX, 13),
2194 			BPF_STMT(BPF_LDX | BPF_MEM, 13),
2195 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2196 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2197 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2198 			BPF_STMT(BPF_STX, 14),
2199 			BPF_STMT(BPF_LDX | BPF_MEM, 14),
2200 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2201 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2202 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2203 			BPF_STMT(BPF_STX, 15),
2204 			BPF_STMT(BPF_LDX | BPF_MEM, 15),
2205 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2206 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
2207 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
2208 			BPF_STMT(BPF_RET | BPF_A, 0),
2209 		},
2210 		CLASSIC | FLAG_NO_DATA,
2211 		{ },
2212 		{ { 0, 116 } },
2213 	},
2214 	{	/* Mainly checking JIT here. */
2215 		"M[]: full STX + full LDX",
2216 		.u.insns = {
2217 			BPF_STMT(BPF_LDX | BPF_IMM, 0xbadfeedb),
2218 			BPF_STMT(BPF_STX, 0),
2219 			BPF_STMT(BPF_LDX | BPF_IMM, 0xecabedae),
2220 			BPF_STMT(BPF_STX, 1),
2221 			BPF_STMT(BPF_LDX | BPF_IMM, 0xafccfeaf),
2222 			BPF_STMT(BPF_STX, 2),
2223 			BPF_STMT(BPF_LDX | BPF_IMM, 0xbffdcedc),
2224 			BPF_STMT(BPF_STX, 3),
2225 			BPF_STMT(BPF_LDX | BPF_IMM, 0xfbbbdccb),
2226 			BPF_STMT(BPF_STX, 4),
2227 			BPF_STMT(BPF_LDX | BPF_IMM, 0xfbabcbda),
2228 			BPF_STMT(BPF_STX, 5),
2229 			BPF_STMT(BPF_LDX | BPF_IMM, 0xaedecbdb),
2230 			BPF_STMT(BPF_STX, 6),
2231 			BPF_STMT(BPF_LDX | BPF_IMM, 0xadebbade),
2232 			BPF_STMT(BPF_STX, 7),
2233 			BPF_STMT(BPF_LDX | BPF_IMM, 0xfcfcfaec),
2234 			BPF_STMT(BPF_STX, 8),
2235 			BPF_STMT(BPF_LDX | BPF_IMM, 0xbcdddbdc),
2236 			BPF_STMT(BPF_STX, 9),
2237 			BPF_STMT(BPF_LDX | BPF_IMM, 0xfeefdfac),
2238 			BPF_STMT(BPF_STX, 10),
2239 			BPF_STMT(BPF_LDX | BPF_IMM, 0xcddcdeea),
2240 			BPF_STMT(BPF_STX, 11),
2241 			BPF_STMT(BPF_LDX | BPF_IMM, 0xaccfaebb),
2242 			BPF_STMT(BPF_STX, 12),
2243 			BPF_STMT(BPF_LDX | BPF_IMM, 0xbdcccdcf),
2244 			BPF_STMT(BPF_STX, 13),
2245 			BPF_STMT(BPF_LDX | BPF_IMM, 0xaaedecde),
2246 			BPF_STMT(BPF_STX, 14),
2247 			BPF_STMT(BPF_LDX | BPF_IMM, 0xfaeacdad),
2248 			BPF_STMT(BPF_STX, 15),
2249 			BPF_STMT(BPF_LDX | BPF_MEM, 0),
2250 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
2251 			BPF_STMT(BPF_LDX | BPF_MEM, 1),
2252 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
2253 			BPF_STMT(BPF_LDX | BPF_MEM, 2),
2254 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
2255 			BPF_STMT(BPF_LDX | BPF_MEM, 3),
2256 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
2257 			BPF_STMT(BPF_LDX | BPF_MEM, 4),
2258 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
2259 			BPF_STMT(BPF_LDX | BPF_MEM, 5),
2260 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
2261 			BPF_STMT(BPF_LDX | BPF_MEM, 6),
2262 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
2263 			BPF_STMT(BPF_LDX | BPF_MEM, 7),
2264 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
2265 			BPF_STMT(BPF_LDX | BPF_MEM, 8),
2266 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
2267 			BPF_STMT(BPF_LDX | BPF_MEM, 9),
2268 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
2269 			BPF_STMT(BPF_LDX | BPF_MEM, 10),
2270 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
2271 			BPF_STMT(BPF_LDX | BPF_MEM, 11),
2272 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
2273 			BPF_STMT(BPF_LDX | BPF_MEM, 12),
2274 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
2275 			BPF_STMT(BPF_LDX | BPF_MEM, 13),
2276 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
2277 			BPF_STMT(BPF_LDX | BPF_MEM, 14),
2278 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
2279 			BPF_STMT(BPF_LDX | BPF_MEM, 15),
2280 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
2281 			BPF_STMT(BPF_RET | BPF_A, 0),
2282 		},
2283 		CLASSIC | FLAG_NO_DATA,
2284 		{ },
2285 		{ { 0, 0x2a5a5e5 } },
2286 	},
2287 	{
2288 		"check: SKF_AD_MAX",
2289 		.u.insns = {
2290 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
2291 				 SKF_AD_OFF + SKF_AD_MAX),
2292 			BPF_STMT(BPF_RET | BPF_A, 0),
2293 		},
2294 		CLASSIC | FLAG_NO_DATA | FLAG_EXPECTED_FAIL,
2295 		{ },
2296 		{ },
2297 	},
2298 	{	/* Passes checker but fails during runtime. */
2299 		"LD [SKF_AD_OFF-1]",
2300 		.u.insns = {
2301 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
2302 				 SKF_AD_OFF - 1),
2303 			BPF_STMT(BPF_RET | BPF_K, 1),
2304 		},
2305 		CLASSIC,
2306 		{ },
2307 		{ { 1, 0 } },
2308 	},
2309 	{
2310 		"load 64-bit immediate",
2311 		.u.insns_int = {
2312 			BPF_LD_IMM64(R1, 0x567800001234LL),
2313 			BPF_MOV64_REG(R2, R1),
2314 			BPF_MOV64_REG(R3, R2),
2315 			BPF_ALU64_IMM(BPF_RSH, R2, 32),
2316 			BPF_ALU64_IMM(BPF_LSH, R3, 32),
2317 			BPF_ALU64_IMM(BPF_RSH, R3, 32),
2318 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
2319 			BPF_JMP_IMM(BPF_JEQ, R2, 0x5678, 1),
2320 			BPF_EXIT_INSN(),
2321 			BPF_JMP_IMM(BPF_JEQ, R3, 0x1234, 1),
2322 			BPF_EXIT_INSN(),
2323 			BPF_LD_IMM64(R0, 0x1ffffffffLL),
2324 			BPF_ALU64_IMM(BPF_RSH, R0, 32), /* R0 = 1 */
2325 			BPF_EXIT_INSN(),
2326 		},
2327 		INTERNAL,
2328 		{ },
2329 		{ { 0, 1 } }
2330 	},
2331 	{
2332 		"nmap reduced",
2333 		.u.insns_int = {
2334 			BPF_MOV64_REG(R6, R1),
2335 			BPF_LD_ABS(BPF_H, 12),
2336 			BPF_JMP_IMM(BPF_JNE, R0, 0x806, 28),
2337 			BPF_LD_ABS(BPF_H, 12),
2338 			BPF_JMP_IMM(BPF_JNE, R0, 0x806, 26),
2339 			BPF_MOV32_IMM(R0, 18),
2340 			BPF_STX_MEM(BPF_W, R10, R0, -64),
2341 			BPF_LDX_MEM(BPF_W, R7, R10, -64),
2342 			BPF_LD_IND(BPF_W, R7, 14),
2343 			BPF_STX_MEM(BPF_W, R10, R0, -60),
2344 			BPF_MOV32_IMM(R0, 280971478),
2345 			BPF_STX_MEM(BPF_W, R10, R0, -56),
2346 			BPF_LDX_MEM(BPF_W, R7, R10, -56),
2347 			BPF_LDX_MEM(BPF_W, R0, R10, -60),
2348 			BPF_ALU32_REG(BPF_SUB, R0, R7),
2349 			BPF_JMP_IMM(BPF_JNE, R0, 0, 15),
2350 			BPF_LD_ABS(BPF_H, 12),
2351 			BPF_JMP_IMM(BPF_JNE, R0, 0x806, 13),
2352 			BPF_MOV32_IMM(R0, 22),
2353 			BPF_STX_MEM(BPF_W, R10, R0, -56),
2354 			BPF_LDX_MEM(BPF_W, R7, R10, -56),
2355 			BPF_LD_IND(BPF_H, R7, 14),
2356 			BPF_STX_MEM(BPF_W, R10, R0, -52),
2357 			BPF_MOV32_IMM(R0, 17366),
2358 			BPF_STX_MEM(BPF_W, R10, R0, -48),
2359 			BPF_LDX_MEM(BPF_W, R7, R10, -48),
2360 			BPF_LDX_MEM(BPF_W, R0, R10, -52),
2361 			BPF_ALU32_REG(BPF_SUB, R0, R7),
2362 			BPF_JMP_IMM(BPF_JNE, R0, 0, 2),
2363 			BPF_MOV32_IMM(R0, 256),
2364 			BPF_EXIT_INSN(),
2365 			BPF_MOV32_IMM(R0, 0),
2366 			BPF_EXIT_INSN(),
2367 		},
2368 		INTERNAL,
2369 		{ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0x08, 0x06, 0, 0,
2370 		  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
2371 		  0x10, 0xbf, 0x48, 0xd6, 0x43, 0xd6},
2372 		{ { 38, 256 } },
2373 		.stack_depth = 64,
2374 	},
2375 	/* BPF_ALU | BPF_MOV | BPF_X */
2376 	{
2377 		"ALU_MOV_X: dst = 2",
2378 		.u.insns_int = {
2379 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
2380 			BPF_ALU32_REG(BPF_MOV, R0, R1),
2381 			BPF_EXIT_INSN(),
2382 		},
2383 		INTERNAL,
2384 		{ },
2385 		{ { 0, 2 } },
2386 	},
2387 	{
2388 		"ALU_MOV_X: dst = 4294967295",
2389 		.u.insns_int = {
2390 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967295U),
2391 			BPF_ALU32_REG(BPF_MOV, R0, R1),
2392 			BPF_EXIT_INSN(),
2393 		},
2394 		INTERNAL,
2395 		{ },
2396 		{ { 0, 4294967295U } },
2397 	},
2398 	{
2399 		"ALU64_MOV_X: dst = 2",
2400 		.u.insns_int = {
2401 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
2402 			BPF_ALU64_REG(BPF_MOV, R0, R1),
2403 			BPF_EXIT_INSN(),
2404 		},
2405 		INTERNAL,
2406 		{ },
2407 		{ { 0, 2 } },
2408 	},
2409 	{
2410 		"ALU64_MOV_X: dst = 4294967295",
2411 		.u.insns_int = {
2412 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967295U),
2413 			BPF_ALU64_REG(BPF_MOV, R0, R1),
2414 			BPF_EXIT_INSN(),
2415 		},
2416 		INTERNAL,
2417 		{ },
2418 		{ { 0, 4294967295U } },
2419 	},
2420 	/* BPF_ALU | BPF_MOV | BPF_K */
2421 	{
2422 		"ALU_MOV_K: dst = 2",
2423 		.u.insns_int = {
2424 			BPF_ALU32_IMM(BPF_MOV, R0, 2),
2425 			BPF_EXIT_INSN(),
2426 		},
2427 		INTERNAL,
2428 		{ },
2429 		{ { 0, 2 } },
2430 	},
2431 	{
2432 		"ALU_MOV_K: dst = 4294967295",
2433 		.u.insns_int = {
2434 			BPF_ALU32_IMM(BPF_MOV, R0, 4294967295U),
2435 			BPF_EXIT_INSN(),
2436 		},
2437 		INTERNAL,
2438 		{ },
2439 		{ { 0, 4294967295U } },
2440 	},
2441 	{
2442 		"ALU_MOV_K: 0x0000ffffffff0000 = 0x00000000ffffffff",
2443 		.u.insns_int = {
2444 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
2445 			BPF_LD_IMM64(R3, 0x00000000ffffffffLL),
2446 			BPF_ALU32_IMM(BPF_MOV, R2, 0xffffffff),
2447 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
2448 			BPF_MOV32_IMM(R0, 2),
2449 			BPF_EXIT_INSN(),
2450 			BPF_MOV32_IMM(R0, 1),
2451 			BPF_EXIT_INSN(),
2452 		},
2453 		INTERNAL,
2454 		{ },
2455 		{ { 0, 0x1 } },
2456 	},
2457 	{
2458 		"ALU64_MOV_K: dst = 2",
2459 		.u.insns_int = {
2460 			BPF_ALU64_IMM(BPF_MOV, R0, 2),
2461 			BPF_EXIT_INSN(),
2462 		},
2463 		INTERNAL,
2464 		{ },
2465 		{ { 0, 2 } },
2466 	},
2467 	{
2468 		"ALU64_MOV_K: dst = 2147483647",
2469 		.u.insns_int = {
2470 			BPF_ALU64_IMM(BPF_MOV, R0, 2147483647),
2471 			BPF_EXIT_INSN(),
2472 		},
2473 		INTERNAL,
2474 		{ },
2475 		{ { 0, 2147483647 } },
2476 	},
2477 	{
2478 		"ALU64_OR_K: dst = 0x0",
2479 		.u.insns_int = {
2480 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
2481 			BPF_LD_IMM64(R3, 0x0),
2482 			BPF_ALU64_IMM(BPF_MOV, R2, 0x0),
2483 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
2484 			BPF_MOV32_IMM(R0, 2),
2485 			BPF_EXIT_INSN(),
2486 			BPF_MOV32_IMM(R0, 1),
2487 			BPF_EXIT_INSN(),
2488 		},
2489 		INTERNAL,
2490 		{ },
2491 		{ { 0, 0x1 } },
2492 	},
2493 	{
2494 		"ALU64_MOV_K: dst = -1",
2495 		.u.insns_int = {
2496 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
2497 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
2498 			BPF_ALU64_IMM(BPF_MOV, R2, 0xffffffff),
2499 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
2500 			BPF_MOV32_IMM(R0, 2),
2501 			BPF_EXIT_INSN(),
2502 			BPF_MOV32_IMM(R0, 1),
2503 			BPF_EXIT_INSN(),
2504 		},
2505 		INTERNAL,
2506 		{ },
2507 		{ { 0, 0x1 } },
2508 	},
2509 	/* BPF_ALU | BPF_ADD | BPF_X */
2510 	{
2511 		"ALU_ADD_X: 1 + 2 = 3",
2512 		.u.insns_int = {
2513 			BPF_LD_IMM64(R0, 1),
2514 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
2515 			BPF_ALU32_REG(BPF_ADD, R0, R1),
2516 			BPF_EXIT_INSN(),
2517 		},
2518 		INTERNAL,
2519 		{ },
2520 		{ { 0, 3 } },
2521 	},
2522 	{
2523 		"ALU_ADD_X: 1 + 4294967294 = 4294967295",
2524 		.u.insns_int = {
2525 			BPF_LD_IMM64(R0, 1),
2526 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967294U),
2527 			BPF_ALU32_REG(BPF_ADD, R0, R1),
2528 			BPF_EXIT_INSN(),
2529 		},
2530 		INTERNAL,
2531 		{ },
2532 		{ { 0, 4294967295U } },
2533 	},
2534 	{
2535 		"ALU_ADD_X: 2 + 4294967294 = 0",
2536 		.u.insns_int = {
2537 			BPF_LD_IMM64(R0, 2),
2538 			BPF_LD_IMM64(R1, 4294967294U),
2539 			BPF_ALU32_REG(BPF_ADD, R0, R1),
2540 			BPF_JMP_IMM(BPF_JEQ, R0, 0, 2),
2541 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
2542 			BPF_EXIT_INSN(),
2543 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
2544 			BPF_EXIT_INSN(),
2545 		},
2546 		INTERNAL,
2547 		{ },
2548 		{ { 0, 1 } },
2549 	},
2550 	{
2551 		"ALU64_ADD_X: 1 + 2 = 3",
2552 		.u.insns_int = {
2553 			BPF_LD_IMM64(R0, 1),
2554 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
2555 			BPF_ALU64_REG(BPF_ADD, R0, R1),
2556 			BPF_EXIT_INSN(),
2557 		},
2558 		INTERNAL,
2559 		{ },
2560 		{ { 0, 3 } },
2561 	},
2562 	{
2563 		"ALU64_ADD_X: 1 + 4294967294 = 4294967295",
2564 		.u.insns_int = {
2565 			BPF_LD_IMM64(R0, 1),
2566 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967294U),
2567 			BPF_ALU64_REG(BPF_ADD, R0, R1),
2568 			BPF_EXIT_INSN(),
2569 		},
2570 		INTERNAL,
2571 		{ },
2572 		{ { 0, 4294967295U } },
2573 	},
2574 	{
2575 		"ALU64_ADD_X: 2 + 4294967294 = 4294967296",
2576 		.u.insns_int = {
2577 			BPF_LD_IMM64(R0, 2),
2578 			BPF_LD_IMM64(R1, 4294967294U),
2579 			BPF_LD_IMM64(R2, 4294967296ULL),
2580 			BPF_ALU64_REG(BPF_ADD, R0, R1),
2581 			BPF_JMP_REG(BPF_JEQ, R0, R2, 2),
2582 			BPF_MOV32_IMM(R0, 0),
2583 			BPF_EXIT_INSN(),
2584 			BPF_MOV32_IMM(R0, 1),
2585 			BPF_EXIT_INSN(),
2586 		},
2587 		INTERNAL,
2588 		{ },
2589 		{ { 0, 1 } },
2590 	},
2591 	/* BPF_ALU | BPF_ADD | BPF_K */
2592 	{
2593 		"ALU_ADD_K: 1 + 2 = 3",
2594 		.u.insns_int = {
2595 			BPF_LD_IMM64(R0, 1),
2596 			BPF_ALU32_IMM(BPF_ADD, R0, 2),
2597 			BPF_EXIT_INSN(),
2598 		},
2599 		INTERNAL,
2600 		{ },
2601 		{ { 0, 3 } },
2602 	},
2603 	{
2604 		"ALU_ADD_K: 3 + 0 = 3",
2605 		.u.insns_int = {
2606 			BPF_LD_IMM64(R0, 3),
2607 			BPF_ALU32_IMM(BPF_ADD, R0, 0),
2608 			BPF_EXIT_INSN(),
2609 		},
2610 		INTERNAL,
2611 		{ },
2612 		{ { 0, 3 } },
2613 	},
2614 	{
2615 		"ALU_ADD_K: 1 + 4294967294 = 4294967295",
2616 		.u.insns_int = {
2617 			BPF_LD_IMM64(R0, 1),
2618 			BPF_ALU32_IMM(BPF_ADD, R0, 4294967294U),
2619 			BPF_EXIT_INSN(),
2620 		},
2621 		INTERNAL,
2622 		{ },
2623 		{ { 0, 4294967295U } },
2624 	},
2625 	{
2626 		"ALU_ADD_K: 4294967294 + 2 = 0",
2627 		.u.insns_int = {
2628 			BPF_LD_IMM64(R0, 4294967294U),
2629 			BPF_ALU32_IMM(BPF_ADD, R0, 2),
2630 			BPF_JMP_IMM(BPF_JEQ, R0, 0, 2),
2631 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
2632 			BPF_EXIT_INSN(),
2633 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
2634 			BPF_EXIT_INSN(),
2635 		},
2636 		INTERNAL,
2637 		{ },
2638 		{ { 0, 1 } },
2639 	},
2640 	{
2641 		"ALU_ADD_K: 0 + (-1) = 0x00000000ffffffff",
2642 		.u.insns_int = {
2643 			BPF_LD_IMM64(R2, 0x0),
2644 			BPF_LD_IMM64(R3, 0x00000000ffffffff),
2645 			BPF_ALU32_IMM(BPF_ADD, R2, 0xffffffff),
2646 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
2647 			BPF_MOV32_IMM(R0, 2),
2648 			BPF_EXIT_INSN(),
2649 			BPF_MOV32_IMM(R0, 1),
2650 			BPF_EXIT_INSN(),
2651 		},
2652 		INTERNAL,
2653 		{ },
2654 		{ { 0, 0x1 } },
2655 	},
2656 	{
2657 		"ALU_ADD_K: 0 + 0xffff = 0xffff",
2658 		.u.insns_int = {
2659 			BPF_LD_IMM64(R2, 0x0),
2660 			BPF_LD_IMM64(R3, 0xffff),
2661 			BPF_ALU32_IMM(BPF_ADD, R2, 0xffff),
2662 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
2663 			BPF_MOV32_IMM(R0, 2),
2664 			BPF_EXIT_INSN(),
2665 			BPF_MOV32_IMM(R0, 1),
2666 			BPF_EXIT_INSN(),
2667 		},
2668 		INTERNAL,
2669 		{ },
2670 		{ { 0, 0x1 } },
2671 	},
2672 	{
2673 		"ALU_ADD_K: 0 + 0x7fffffff = 0x7fffffff",
2674 		.u.insns_int = {
2675 			BPF_LD_IMM64(R2, 0x0),
2676 			BPF_LD_IMM64(R3, 0x7fffffff),
2677 			BPF_ALU32_IMM(BPF_ADD, R2, 0x7fffffff),
2678 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
2679 			BPF_MOV32_IMM(R0, 2),
2680 			BPF_EXIT_INSN(),
2681 			BPF_MOV32_IMM(R0, 1),
2682 			BPF_EXIT_INSN(),
2683 		},
2684 		INTERNAL,
2685 		{ },
2686 		{ { 0, 0x1 } },
2687 	},
2688 	{
2689 		"ALU_ADD_K: 0 + 0x80000000 = 0x80000000",
2690 		.u.insns_int = {
2691 			BPF_LD_IMM64(R2, 0x0),
2692 			BPF_LD_IMM64(R3, 0x80000000),
2693 			BPF_ALU32_IMM(BPF_ADD, R2, 0x80000000),
2694 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
2695 			BPF_MOV32_IMM(R0, 2),
2696 			BPF_EXIT_INSN(),
2697 			BPF_MOV32_IMM(R0, 1),
2698 			BPF_EXIT_INSN(),
2699 		},
2700 		INTERNAL,
2701 		{ },
2702 		{ { 0, 0x1 } },
2703 	},
2704 	{
2705 		"ALU_ADD_K: 0 + 0x80008000 = 0x80008000",
2706 		.u.insns_int = {
2707 			BPF_LD_IMM64(R2, 0x0),
2708 			BPF_LD_IMM64(R3, 0x80008000),
2709 			BPF_ALU32_IMM(BPF_ADD, R2, 0x80008000),
2710 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
2711 			BPF_MOV32_IMM(R0, 2),
2712 			BPF_EXIT_INSN(),
2713 			BPF_MOV32_IMM(R0, 1),
2714 			BPF_EXIT_INSN(),
2715 		},
2716 		INTERNAL,
2717 		{ },
2718 		{ { 0, 0x1 } },
2719 	},
2720 	{
2721 		"ALU64_ADD_K: 1 + 2 = 3",
2722 		.u.insns_int = {
2723 			BPF_LD_IMM64(R0, 1),
2724 			BPF_ALU64_IMM(BPF_ADD, R0, 2),
2725 			BPF_EXIT_INSN(),
2726 		},
2727 		INTERNAL,
2728 		{ },
2729 		{ { 0, 3 } },
2730 	},
2731 	{
2732 		"ALU64_ADD_K: 3 + 0 = 3",
2733 		.u.insns_int = {
2734 			BPF_LD_IMM64(R0, 3),
2735 			BPF_ALU64_IMM(BPF_ADD, R0, 0),
2736 			BPF_EXIT_INSN(),
2737 		},
2738 		INTERNAL,
2739 		{ },
2740 		{ { 0, 3 } },
2741 	},
2742 	{
2743 		"ALU64_ADD_K: 1 + 2147483646 = 2147483647",
2744 		.u.insns_int = {
2745 			BPF_LD_IMM64(R0, 1),
2746 			BPF_ALU64_IMM(BPF_ADD, R0, 2147483646),
2747 			BPF_EXIT_INSN(),
2748 		},
2749 		INTERNAL,
2750 		{ },
2751 		{ { 0, 2147483647 } },
2752 	},
2753 	{
2754 		"ALU64_ADD_K: 4294967294 + 2 = 4294967296",
2755 		.u.insns_int = {
2756 			BPF_LD_IMM64(R0, 4294967294U),
2757 			BPF_LD_IMM64(R1, 4294967296ULL),
2758 			BPF_ALU64_IMM(BPF_ADD, R0, 2),
2759 			BPF_JMP_REG(BPF_JEQ, R0, R1, 2),
2760 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
2761 			BPF_EXIT_INSN(),
2762 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
2763 			BPF_EXIT_INSN(),
2764 		},
2765 		INTERNAL,
2766 		{ },
2767 		{ { 0, 1 } },
2768 	},
2769 	{
2770 		"ALU64_ADD_K: 2147483646 + -2147483647 = -1",
2771 		.u.insns_int = {
2772 			BPF_LD_IMM64(R0, 2147483646),
2773 			BPF_ALU64_IMM(BPF_ADD, R0, -2147483647),
2774 			BPF_EXIT_INSN(),
2775 		},
2776 		INTERNAL,
2777 		{ },
2778 		{ { 0, -1 } },
2779 	},
2780 	{
2781 		"ALU64_ADD_K: 1 + 0 = 1",
2782 		.u.insns_int = {
2783 			BPF_LD_IMM64(R2, 0x1),
2784 			BPF_LD_IMM64(R3, 0x1),
2785 			BPF_ALU64_IMM(BPF_ADD, R2, 0x0),
2786 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
2787 			BPF_MOV32_IMM(R0, 2),
2788 			BPF_EXIT_INSN(),
2789 			BPF_MOV32_IMM(R0, 1),
2790 			BPF_EXIT_INSN(),
2791 		},
2792 		INTERNAL,
2793 		{ },
2794 		{ { 0, 0x1 } },
2795 	},
2796 	{
2797 		"ALU64_ADD_K: 0 + (-1) = 0xffffffffffffffff",
2798 		.u.insns_int = {
2799 			BPF_LD_IMM64(R2, 0x0),
2800 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
2801 			BPF_ALU64_IMM(BPF_ADD, R2, 0xffffffff),
2802 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
2803 			BPF_MOV32_IMM(R0, 2),
2804 			BPF_EXIT_INSN(),
2805 			BPF_MOV32_IMM(R0, 1),
2806 			BPF_EXIT_INSN(),
2807 		},
2808 		INTERNAL,
2809 		{ },
2810 		{ { 0, 0x1 } },
2811 	},
2812 	{
2813 		"ALU64_ADD_K: 0 + 0xffff = 0xffff",
2814 		.u.insns_int = {
2815 			BPF_LD_IMM64(R2, 0x0),
2816 			BPF_LD_IMM64(R3, 0xffff),
2817 			BPF_ALU64_IMM(BPF_ADD, R2, 0xffff),
2818 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
2819 			BPF_MOV32_IMM(R0, 2),
2820 			BPF_EXIT_INSN(),
2821 			BPF_MOV32_IMM(R0, 1),
2822 			BPF_EXIT_INSN(),
2823 		},
2824 		INTERNAL,
2825 		{ },
2826 		{ { 0, 0x1 } },
2827 	},
2828 	{
2829 		"ALU64_ADD_K: 0 + 0x7fffffff = 0x7fffffff",
2830 		.u.insns_int = {
2831 			BPF_LD_IMM64(R2, 0x0),
2832 			BPF_LD_IMM64(R3, 0x7fffffff),
2833 			BPF_ALU64_IMM(BPF_ADD, R2, 0x7fffffff),
2834 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
2835 			BPF_MOV32_IMM(R0, 2),
2836 			BPF_EXIT_INSN(),
2837 			BPF_MOV32_IMM(R0, 1),
2838 			BPF_EXIT_INSN(),
2839 		},
2840 		INTERNAL,
2841 		{ },
2842 		{ { 0, 0x1 } },
2843 	},
2844 	{
2845 		"ALU64_ADD_K: 0 + 0x80000000 = 0xffffffff80000000",
2846 		.u.insns_int = {
2847 			BPF_LD_IMM64(R2, 0x0),
2848 			BPF_LD_IMM64(R3, 0xffffffff80000000LL),
2849 			BPF_ALU64_IMM(BPF_ADD, R2, 0x80000000),
2850 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
2851 			BPF_MOV32_IMM(R0, 2),
2852 			BPF_EXIT_INSN(),
2853 			BPF_MOV32_IMM(R0, 1),
2854 			BPF_EXIT_INSN(),
2855 		},
2856 		INTERNAL,
2857 		{ },
2858 		{ { 0, 0x1 } },
2859 	},
2860 	{
2861 		"ALU_ADD_K: 0 + 0x80008000 = 0xffffffff80008000",
2862 		.u.insns_int = {
2863 			BPF_LD_IMM64(R2, 0x0),
2864 			BPF_LD_IMM64(R3, 0xffffffff80008000LL),
2865 			BPF_ALU64_IMM(BPF_ADD, R2, 0x80008000),
2866 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
2867 			BPF_MOV32_IMM(R0, 2),
2868 			BPF_EXIT_INSN(),
2869 			BPF_MOV32_IMM(R0, 1),
2870 			BPF_EXIT_INSN(),
2871 		},
2872 		INTERNAL,
2873 		{ },
2874 		{ { 0, 0x1 } },
2875 	},
2876 	/* BPF_ALU | BPF_SUB | BPF_X */
2877 	{
2878 		"ALU_SUB_X: 3 - 1 = 2",
2879 		.u.insns_int = {
2880 			BPF_LD_IMM64(R0, 3),
2881 			BPF_ALU32_IMM(BPF_MOV, R1, 1),
2882 			BPF_ALU32_REG(BPF_SUB, R0, R1),
2883 			BPF_EXIT_INSN(),
2884 		},
2885 		INTERNAL,
2886 		{ },
2887 		{ { 0, 2 } },
2888 	},
2889 	{
2890 		"ALU_SUB_X: 4294967295 - 4294967294 = 1",
2891 		.u.insns_int = {
2892 			BPF_LD_IMM64(R0, 4294967295U),
2893 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967294U),
2894 			BPF_ALU32_REG(BPF_SUB, R0, R1),
2895 			BPF_EXIT_INSN(),
2896 		},
2897 		INTERNAL,
2898 		{ },
2899 		{ { 0, 1 } },
2900 	},
2901 	{
2902 		"ALU64_SUB_X: 3 - 1 = 2",
2903 		.u.insns_int = {
2904 			BPF_LD_IMM64(R0, 3),
2905 			BPF_ALU32_IMM(BPF_MOV, R1, 1),
2906 			BPF_ALU64_REG(BPF_SUB, R0, R1),
2907 			BPF_EXIT_INSN(),
2908 		},
2909 		INTERNAL,
2910 		{ },
2911 		{ { 0, 2 } },
2912 	},
2913 	{
2914 		"ALU64_SUB_X: 4294967295 - 4294967294 = 1",
2915 		.u.insns_int = {
2916 			BPF_LD_IMM64(R0, 4294967295U),
2917 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967294U),
2918 			BPF_ALU64_REG(BPF_SUB, R0, R1),
2919 			BPF_EXIT_INSN(),
2920 		},
2921 		INTERNAL,
2922 		{ },
2923 		{ { 0, 1 } },
2924 	},
2925 	/* BPF_ALU | BPF_SUB | BPF_K */
2926 	{
2927 		"ALU_SUB_K: 3 - 1 = 2",
2928 		.u.insns_int = {
2929 			BPF_LD_IMM64(R0, 3),
2930 			BPF_ALU32_IMM(BPF_SUB, R0, 1),
2931 			BPF_EXIT_INSN(),
2932 		},
2933 		INTERNAL,
2934 		{ },
2935 		{ { 0, 2 } },
2936 	},
2937 	{
2938 		"ALU_SUB_K: 3 - 0 = 3",
2939 		.u.insns_int = {
2940 			BPF_LD_IMM64(R0, 3),
2941 			BPF_ALU32_IMM(BPF_SUB, R0, 0),
2942 			BPF_EXIT_INSN(),
2943 		},
2944 		INTERNAL,
2945 		{ },
2946 		{ { 0, 3 } },
2947 	},
2948 	{
2949 		"ALU_SUB_K: 4294967295 - 4294967294 = 1",
2950 		.u.insns_int = {
2951 			BPF_LD_IMM64(R0, 4294967295U),
2952 			BPF_ALU32_IMM(BPF_SUB, R0, 4294967294U),
2953 			BPF_EXIT_INSN(),
2954 		},
2955 		INTERNAL,
2956 		{ },
2957 		{ { 0, 1 } },
2958 	},
2959 	{
2960 		"ALU64_SUB_K: 3 - 1 = 2",
2961 		.u.insns_int = {
2962 			BPF_LD_IMM64(R0, 3),
2963 			BPF_ALU64_IMM(BPF_SUB, R0, 1),
2964 			BPF_EXIT_INSN(),
2965 		},
2966 		INTERNAL,
2967 		{ },
2968 		{ { 0, 2 } },
2969 	},
2970 	{
2971 		"ALU64_SUB_K: 3 - 0 = 3",
2972 		.u.insns_int = {
2973 			BPF_LD_IMM64(R0, 3),
2974 			BPF_ALU64_IMM(BPF_SUB, R0, 0),
2975 			BPF_EXIT_INSN(),
2976 		},
2977 		INTERNAL,
2978 		{ },
2979 		{ { 0, 3 } },
2980 	},
2981 	{
2982 		"ALU64_SUB_K: 4294967294 - 4294967295 = -1",
2983 		.u.insns_int = {
2984 			BPF_LD_IMM64(R0, 4294967294U),
2985 			BPF_ALU64_IMM(BPF_SUB, R0, 4294967295U),
2986 			BPF_EXIT_INSN(),
2987 		},
2988 		INTERNAL,
2989 		{ },
2990 		{ { 0, -1 } },
2991 	},
2992 	{
2993 		"ALU64_ADD_K: 2147483646 - 2147483647 = -1",
2994 		.u.insns_int = {
2995 			BPF_LD_IMM64(R0, 2147483646),
2996 			BPF_ALU64_IMM(BPF_SUB, R0, 2147483647),
2997 			BPF_EXIT_INSN(),
2998 		},
2999 		INTERNAL,
3000 		{ },
3001 		{ { 0, -1 } },
3002 	},
3003 	/* BPF_ALU | BPF_MUL | BPF_X */
3004 	{
3005 		"ALU_MUL_X: 2 * 3 = 6",
3006 		.u.insns_int = {
3007 			BPF_LD_IMM64(R0, 2),
3008 			BPF_ALU32_IMM(BPF_MOV, R1, 3),
3009 			BPF_ALU32_REG(BPF_MUL, R0, R1),
3010 			BPF_EXIT_INSN(),
3011 		},
3012 		INTERNAL,
3013 		{ },
3014 		{ { 0, 6 } },
3015 	},
3016 	{
3017 		"ALU_MUL_X: 2 * 0x7FFFFFF8 = 0xFFFFFFF0",
3018 		.u.insns_int = {
3019 			BPF_LD_IMM64(R0, 2),
3020 			BPF_ALU32_IMM(BPF_MOV, R1, 0x7FFFFFF8),
3021 			BPF_ALU32_REG(BPF_MUL, R0, R1),
3022 			BPF_EXIT_INSN(),
3023 		},
3024 		INTERNAL,
3025 		{ },
3026 		{ { 0, 0xFFFFFFF0 } },
3027 	},
3028 	{
3029 		"ALU_MUL_X: -1 * -1 = 1",
3030 		.u.insns_int = {
3031 			BPF_LD_IMM64(R0, -1),
3032 			BPF_ALU32_IMM(BPF_MOV, R1, -1),
3033 			BPF_ALU32_REG(BPF_MUL, R0, R1),
3034 			BPF_EXIT_INSN(),
3035 		},
3036 		INTERNAL,
3037 		{ },
3038 		{ { 0, 1 } },
3039 	},
3040 	{
3041 		"ALU64_MUL_X: 2 * 3 = 6",
3042 		.u.insns_int = {
3043 			BPF_LD_IMM64(R0, 2),
3044 			BPF_ALU32_IMM(BPF_MOV, R1, 3),
3045 			BPF_ALU64_REG(BPF_MUL, R0, R1),
3046 			BPF_EXIT_INSN(),
3047 		},
3048 		INTERNAL,
3049 		{ },
3050 		{ { 0, 6 } },
3051 	},
3052 	{
3053 		"ALU64_MUL_X: 1 * 2147483647 = 2147483647",
3054 		.u.insns_int = {
3055 			BPF_LD_IMM64(R0, 1),
3056 			BPF_ALU32_IMM(BPF_MOV, R1, 2147483647),
3057 			BPF_ALU64_REG(BPF_MUL, R0, R1),
3058 			BPF_EXIT_INSN(),
3059 		},
3060 		INTERNAL,
3061 		{ },
3062 		{ { 0, 2147483647 } },
3063 	},
3064 	/* BPF_ALU | BPF_MUL | BPF_K */
3065 	{
3066 		"ALU_MUL_K: 2 * 3 = 6",
3067 		.u.insns_int = {
3068 			BPF_LD_IMM64(R0, 2),
3069 			BPF_ALU32_IMM(BPF_MUL, R0, 3),
3070 			BPF_EXIT_INSN(),
3071 		},
3072 		INTERNAL,
3073 		{ },
3074 		{ { 0, 6 } },
3075 	},
3076 	{
3077 		"ALU_MUL_K: 3 * 1 = 3",
3078 		.u.insns_int = {
3079 			BPF_LD_IMM64(R0, 3),
3080 			BPF_ALU32_IMM(BPF_MUL, R0, 1),
3081 			BPF_EXIT_INSN(),
3082 		},
3083 		INTERNAL,
3084 		{ },
3085 		{ { 0, 3 } },
3086 	},
3087 	{
3088 		"ALU_MUL_K: 2 * 0x7FFFFFF8 = 0xFFFFFFF0",
3089 		.u.insns_int = {
3090 			BPF_LD_IMM64(R0, 2),
3091 			BPF_ALU32_IMM(BPF_MUL, R0, 0x7FFFFFF8),
3092 			BPF_EXIT_INSN(),
3093 		},
3094 		INTERNAL,
3095 		{ },
3096 		{ { 0, 0xFFFFFFF0 } },
3097 	},
3098 	{
3099 		"ALU_MUL_K: 1 * (-1) = 0x00000000ffffffff",
3100 		.u.insns_int = {
3101 			BPF_LD_IMM64(R2, 0x1),
3102 			BPF_LD_IMM64(R3, 0x00000000ffffffff),
3103 			BPF_ALU32_IMM(BPF_MUL, R2, 0xffffffff),
3104 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
3105 			BPF_MOV32_IMM(R0, 2),
3106 			BPF_EXIT_INSN(),
3107 			BPF_MOV32_IMM(R0, 1),
3108 			BPF_EXIT_INSN(),
3109 		},
3110 		INTERNAL,
3111 		{ },
3112 		{ { 0, 0x1 } },
3113 	},
3114 	{
3115 		"ALU64_MUL_K: 2 * 3 = 6",
3116 		.u.insns_int = {
3117 			BPF_LD_IMM64(R0, 2),
3118 			BPF_ALU64_IMM(BPF_MUL, R0, 3),
3119 			BPF_EXIT_INSN(),
3120 		},
3121 		INTERNAL,
3122 		{ },
3123 		{ { 0, 6 } },
3124 	},
3125 	{
3126 		"ALU64_MUL_K: 3 * 1 = 3",
3127 		.u.insns_int = {
3128 			BPF_LD_IMM64(R0, 3),
3129 			BPF_ALU64_IMM(BPF_MUL, R0, 1),
3130 			BPF_EXIT_INSN(),
3131 		},
3132 		INTERNAL,
3133 		{ },
3134 		{ { 0, 3 } },
3135 	},
3136 	{
3137 		"ALU64_MUL_K: 1 * 2147483647 = 2147483647",
3138 		.u.insns_int = {
3139 			BPF_LD_IMM64(R0, 1),
3140 			BPF_ALU64_IMM(BPF_MUL, R0, 2147483647),
3141 			BPF_EXIT_INSN(),
3142 		},
3143 		INTERNAL,
3144 		{ },
3145 		{ { 0, 2147483647 } },
3146 	},
3147 	{
3148 		"ALU64_MUL_K: 1 * -2147483647 = -2147483647",
3149 		.u.insns_int = {
3150 			BPF_LD_IMM64(R0, 1),
3151 			BPF_ALU64_IMM(BPF_MUL, R0, -2147483647),
3152 			BPF_EXIT_INSN(),
3153 		},
3154 		INTERNAL,
3155 		{ },
3156 		{ { 0, -2147483647 } },
3157 	},
3158 	{
3159 		"ALU64_MUL_K: 1 * (-1) = 0xffffffffffffffff",
3160 		.u.insns_int = {
3161 			BPF_LD_IMM64(R2, 0x1),
3162 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
3163 			BPF_ALU64_IMM(BPF_MUL, R2, 0xffffffff),
3164 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
3165 			BPF_MOV32_IMM(R0, 2),
3166 			BPF_EXIT_INSN(),
3167 			BPF_MOV32_IMM(R0, 1),
3168 			BPF_EXIT_INSN(),
3169 		},
3170 		INTERNAL,
3171 		{ },
3172 		{ { 0, 0x1 } },
3173 	},
3174 	/* BPF_ALU | BPF_DIV | BPF_X */
3175 	{
3176 		"ALU_DIV_X: 6 / 2 = 3",
3177 		.u.insns_int = {
3178 			BPF_LD_IMM64(R0, 6),
3179 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
3180 			BPF_ALU32_REG(BPF_DIV, R0, R1),
3181 			BPF_EXIT_INSN(),
3182 		},
3183 		INTERNAL,
3184 		{ },
3185 		{ { 0, 3 } },
3186 	},
3187 	{
3188 		"ALU_DIV_X: 4294967295 / 4294967295 = 1",
3189 		.u.insns_int = {
3190 			BPF_LD_IMM64(R0, 4294967295U),
3191 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967295U),
3192 			BPF_ALU32_REG(BPF_DIV, R0, R1),
3193 			BPF_EXIT_INSN(),
3194 		},
3195 		INTERNAL,
3196 		{ },
3197 		{ { 0, 1 } },
3198 	},
3199 	{
3200 		"ALU64_DIV_X: 6 / 2 = 3",
3201 		.u.insns_int = {
3202 			BPF_LD_IMM64(R0, 6),
3203 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
3204 			BPF_ALU64_REG(BPF_DIV, R0, R1),
3205 			BPF_EXIT_INSN(),
3206 		},
3207 		INTERNAL,
3208 		{ },
3209 		{ { 0, 3 } },
3210 	},
3211 	{
3212 		"ALU64_DIV_X: 2147483647 / 2147483647 = 1",
3213 		.u.insns_int = {
3214 			BPF_LD_IMM64(R0, 2147483647),
3215 			BPF_ALU32_IMM(BPF_MOV, R1, 2147483647),
3216 			BPF_ALU64_REG(BPF_DIV, R0, R1),
3217 			BPF_EXIT_INSN(),
3218 		},
3219 		INTERNAL,
3220 		{ },
3221 		{ { 0, 1 } },
3222 	},
3223 	{
3224 		"ALU64_DIV_X: 0xffffffffffffffff / (-1) = 0x0000000000000001",
3225 		.u.insns_int = {
3226 			BPF_LD_IMM64(R2, 0xffffffffffffffffLL),
3227 			BPF_LD_IMM64(R4, 0xffffffffffffffffLL),
3228 			BPF_LD_IMM64(R3, 0x0000000000000001LL),
3229 			BPF_ALU64_REG(BPF_DIV, R2, R4),
3230 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
3231 			BPF_MOV32_IMM(R0, 2),
3232 			BPF_EXIT_INSN(),
3233 			BPF_MOV32_IMM(R0, 1),
3234 			BPF_EXIT_INSN(),
3235 		},
3236 		INTERNAL,
3237 		{ },
3238 		{ { 0, 0x1 } },
3239 	},
3240 	/* BPF_ALU | BPF_DIV | BPF_K */
3241 	{
3242 		"ALU_DIV_K: 6 / 2 = 3",
3243 		.u.insns_int = {
3244 			BPF_LD_IMM64(R0, 6),
3245 			BPF_ALU32_IMM(BPF_DIV, R0, 2),
3246 			BPF_EXIT_INSN(),
3247 		},
3248 		INTERNAL,
3249 		{ },
3250 		{ { 0, 3 } },
3251 	},
3252 	{
3253 		"ALU_DIV_K: 3 / 1 = 3",
3254 		.u.insns_int = {
3255 			BPF_LD_IMM64(R0, 3),
3256 			BPF_ALU32_IMM(BPF_DIV, R0, 1),
3257 			BPF_EXIT_INSN(),
3258 		},
3259 		INTERNAL,
3260 		{ },
3261 		{ { 0, 3 } },
3262 	},
3263 	{
3264 		"ALU_DIV_K: 4294967295 / 4294967295 = 1",
3265 		.u.insns_int = {
3266 			BPF_LD_IMM64(R0, 4294967295U),
3267 			BPF_ALU32_IMM(BPF_DIV, R0, 4294967295U),
3268 			BPF_EXIT_INSN(),
3269 		},
3270 		INTERNAL,
3271 		{ },
3272 		{ { 0, 1 } },
3273 	},
3274 	{
3275 		"ALU_DIV_K: 0xffffffffffffffff / (-1) = 0x1",
3276 		.u.insns_int = {
3277 			BPF_LD_IMM64(R2, 0xffffffffffffffffLL),
3278 			BPF_LD_IMM64(R3, 0x1UL),
3279 			BPF_ALU32_IMM(BPF_DIV, R2, 0xffffffff),
3280 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
3281 			BPF_MOV32_IMM(R0, 2),
3282 			BPF_EXIT_INSN(),
3283 			BPF_MOV32_IMM(R0, 1),
3284 			BPF_EXIT_INSN(),
3285 		},
3286 		INTERNAL,
3287 		{ },
3288 		{ { 0, 0x1 } },
3289 	},
3290 	{
3291 		"ALU64_DIV_K: 6 / 2 = 3",
3292 		.u.insns_int = {
3293 			BPF_LD_IMM64(R0, 6),
3294 			BPF_ALU64_IMM(BPF_DIV, R0, 2),
3295 			BPF_EXIT_INSN(),
3296 		},
3297 		INTERNAL,
3298 		{ },
3299 		{ { 0, 3 } },
3300 	},
3301 	{
3302 		"ALU64_DIV_K: 3 / 1 = 3",
3303 		.u.insns_int = {
3304 			BPF_LD_IMM64(R0, 3),
3305 			BPF_ALU64_IMM(BPF_DIV, R0, 1),
3306 			BPF_EXIT_INSN(),
3307 		},
3308 		INTERNAL,
3309 		{ },
3310 		{ { 0, 3 } },
3311 	},
3312 	{
3313 		"ALU64_DIV_K: 2147483647 / 2147483647 = 1",
3314 		.u.insns_int = {
3315 			BPF_LD_IMM64(R0, 2147483647),
3316 			BPF_ALU64_IMM(BPF_DIV, R0, 2147483647),
3317 			BPF_EXIT_INSN(),
3318 		},
3319 		INTERNAL,
3320 		{ },
3321 		{ { 0, 1 } },
3322 	},
3323 	{
3324 		"ALU64_DIV_K: 0xffffffffffffffff / (-1) = 0x0000000000000001",
3325 		.u.insns_int = {
3326 			BPF_LD_IMM64(R2, 0xffffffffffffffffLL),
3327 			BPF_LD_IMM64(R3, 0x0000000000000001LL),
3328 			BPF_ALU64_IMM(BPF_DIV, R2, 0xffffffff),
3329 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
3330 			BPF_MOV32_IMM(R0, 2),
3331 			BPF_EXIT_INSN(),
3332 			BPF_MOV32_IMM(R0, 1),
3333 			BPF_EXIT_INSN(),
3334 		},
3335 		INTERNAL,
3336 		{ },
3337 		{ { 0, 0x1 } },
3338 	},
3339 	/* BPF_ALU | BPF_MOD | BPF_X */
3340 	{
3341 		"ALU_MOD_X: 3 % 2 = 1",
3342 		.u.insns_int = {
3343 			BPF_LD_IMM64(R0, 3),
3344 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
3345 			BPF_ALU32_REG(BPF_MOD, R0, R1),
3346 			BPF_EXIT_INSN(),
3347 		},
3348 		INTERNAL,
3349 		{ },
3350 		{ { 0, 1 } },
3351 	},
3352 	{
3353 		"ALU_MOD_X: 4294967295 % 4294967293 = 2",
3354 		.u.insns_int = {
3355 			BPF_LD_IMM64(R0, 4294967295U),
3356 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967293U),
3357 			BPF_ALU32_REG(BPF_MOD, R0, R1),
3358 			BPF_EXIT_INSN(),
3359 		},
3360 		INTERNAL,
3361 		{ },
3362 		{ { 0, 2 } },
3363 	},
3364 	{
3365 		"ALU64_MOD_X: 3 % 2 = 1",
3366 		.u.insns_int = {
3367 			BPF_LD_IMM64(R0, 3),
3368 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
3369 			BPF_ALU64_REG(BPF_MOD, R0, R1),
3370 			BPF_EXIT_INSN(),
3371 		},
3372 		INTERNAL,
3373 		{ },
3374 		{ { 0, 1 } },
3375 	},
3376 	{
3377 		"ALU64_MOD_X: 2147483647 % 2147483645 = 2",
3378 		.u.insns_int = {
3379 			BPF_LD_IMM64(R0, 2147483647),
3380 			BPF_ALU32_IMM(BPF_MOV, R1, 2147483645),
3381 			BPF_ALU64_REG(BPF_MOD, R0, R1),
3382 			BPF_EXIT_INSN(),
3383 		},
3384 		INTERNAL,
3385 		{ },
3386 		{ { 0, 2 } },
3387 	},
3388 	/* BPF_ALU | BPF_MOD | BPF_K */
3389 	{
3390 		"ALU_MOD_K: 3 % 2 = 1",
3391 		.u.insns_int = {
3392 			BPF_LD_IMM64(R0, 3),
3393 			BPF_ALU32_IMM(BPF_MOD, R0, 2),
3394 			BPF_EXIT_INSN(),
3395 		},
3396 		INTERNAL,
3397 		{ },
3398 		{ { 0, 1 } },
3399 	},
3400 	{
3401 		"ALU_MOD_K: 3 % 1 = 0",
3402 		.u.insns_int = {
3403 			BPF_LD_IMM64(R0, 3),
3404 			BPF_ALU32_IMM(BPF_MOD, R0, 1),
3405 			BPF_EXIT_INSN(),
3406 		},
3407 		INTERNAL,
3408 		{ },
3409 		{ { 0, 0 } },
3410 	},
3411 	{
3412 		"ALU_MOD_K: 4294967295 % 4294967293 = 2",
3413 		.u.insns_int = {
3414 			BPF_LD_IMM64(R0, 4294967295U),
3415 			BPF_ALU32_IMM(BPF_MOD, R0, 4294967293U),
3416 			BPF_EXIT_INSN(),
3417 		},
3418 		INTERNAL,
3419 		{ },
3420 		{ { 0, 2 } },
3421 	},
3422 	{
3423 		"ALU64_MOD_K: 3 % 2 = 1",
3424 		.u.insns_int = {
3425 			BPF_LD_IMM64(R0, 3),
3426 			BPF_ALU64_IMM(BPF_MOD, R0, 2),
3427 			BPF_EXIT_INSN(),
3428 		},
3429 		INTERNAL,
3430 		{ },
3431 		{ { 0, 1 } },
3432 	},
3433 	{
3434 		"ALU64_MOD_K: 3 % 1 = 0",
3435 		.u.insns_int = {
3436 			BPF_LD_IMM64(R0, 3),
3437 			BPF_ALU64_IMM(BPF_MOD, R0, 1),
3438 			BPF_EXIT_INSN(),
3439 		},
3440 		INTERNAL,
3441 		{ },
3442 		{ { 0, 0 } },
3443 	},
3444 	{
3445 		"ALU64_MOD_K: 2147483647 % 2147483645 = 2",
3446 		.u.insns_int = {
3447 			BPF_LD_IMM64(R0, 2147483647),
3448 			BPF_ALU64_IMM(BPF_MOD, R0, 2147483645),
3449 			BPF_EXIT_INSN(),
3450 		},
3451 		INTERNAL,
3452 		{ },
3453 		{ { 0, 2 } },
3454 	},
3455 	/* BPF_ALU | BPF_AND | BPF_X */
3456 	{
3457 		"ALU_AND_X: 3 & 2 = 2",
3458 		.u.insns_int = {
3459 			BPF_LD_IMM64(R0, 3),
3460 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
3461 			BPF_ALU32_REG(BPF_AND, R0, R1),
3462 			BPF_EXIT_INSN(),
3463 		},
3464 		INTERNAL,
3465 		{ },
3466 		{ { 0, 2 } },
3467 	},
3468 	{
3469 		"ALU_AND_X: 0xffffffff & 0xffffffff = 0xffffffff",
3470 		.u.insns_int = {
3471 			BPF_LD_IMM64(R0, 0xffffffff),
3472 			BPF_ALU32_IMM(BPF_MOV, R1, 0xffffffff),
3473 			BPF_ALU32_REG(BPF_AND, R0, R1),
3474 			BPF_EXIT_INSN(),
3475 		},
3476 		INTERNAL,
3477 		{ },
3478 		{ { 0, 0xffffffff } },
3479 	},
3480 	{
3481 		"ALU64_AND_X: 3 & 2 = 2",
3482 		.u.insns_int = {
3483 			BPF_LD_IMM64(R0, 3),
3484 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
3485 			BPF_ALU64_REG(BPF_AND, R0, R1),
3486 			BPF_EXIT_INSN(),
3487 		},
3488 		INTERNAL,
3489 		{ },
3490 		{ { 0, 2 } },
3491 	},
3492 	{
3493 		"ALU64_AND_X: 0xffffffff & 0xffffffff = 0xffffffff",
3494 		.u.insns_int = {
3495 			BPF_LD_IMM64(R0, 0xffffffff),
3496 			BPF_ALU32_IMM(BPF_MOV, R1, 0xffffffff),
3497 			BPF_ALU64_REG(BPF_AND, R0, R1),
3498 			BPF_EXIT_INSN(),
3499 		},
3500 		INTERNAL,
3501 		{ },
3502 		{ { 0, 0xffffffff } },
3503 	},
3504 	/* BPF_ALU | BPF_AND | BPF_K */
3505 	{
3506 		"ALU_AND_K: 3 & 2 = 2",
3507 		.u.insns_int = {
3508 			BPF_LD_IMM64(R0, 3),
3509 			BPF_ALU32_IMM(BPF_AND, R0, 2),
3510 			BPF_EXIT_INSN(),
3511 		},
3512 		INTERNAL,
3513 		{ },
3514 		{ { 0, 2 } },
3515 	},
3516 	{
3517 		"ALU_AND_K: 0xffffffff & 0xffffffff = 0xffffffff",
3518 		.u.insns_int = {
3519 			BPF_LD_IMM64(R0, 0xffffffff),
3520 			BPF_ALU32_IMM(BPF_AND, R0, 0xffffffff),
3521 			BPF_EXIT_INSN(),
3522 		},
3523 		INTERNAL,
3524 		{ },
3525 		{ { 0, 0xffffffff } },
3526 	},
3527 	{
3528 		"ALU64_AND_K: 3 & 2 = 2",
3529 		.u.insns_int = {
3530 			BPF_LD_IMM64(R0, 3),
3531 			BPF_ALU64_IMM(BPF_AND, R0, 2),
3532 			BPF_EXIT_INSN(),
3533 		},
3534 		INTERNAL,
3535 		{ },
3536 		{ { 0, 2 } },
3537 	},
3538 	{
3539 		"ALU64_AND_K: 0xffffffff & 0xffffffff = 0xffffffff",
3540 		.u.insns_int = {
3541 			BPF_LD_IMM64(R0, 0xffffffff),
3542 			BPF_ALU64_IMM(BPF_AND, R0, 0xffffffff),
3543 			BPF_EXIT_INSN(),
3544 		},
3545 		INTERNAL,
3546 		{ },
3547 		{ { 0, 0xffffffff } },
3548 	},
3549 	{
3550 		"ALU64_AND_K: 0x0000ffffffff0000 & 0x0 = 0x0000ffff00000000",
3551 		.u.insns_int = {
3552 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
3553 			BPF_LD_IMM64(R3, 0x0000000000000000LL),
3554 			BPF_ALU64_IMM(BPF_AND, R2, 0x0),
3555 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
3556 			BPF_MOV32_IMM(R0, 2),
3557 			BPF_EXIT_INSN(),
3558 			BPF_MOV32_IMM(R0, 1),
3559 			BPF_EXIT_INSN(),
3560 		},
3561 		INTERNAL,
3562 		{ },
3563 		{ { 0, 0x1 } },
3564 	},
3565 	{
3566 		"ALU64_AND_K: 0x0000ffffffff0000 & -1 = 0x0000ffffffffffff",
3567 		.u.insns_int = {
3568 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
3569 			BPF_LD_IMM64(R3, 0x0000ffffffff0000LL),
3570 			BPF_ALU64_IMM(BPF_AND, R2, 0xffffffff),
3571 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
3572 			BPF_MOV32_IMM(R0, 2),
3573 			BPF_EXIT_INSN(),
3574 			BPF_MOV32_IMM(R0, 1),
3575 			BPF_EXIT_INSN(),
3576 		},
3577 		INTERNAL,
3578 		{ },
3579 		{ { 0, 0x1 } },
3580 	},
3581 	{
3582 		"ALU64_AND_K: 0xffffffffffffffff & -1 = 0xffffffffffffffff",
3583 		.u.insns_int = {
3584 			BPF_LD_IMM64(R2, 0xffffffffffffffffLL),
3585 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
3586 			BPF_ALU64_IMM(BPF_AND, R2, 0xffffffff),
3587 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
3588 			BPF_MOV32_IMM(R0, 2),
3589 			BPF_EXIT_INSN(),
3590 			BPF_MOV32_IMM(R0, 1),
3591 			BPF_EXIT_INSN(),
3592 		},
3593 		INTERNAL,
3594 		{ },
3595 		{ { 0, 0x1 } },
3596 	},
3597 	/* BPF_ALU | BPF_OR | BPF_X */
3598 	{
3599 		"ALU_OR_X: 1 | 2 = 3",
3600 		.u.insns_int = {
3601 			BPF_LD_IMM64(R0, 1),
3602 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
3603 			BPF_ALU32_REG(BPF_OR, R0, R1),
3604 			BPF_EXIT_INSN(),
3605 		},
3606 		INTERNAL,
3607 		{ },
3608 		{ { 0, 3 } },
3609 	},
3610 	{
3611 		"ALU_OR_X: 0x0 | 0xffffffff = 0xffffffff",
3612 		.u.insns_int = {
3613 			BPF_LD_IMM64(R0, 0),
3614 			BPF_ALU32_IMM(BPF_MOV, R1, 0xffffffff),
3615 			BPF_ALU32_REG(BPF_OR, R0, R1),
3616 			BPF_EXIT_INSN(),
3617 		},
3618 		INTERNAL,
3619 		{ },
3620 		{ { 0, 0xffffffff } },
3621 	},
3622 	{
3623 		"ALU64_OR_X: 1 | 2 = 3",
3624 		.u.insns_int = {
3625 			BPF_LD_IMM64(R0, 1),
3626 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
3627 			BPF_ALU64_REG(BPF_OR, R0, R1),
3628 			BPF_EXIT_INSN(),
3629 		},
3630 		INTERNAL,
3631 		{ },
3632 		{ { 0, 3 } },
3633 	},
3634 	{
3635 		"ALU64_OR_X: 0 | 0xffffffff = 0xffffffff",
3636 		.u.insns_int = {
3637 			BPF_LD_IMM64(R0, 0),
3638 			BPF_ALU32_IMM(BPF_MOV, R1, 0xffffffff),
3639 			BPF_ALU64_REG(BPF_OR, R0, R1),
3640 			BPF_EXIT_INSN(),
3641 		},
3642 		INTERNAL,
3643 		{ },
3644 		{ { 0, 0xffffffff } },
3645 	},
3646 	/* BPF_ALU | BPF_OR | BPF_K */
3647 	{
3648 		"ALU_OR_K: 1 | 2 = 3",
3649 		.u.insns_int = {
3650 			BPF_LD_IMM64(R0, 1),
3651 			BPF_ALU32_IMM(BPF_OR, R0, 2),
3652 			BPF_EXIT_INSN(),
3653 		},
3654 		INTERNAL,
3655 		{ },
3656 		{ { 0, 3 } },
3657 	},
3658 	{
3659 		"ALU_OR_K: 0 & 0xffffffff = 0xffffffff",
3660 		.u.insns_int = {
3661 			BPF_LD_IMM64(R0, 0),
3662 			BPF_ALU32_IMM(BPF_OR, R0, 0xffffffff),
3663 			BPF_EXIT_INSN(),
3664 		},
3665 		INTERNAL,
3666 		{ },
3667 		{ { 0, 0xffffffff } },
3668 	},
3669 	{
3670 		"ALU64_OR_K: 1 | 2 = 3",
3671 		.u.insns_int = {
3672 			BPF_LD_IMM64(R0, 1),
3673 			BPF_ALU64_IMM(BPF_OR, R0, 2),
3674 			BPF_EXIT_INSN(),
3675 		},
3676 		INTERNAL,
3677 		{ },
3678 		{ { 0, 3 } },
3679 	},
3680 	{
3681 		"ALU64_OR_K: 0 & 0xffffffff = 0xffffffff",
3682 		.u.insns_int = {
3683 			BPF_LD_IMM64(R0, 0),
3684 			BPF_ALU64_IMM(BPF_OR, R0, 0xffffffff),
3685 			BPF_EXIT_INSN(),
3686 		},
3687 		INTERNAL,
3688 		{ },
3689 		{ { 0, 0xffffffff } },
3690 	},
3691 	{
3692 		"ALU64_OR_K: 0x0000ffffffff0000 | 0x0 = 0x0000ffff00000000",
3693 		.u.insns_int = {
3694 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
3695 			BPF_LD_IMM64(R3, 0x0000ffffffff0000LL),
3696 			BPF_ALU64_IMM(BPF_OR, R2, 0x0),
3697 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
3698 			BPF_MOV32_IMM(R0, 2),
3699 			BPF_EXIT_INSN(),
3700 			BPF_MOV32_IMM(R0, 1),
3701 			BPF_EXIT_INSN(),
3702 		},
3703 		INTERNAL,
3704 		{ },
3705 		{ { 0, 0x1 } },
3706 	},
3707 	{
3708 		"ALU64_OR_K: 0x0000ffffffff0000 | -1 = 0xffffffffffffffff",
3709 		.u.insns_int = {
3710 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
3711 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
3712 			BPF_ALU64_IMM(BPF_OR, R2, 0xffffffff),
3713 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
3714 			BPF_MOV32_IMM(R0, 2),
3715 			BPF_EXIT_INSN(),
3716 			BPF_MOV32_IMM(R0, 1),
3717 			BPF_EXIT_INSN(),
3718 		},
3719 		INTERNAL,
3720 		{ },
3721 		{ { 0, 0x1 } },
3722 	},
3723 	{
3724 		"ALU64_OR_K: 0x000000000000000 | -1 = 0xffffffffffffffff",
3725 		.u.insns_int = {
3726 			BPF_LD_IMM64(R2, 0x0000000000000000LL),
3727 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
3728 			BPF_ALU64_IMM(BPF_OR, R2, 0xffffffff),
3729 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
3730 			BPF_MOV32_IMM(R0, 2),
3731 			BPF_EXIT_INSN(),
3732 			BPF_MOV32_IMM(R0, 1),
3733 			BPF_EXIT_INSN(),
3734 		},
3735 		INTERNAL,
3736 		{ },
3737 		{ { 0, 0x1 } },
3738 	},
3739 	/* BPF_ALU | BPF_XOR | BPF_X */
3740 	{
3741 		"ALU_XOR_X: 5 ^ 6 = 3",
3742 		.u.insns_int = {
3743 			BPF_LD_IMM64(R0, 5),
3744 			BPF_ALU32_IMM(BPF_MOV, R1, 6),
3745 			BPF_ALU32_REG(BPF_XOR, R0, R1),
3746 			BPF_EXIT_INSN(),
3747 		},
3748 		INTERNAL,
3749 		{ },
3750 		{ { 0, 3 } },
3751 	},
3752 	{
3753 		"ALU_XOR_X: 0x1 ^ 0xffffffff = 0xfffffffe",
3754 		.u.insns_int = {
3755 			BPF_LD_IMM64(R0, 1),
3756 			BPF_ALU32_IMM(BPF_MOV, R1, 0xffffffff),
3757 			BPF_ALU32_REG(BPF_XOR, R0, R1),
3758 			BPF_EXIT_INSN(),
3759 		},
3760 		INTERNAL,
3761 		{ },
3762 		{ { 0, 0xfffffffe } },
3763 	},
3764 	{
3765 		"ALU64_XOR_X: 5 ^ 6 = 3",
3766 		.u.insns_int = {
3767 			BPF_LD_IMM64(R0, 5),
3768 			BPF_ALU32_IMM(BPF_MOV, R1, 6),
3769 			BPF_ALU64_REG(BPF_XOR, R0, R1),
3770 			BPF_EXIT_INSN(),
3771 		},
3772 		INTERNAL,
3773 		{ },
3774 		{ { 0, 3 } },
3775 	},
3776 	{
3777 		"ALU64_XOR_X: 1 ^ 0xffffffff = 0xfffffffe",
3778 		.u.insns_int = {
3779 			BPF_LD_IMM64(R0, 1),
3780 			BPF_ALU32_IMM(BPF_MOV, R1, 0xffffffff),
3781 			BPF_ALU64_REG(BPF_XOR, R0, R1),
3782 			BPF_EXIT_INSN(),
3783 		},
3784 		INTERNAL,
3785 		{ },
3786 		{ { 0, 0xfffffffe } },
3787 	},
3788 	/* BPF_ALU | BPF_XOR | BPF_K */
3789 	{
3790 		"ALU_XOR_K: 5 ^ 6 = 3",
3791 		.u.insns_int = {
3792 			BPF_LD_IMM64(R0, 5),
3793 			BPF_ALU32_IMM(BPF_XOR, R0, 6),
3794 			BPF_EXIT_INSN(),
3795 		},
3796 		INTERNAL,
3797 		{ },
3798 		{ { 0, 3 } },
3799 	},
3800 	{
3801 		"ALU_XOR_K: 1 ^ 0xffffffff = 0xfffffffe",
3802 		.u.insns_int = {
3803 			BPF_LD_IMM64(R0, 1),
3804 			BPF_ALU32_IMM(BPF_XOR, R0, 0xffffffff),
3805 			BPF_EXIT_INSN(),
3806 		},
3807 		INTERNAL,
3808 		{ },
3809 		{ { 0, 0xfffffffe } },
3810 	},
3811 	{
3812 		"ALU64_XOR_K: 5 ^ 6 = 3",
3813 		.u.insns_int = {
3814 			BPF_LD_IMM64(R0, 5),
3815 			BPF_ALU64_IMM(BPF_XOR, R0, 6),
3816 			BPF_EXIT_INSN(),
3817 		},
3818 		INTERNAL,
3819 		{ },
3820 		{ { 0, 3 } },
3821 	},
3822 	{
3823 		"ALU64_XOR_K: 1 & 0xffffffff = 0xfffffffe",
3824 		.u.insns_int = {
3825 			BPF_LD_IMM64(R0, 1),
3826 			BPF_ALU64_IMM(BPF_XOR, R0, 0xffffffff),
3827 			BPF_EXIT_INSN(),
3828 		},
3829 		INTERNAL,
3830 		{ },
3831 		{ { 0, 0xfffffffe } },
3832 	},
3833 	{
3834 		"ALU64_XOR_K: 0x0000ffffffff0000 ^ 0x0 = 0x0000ffffffff0000",
3835 		.u.insns_int = {
3836 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
3837 			BPF_LD_IMM64(R3, 0x0000ffffffff0000LL),
3838 			BPF_ALU64_IMM(BPF_XOR, R2, 0x0),
3839 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
3840 			BPF_MOV32_IMM(R0, 2),
3841 			BPF_EXIT_INSN(),
3842 			BPF_MOV32_IMM(R0, 1),
3843 			BPF_EXIT_INSN(),
3844 		},
3845 		INTERNAL,
3846 		{ },
3847 		{ { 0, 0x1 } },
3848 	},
3849 	{
3850 		"ALU64_XOR_K: 0x0000ffffffff0000 ^ -1 = 0xffff00000000ffff",
3851 		.u.insns_int = {
3852 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
3853 			BPF_LD_IMM64(R3, 0xffff00000000ffffLL),
3854 			BPF_ALU64_IMM(BPF_XOR, R2, 0xffffffff),
3855 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
3856 			BPF_MOV32_IMM(R0, 2),
3857 			BPF_EXIT_INSN(),
3858 			BPF_MOV32_IMM(R0, 1),
3859 			BPF_EXIT_INSN(),
3860 		},
3861 		INTERNAL,
3862 		{ },
3863 		{ { 0, 0x1 } },
3864 	},
3865 	{
3866 		"ALU64_XOR_K: 0x000000000000000 ^ -1 = 0xffffffffffffffff",
3867 		.u.insns_int = {
3868 			BPF_LD_IMM64(R2, 0x0000000000000000LL),
3869 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
3870 			BPF_ALU64_IMM(BPF_XOR, R2, 0xffffffff),
3871 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
3872 			BPF_MOV32_IMM(R0, 2),
3873 			BPF_EXIT_INSN(),
3874 			BPF_MOV32_IMM(R0, 1),
3875 			BPF_EXIT_INSN(),
3876 		},
3877 		INTERNAL,
3878 		{ },
3879 		{ { 0, 0x1 } },
3880 	},
3881 	/* BPF_ALU | BPF_LSH | BPF_X */
3882 	{
3883 		"ALU_LSH_X: 1 << 1 = 2",
3884 		.u.insns_int = {
3885 			BPF_LD_IMM64(R0, 1),
3886 			BPF_ALU32_IMM(BPF_MOV, R1, 1),
3887 			BPF_ALU32_REG(BPF_LSH, R0, R1),
3888 			BPF_EXIT_INSN(),
3889 		},
3890 		INTERNAL,
3891 		{ },
3892 		{ { 0, 2 } },
3893 	},
3894 	{
3895 		"ALU_LSH_X: 1 << 31 = 0x80000000",
3896 		.u.insns_int = {
3897 			BPF_LD_IMM64(R0, 1),
3898 			BPF_ALU32_IMM(BPF_MOV, R1, 31),
3899 			BPF_ALU32_REG(BPF_LSH, R0, R1),
3900 			BPF_EXIT_INSN(),
3901 		},
3902 		INTERNAL,
3903 		{ },
3904 		{ { 0, 0x80000000 } },
3905 	},
3906 	{
3907 		"ALU64_LSH_X: 1 << 1 = 2",
3908 		.u.insns_int = {
3909 			BPF_LD_IMM64(R0, 1),
3910 			BPF_ALU32_IMM(BPF_MOV, R1, 1),
3911 			BPF_ALU64_REG(BPF_LSH, R0, R1),
3912 			BPF_EXIT_INSN(),
3913 		},
3914 		INTERNAL,
3915 		{ },
3916 		{ { 0, 2 } },
3917 	},
3918 	{
3919 		"ALU64_LSH_X: 1 << 31 = 0x80000000",
3920 		.u.insns_int = {
3921 			BPF_LD_IMM64(R0, 1),
3922 			BPF_ALU32_IMM(BPF_MOV, R1, 31),
3923 			BPF_ALU64_REG(BPF_LSH, R0, R1),
3924 			BPF_EXIT_INSN(),
3925 		},
3926 		INTERNAL,
3927 		{ },
3928 		{ { 0, 0x80000000 } },
3929 	},
3930 	/* BPF_ALU | BPF_LSH | BPF_K */
3931 	{
3932 		"ALU_LSH_K: 1 << 1 = 2",
3933 		.u.insns_int = {
3934 			BPF_LD_IMM64(R0, 1),
3935 			BPF_ALU32_IMM(BPF_LSH, R0, 1),
3936 			BPF_EXIT_INSN(),
3937 		},
3938 		INTERNAL,
3939 		{ },
3940 		{ { 0, 2 } },
3941 	},
3942 	{
3943 		"ALU_LSH_K: 1 << 31 = 0x80000000",
3944 		.u.insns_int = {
3945 			BPF_LD_IMM64(R0, 1),
3946 			BPF_ALU32_IMM(BPF_LSH, R0, 31),
3947 			BPF_EXIT_INSN(),
3948 		},
3949 		INTERNAL,
3950 		{ },
3951 		{ { 0, 0x80000000 } },
3952 	},
3953 	{
3954 		"ALU64_LSH_K: 1 << 1 = 2",
3955 		.u.insns_int = {
3956 			BPF_LD_IMM64(R0, 1),
3957 			BPF_ALU64_IMM(BPF_LSH, R0, 1),
3958 			BPF_EXIT_INSN(),
3959 		},
3960 		INTERNAL,
3961 		{ },
3962 		{ { 0, 2 } },
3963 	},
3964 	{
3965 		"ALU64_LSH_K: 1 << 31 = 0x80000000",
3966 		.u.insns_int = {
3967 			BPF_LD_IMM64(R0, 1),
3968 			BPF_ALU64_IMM(BPF_LSH, R0, 31),
3969 			BPF_EXIT_INSN(),
3970 		},
3971 		INTERNAL,
3972 		{ },
3973 		{ { 0, 0x80000000 } },
3974 	},
3975 	/* BPF_ALU | BPF_RSH | BPF_X */
3976 	{
3977 		"ALU_RSH_X: 2 >> 1 = 1",
3978 		.u.insns_int = {
3979 			BPF_LD_IMM64(R0, 2),
3980 			BPF_ALU32_IMM(BPF_MOV, R1, 1),
3981 			BPF_ALU32_REG(BPF_RSH, R0, R1),
3982 			BPF_EXIT_INSN(),
3983 		},
3984 		INTERNAL,
3985 		{ },
3986 		{ { 0, 1 } },
3987 	},
3988 	{
3989 		"ALU_RSH_X: 0x80000000 >> 31 = 1",
3990 		.u.insns_int = {
3991 			BPF_LD_IMM64(R0, 0x80000000),
3992 			BPF_ALU32_IMM(BPF_MOV, R1, 31),
3993 			BPF_ALU32_REG(BPF_RSH, R0, R1),
3994 			BPF_EXIT_INSN(),
3995 		},
3996 		INTERNAL,
3997 		{ },
3998 		{ { 0, 1 } },
3999 	},
4000 	{
4001 		"ALU64_RSH_X: 2 >> 1 = 1",
4002 		.u.insns_int = {
4003 			BPF_LD_IMM64(R0, 2),
4004 			BPF_ALU32_IMM(BPF_MOV, R1, 1),
4005 			BPF_ALU64_REG(BPF_RSH, R0, R1),
4006 			BPF_EXIT_INSN(),
4007 		},
4008 		INTERNAL,
4009 		{ },
4010 		{ { 0, 1 } },
4011 	},
4012 	{
4013 		"ALU64_RSH_X: 0x80000000 >> 31 = 1",
4014 		.u.insns_int = {
4015 			BPF_LD_IMM64(R0, 0x80000000),
4016 			BPF_ALU32_IMM(BPF_MOV, R1, 31),
4017 			BPF_ALU64_REG(BPF_RSH, R0, R1),
4018 			BPF_EXIT_INSN(),
4019 		},
4020 		INTERNAL,
4021 		{ },
4022 		{ { 0, 1 } },
4023 	},
4024 	/* BPF_ALU | BPF_RSH | BPF_K */
4025 	{
4026 		"ALU_RSH_K: 2 >> 1 = 1",
4027 		.u.insns_int = {
4028 			BPF_LD_IMM64(R0, 2),
4029 			BPF_ALU32_IMM(BPF_RSH, R0, 1),
4030 			BPF_EXIT_INSN(),
4031 		},
4032 		INTERNAL,
4033 		{ },
4034 		{ { 0, 1 } },
4035 	},
4036 	{
4037 		"ALU_RSH_K: 0x80000000 >> 31 = 1",
4038 		.u.insns_int = {
4039 			BPF_LD_IMM64(R0, 0x80000000),
4040 			BPF_ALU32_IMM(BPF_RSH, R0, 31),
4041 			BPF_EXIT_INSN(),
4042 		},
4043 		INTERNAL,
4044 		{ },
4045 		{ { 0, 1 } },
4046 	},
4047 	{
4048 		"ALU64_RSH_K: 2 >> 1 = 1",
4049 		.u.insns_int = {
4050 			BPF_LD_IMM64(R0, 2),
4051 			BPF_ALU64_IMM(BPF_RSH, R0, 1),
4052 			BPF_EXIT_INSN(),
4053 		},
4054 		INTERNAL,
4055 		{ },
4056 		{ { 0, 1 } },
4057 	},
4058 	{
4059 		"ALU64_RSH_K: 0x80000000 >> 31 = 1",
4060 		.u.insns_int = {
4061 			BPF_LD_IMM64(R0, 0x80000000),
4062 			BPF_ALU64_IMM(BPF_RSH, R0, 31),
4063 			BPF_EXIT_INSN(),
4064 		},
4065 		INTERNAL,
4066 		{ },
4067 		{ { 0, 1 } },
4068 	},
4069 	/* BPF_ALU | BPF_ARSH | BPF_X */
4070 	{
4071 		"ALU_ARSH_X: 0xff00ff0000000000 >> 40 = 0xffffffffffff00ff",
4072 		.u.insns_int = {
4073 			BPF_LD_IMM64(R0, 0xff00ff0000000000LL),
4074 			BPF_ALU32_IMM(BPF_MOV, R1, 40),
4075 			BPF_ALU64_REG(BPF_ARSH, R0, R1),
4076 			BPF_EXIT_INSN(),
4077 		},
4078 		INTERNAL,
4079 		{ },
4080 		{ { 0, 0xffff00ff } },
4081 	},
4082 	/* BPF_ALU | BPF_ARSH | BPF_K */
4083 	{
4084 		"ALU_ARSH_K: 0xff00ff0000000000 >> 40 = 0xffffffffffff00ff",
4085 		.u.insns_int = {
4086 			BPF_LD_IMM64(R0, 0xff00ff0000000000LL),
4087 			BPF_ALU64_IMM(BPF_ARSH, R0, 40),
4088 			BPF_EXIT_INSN(),
4089 		},
4090 		INTERNAL,
4091 		{ },
4092 		{ { 0, 0xffff00ff } },
4093 	},
4094 	/* BPF_ALU | BPF_NEG */
4095 	{
4096 		"ALU_NEG: -(3) = -3",
4097 		.u.insns_int = {
4098 			BPF_ALU32_IMM(BPF_MOV, R0, 3),
4099 			BPF_ALU32_IMM(BPF_NEG, R0, 0),
4100 			BPF_EXIT_INSN(),
4101 		},
4102 		INTERNAL,
4103 		{ },
4104 		{ { 0, -3 } },
4105 	},
4106 	{
4107 		"ALU_NEG: -(-3) = 3",
4108 		.u.insns_int = {
4109 			BPF_ALU32_IMM(BPF_MOV, R0, -3),
4110 			BPF_ALU32_IMM(BPF_NEG, R0, 0),
4111 			BPF_EXIT_INSN(),
4112 		},
4113 		INTERNAL,
4114 		{ },
4115 		{ { 0, 3 } },
4116 	},
4117 	{
4118 		"ALU64_NEG: -(3) = -3",
4119 		.u.insns_int = {
4120 			BPF_LD_IMM64(R0, 3),
4121 			BPF_ALU64_IMM(BPF_NEG, R0, 0),
4122 			BPF_EXIT_INSN(),
4123 		},
4124 		INTERNAL,
4125 		{ },
4126 		{ { 0, -3 } },
4127 	},
4128 	{
4129 		"ALU64_NEG: -(-3) = 3",
4130 		.u.insns_int = {
4131 			BPF_LD_IMM64(R0, -3),
4132 			BPF_ALU64_IMM(BPF_NEG, R0, 0),
4133 			BPF_EXIT_INSN(),
4134 		},
4135 		INTERNAL,
4136 		{ },
4137 		{ { 0, 3 } },
4138 	},
4139 	/* BPF_ALU | BPF_END | BPF_FROM_BE */
4140 	{
4141 		"ALU_END_FROM_BE 16: 0x0123456789abcdef -> 0xcdef",
4142 		.u.insns_int = {
4143 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
4144 			BPF_ENDIAN(BPF_FROM_BE, R0, 16),
4145 			BPF_EXIT_INSN(),
4146 		},
4147 		INTERNAL,
4148 		{ },
4149 		{ { 0,  cpu_to_be16(0xcdef) } },
4150 	},
4151 	{
4152 		"ALU_END_FROM_BE 32: 0x0123456789abcdef -> 0x89abcdef",
4153 		.u.insns_int = {
4154 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
4155 			BPF_ENDIAN(BPF_FROM_BE, R0, 32),
4156 			BPF_ALU64_REG(BPF_MOV, R1, R0),
4157 			BPF_ALU64_IMM(BPF_RSH, R1, 32),
4158 			BPF_ALU32_REG(BPF_ADD, R0, R1), /* R1 = 0 */
4159 			BPF_EXIT_INSN(),
4160 		},
4161 		INTERNAL,
4162 		{ },
4163 		{ { 0, cpu_to_be32(0x89abcdef) } },
4164 	},
4165 	{
4166 		"ALU_END_FROM_BE 64: 0x0123456789abcdef -> 0x89abcdef",
4167 		.u.insns_int = {
4168 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
4169 			BPF_ENDIAN(BPF_FROM_BE, R0, 64),
4170 			BPF_EXIT_INSN(),
4171 		},
4172 		INTERNAL,
4173 		{ },
4174 		{ { 0, (u32) cpu_to_be64(0x0123456789abcdefLL) } },
4175 	},
4176 	/* BPF_ALU | BPF_END | BPF_FROM_LE */
4177 	{
4178 		"ALU_END_FROM_LE 16: 0x0123456789abcdef -> 0xefcd",
4179 		.u.insns_int = {
4180 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
4181 			BPF_ENDIAN(BPF_FROM_LE, R0, 16),
4182 			BPF_EXIT_INSN(),
4183 		},
4184 		INTERNAL,
4185 		{ },
4186 		{ { 0, cpu_to_le16(0xcdef) } },
4187 	},
4188 	{
4189 		"ALU_END_FROM_LE 32: 0x0123456789abcdef -> 0xefcdab89",
4190 		.u.insns_int = {
4191 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
4192 			BPF_ENDIAN(BPF_FROM_LE, R0, 32),
4193 			BPF_ALU64_REG(BPF_MOV, R1, R0),
4194 			BPF_ALU64_IMM(BPF_RSH, R1, 32),
4195 			BPF_ALU32_REG(BPF_ADD, R0, R1), /* R1 = 0 */
4196 			BPF_EXIT_INSN(),
4197 		},
4198 		INTERNAL,
4199 		{ },
4200 		{ { 0, cpu_to_le32(0x89abcdef) } },
4201 	},
4202 	{
4203 		"ALU_END_FROM_LE 64: 0x0123456789abcdef -> 0x67452301",
4204 		.u.insns_int = {
4205 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
4206 			BPF_ENDIAN(BPF_FROM_LE, R0, 64),
4207 			BPF_EXIT_INSN(),
4208 		},
4209 		INTERNAL,
4210 		{ },
4211 		{ { 0, (u32) cpu_to_le64(0x0123456789abcdefLL) } },
4212 	},
4213 	/* BPF_ST(X) | BPF_MEM | BPF_B/H/W/DW */
4214 	{
4215 		"ST_MEM_B: Store/Load byte: max negative",
4216 		.u.insns_int = {
4217 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4218 			BPF_ST_MEM(BPF_B, R10, -40, 0xff),
4219 			BPF_LDX_MEM(BPF_B, R0, R10, -40),
4220 			BPF_EXIT_INSN(),
4221 		},
4222 		INTERNAL,
4223 		{ },
4224 		{ { 0, 0xff } },
4225 		.stack_depth = 40,
4226 	},
4227 	{
4228 		"ST_MEM_B: Store/Load byte: max positive",
4229 		.u.insns_int = {
4230 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4231 			BPF_ST_MEM(BPF_H, R10, -40, 0x7f),
4232 			BPF_LDX_MEM(BPF_H, R0, R10, -40),
4233 			BPF_EXIT_INSN(),
4234 		},
4235 		INTERNAL,
4236 		{ },
4237 		{ { 0, 0x7f } },
4238 		.stack_depth = 40,
4239 	},
4240 	{
4241 		"STX_MEM_B: Store/Load byte: max negative",
4242 		.u.insns_int = {
4243 			BPF_LD_IMM64(R0, 0),
4244 			BPF_LD_IMM64(R1, 0xffLL),
4245 			BPF_STX_MEM(BPF_B, R10, R1, -40),
4246 			BPF_LDX_MEM(BPF_B, R0, R10, -40),
4247 			BPF_EXIT_INSN(),
4248 		},
4249 		INTERNAL,
4250 		{ },
4251 		{ { 0, 0xff } },
4252 		.stack_depth = 40,
4253 	},
4254 	{
4255 		"ST_MEM_H: Store/Load half word: max negative",
4256 		.u.insns_int = {
4257 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4258 			BPF_ST_MEM(BPF_H, R10, -40, 0xffff),
4259 			BPF_LDX_MEM(BPF_H, R0, R10, -40),
4260 			BPF_EXIT_INSN(),
4261 		},
4262 		INTERNAL,
4263 		{ },
4264 		{ { 0, 0xffff } },
4265 		.stack_depth = 40,
4266 	},
4267 	{
4268 		"ST_MEM_H: Store/Load half word: max positive",
4269 		.u.insns_int = {
4270 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4271 			BPF_ST_MEM(BPF_H, R10, -40, 0x7fff),
4272 			BPF_LDX_MEM(BPF_H, R0, R10, -40),
4273 			BPF_EXIT_INSN(),
4274 		},
4275 		INTERNAL,
4276 		{ },
4277 		{ { 0, 0x7fff } },
4278 		.stack_depth = 40,
4279 	},
4280 	{
4281 		"STX_MEM_H: Store/Load half word: max negative",
4282 		.u.insns_int = {
4283 			BPF_LD_IMM64(R0, 0),
4284 			BPF_LD_IMM64(R1, 0xffffLL),
4285 			BPF_STX_MEM(BPF_H, R10, R1, -40),
4286 			BPF_LDX_MEM(BPF_H, R0, R10, -40),
4287 			BPF_EXIT_INSN(),
4288 		},
4289 		INTERNAL,
4290 		{ },
4291 		{ { 0, 0xffff } },
4292 		.stack_depth = 40,
4293 	},
4294 	{
4295 		"ST_MEM_W: Store/Load word: max negative",
4296 		.u.insns_int = {
4297 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4298 			BPF_ST_MEM(BPF_W, R10, -40, 0xffffffff),
4299 			BPF_LDX_MEM(BPF_W, R0, R10, -40),
4300 			BPF_EXIT_INSN(),
4301 		},
4302 		INTERNAL,
4303 		{ },
4304 		{ { 0, 0xffffffff } },
4305 		.stack_depth = 40,
4306 	},
4307 	{
4308 		"ST_MEM_W: Store/Load word: max positive",
4309 		.u.insns_int = {
4310 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4311 			BPF_ST_MEM(BPF_W, R10, -40, 0x7fffffff),
4312 			BPF_LDX_MEM(BPF_W, R0, R10, -40),
4313 			BPF_EXIT_INSN(),
4314 		},
4315 		INTERNAL,
4316 		{ },
4317 		{ { 0, 0x7fffffff } },
4318 		.stack_depth = 40,
4319 	},
4320 	{
4321 		"STX_MEM_W: Store/Load word: max negative",
4322 		.u.insns_int = {
4323 			BPF_LD_IMM64(R0, 0),
4324 			BPF_LD_IMM64(R1, 0xffffffffLL),
4325 			BPF_STX_MEM(BPF_W, R10, R1, -40),
4326 			BPF_LDX_MEM(BPF_W, R0, R10, -40),
4327 			BPF_EXIT_INSN(),
4328 		},
4329 		INTERNAL,
4330 		{ },
4331 		{ { 0, 0xffffffff } },
4332 		.stack_depth = 40,
4333 	},
4334 	{
4335 		"ST_MEM_DW: Store/Load double word: max negative",
4336 		.u.insns_int = {
4337 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4338 			BPF_ST_MEM(BPF_DW, R10, -40, 0xffffffff),
4339 			BPF_LDX_MEM(BPF_DW, R0, R10, -40),
4340 			BPF_EXIT_INSN(),
4341 		},
4342 		INTERNAL,
4343 		{ },
4344 		{ { 0, 0xffffffff } },
4345 		.stack_depth = 40,
4346 	},
4347 	{
4348 		"ST_MEM_DW: Store/Load double word: max negative 2",
4349 		.u.insns_int = {
4350 			BPF_LD_IMM64(R2, 0xffff00000000ffffLL),
4351 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
4352 			BPF_ST_MEM(BPF_DW, R10, -40, 0xffffffff),
4353 			BPF_LDX_MEM(BPF_DW, R2, R10, -40),
4354 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
4355 			BPF_MOV32_IMM(R0, 2),
4356 			BPF_EXIT_INSN(),
4357 			BPF_MOV32_IMM(R0, 1),
4358 			BPF_EXIT_INSN(),
4359 		},
4360 		INTERNAL,
4361 		{ },
4362 		{ { 0, 0x1 } },
4363 		.stack_depth = 40,
4364 	},
4365 	{
4366 		"ST_MEM_DW: Store/Load double word: max positive",
4367 		.u.insns_int = {
4368 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4369 			BPF_ST_MEM(BPF_DW, R10, -40, 0x7fffffff),
4370 			BPF_LDX_MEM(BPF_DW, R0, R10, -40),
4371 			BPF_EXIT_INSN(),
4372 		},
4373 		INTERNAL,
4374 		{ },
4375 		{ { 0, 0x7fffffff } },
4376 		.stack_depth = 40,
4377 	},
4378 	{
4379 		"STX_MEM_DW: Store/Load double word: max negative",
4380 		.u.insns_int = {
4381 			BPF_LD_IMM64(R0, 0),
4382 			BPF_LD_IMM64(R1, 0xffffffffffffffffLL),
4383 			BPF_STX_MEM(BPF_W, R10, R1, -40),
4384 			BPF_LDX_MEM(BPF_W, R0, R10, -40),
4385 			BPF_EXIT_INSN(),
4386 		},
4387 		INTERNAL,
4388 		{ },
4389 		{ { 0, 0xffffffff } },
4390 		.stack_depth = 40,
4391 	},
4392 	/* BPF_STX | BPF_XADD | BPF_W/DW */
4393 	{
4394 		"STX_XADD_W: Test: 0x12 + 0x10 = 0x22",
4395 		.u.insns_int = {
4396 			BPF_ALU32_IMM(BPF_MOV, R0, 0x12),
4397 			BPF_ST_MEM(BPF_W, R10, -40, 0x10),
4398 			BPF_STX_XADD(BPF_W, R10, R0, -40),
4399 			BPF_LDX_MEM(BPF_W, R0, R10, -40),
4400 			BPF_EXIT_INSN(),
4401 		},
4402 		INTERNAL,
4403 		{ },
4404 		{ { 0, 0x22 } },
4405 		.stack_depth = 40,
4406 	},
4407 	{
4408 		"STX_XADD_W: Test side-effects, r10: 0x12 + 0x10 = 0x22",
4409 		.u.insns_int = {
4410 			BPF_ALU64_REG(BPF_MOV, R1, R10),
4411 			BPF_ALU32_IMM(BPF_MOV, R0, 0x12),
4412 			BPF_ST_MEM(BPF_W, R10, -40, 0x10),
4413 			BPF_STX_XADD(BPF_W, R10, R0, -40),
4414 			BPF_ALU64_REG(BPF_MOV, R0, R10),
4415 			BPF_ALU64_REG(BPF_SUB, R0, R1),
4416 			BPF_EXIT_INSN(),
4417 		},
4418 		INTERNAL,
4419 		{ },
4420 		{ { 0, 0 } },
4421 		.stack_depth = 40,
4422 	},
4423 	{
4424 		"STX_XADD_W: Test side-effects, r0: 0x12 + 0x10 = 0x22",
4425 		.u.insns_int = {
4426 			BPF_ALU32_IMM(BPF_MOV, R0, 0x12),
4427 			BPF_ST_MEM(BPF_W, R10, -40, 0x10),
4428 			BPF_STX_XADD(BPF_W, R10, R0, -40),
4429 			BPF_EXIT_INSN(),
4430 		},
4431 		INTERNAL,
4432 		{ },
4433 		{ { 0, 0x12 } },
4434 		.stack_depth = 40,
4435 	},
4436 	{
4437 		"STX_XADD_W: X + 1 + 1 + 1 + ...",
4438 		{ },
4439 		INTERNAL,
4440 		{ },
4441 		{ { 0, 4134 } },
4442 		.fill_helper = bpf_fill_stxw,
4443 	},
4444 	{
4445 		"STX_XADD_DW: Test: 0x12 + 0x10 = 0x22",
4446 		.u.insns_int = {
4447 			BPF_ALU32_IMM(BPF_MOV, R0, 0x12),
4448 			BPF_ST_MEM(BPF_DW, R10, -40, 0x10),
4449 			BPF_STX_XADD(BPF_DW, R10, R0, -40),
4450 			BPF_LDX_MEM(BPF_DW, R0, R10, -40),
4451 			BPF_EXIT_INSN(),
4452 		},
4453 		INTERNAL,
4454 		{ },
4455 		{ { 0, 0x22 } },
4456 		.stack_depth = 40,
4457 	},
4458 	{
4459 		"STX_XADD_DW: Test side-effects, r10: 0x12 + 0x10 = 0x22",
4460 		.u.insns_int = {
4461 			BPF_ALU64_REG(BPF_MOV, R1, R10),
4462 			BPF_ALU32_IMM(BPF_MOV, R0, 0x12),
4463 			BPF_ST_MEM(BPF_DW, R10, -40, 0x10),
4464 			BPF_STX_XADD(BPF_DW, R10, R0, -40),
4465 			BPF_ALU64_REG(BPF_MOV, R0, R10),
4466 			BPF_ALU64_REG(BPF_SUB, R0, R1),
4467 			BPF_EXIT_INSN(),
4468 		},
4469 		INTERNAL,
4470 		{ },
4471 		{ { 0, 0 } },
4472 		.stack_depth = 40,
4473 	},
4474 	{
4475 		"STX_XADD_DW: Test side-effects, r0: 0x12 + 0x10 = 0x22",
4476 		.u.insns_int = {
4477 			BPF_ALU32_IMM(BPF_MOV, R0, 0x12),
4478 			BPF_ST_MEM(BPF_DW, R10, -40, 0x10),
4479 			BPF_STX_XADD(BPF_DW, R10, R0, -40),
4480 			BPF_EXIT_INSN(),
4481 		},
4482 		INTERNAL,
4483 		{ },
4484 		{ { 0, 0x12 } },
4485 		.stack_depth = 40,
4486 	},
4487 	{
4488 		"STX_XADD_DW: X + 1 + 1 + 1 + ...",
4489 		{ },
4490 		INTERNAL,
4491 		{ },
4492 		{ { 0, 4134 } },
4493 		.fill_helper = bpf_fill_stxdw,
4494 	},
4495 	/* BPF_JMP | BPF_EXIT */
4496 	{
4497 		"JMP_EXIT",
4498 		.u.insns_int = {
4499 			BPF_ALU32_IMM(BPF_MOV, R0, 0x4711),
4500 			BPF_EXIT_INSN(),
4501 			BPF_ALU32_IMM(BPF_MOV, R0, 0x4712),
4502 		},
4503 		INTERNAL,
4504 		{ },
4505 		{ { 0, 0x4711 } },
4506 	},
4507 	/* BPF_JMP | BPF_JA */
4508 	{
4509 		"JMP_JA: Unconditional jump: if (true) return 1",
4510 		.u.insns_int = {
4511 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4512 			BPF_JMP_IMM(BPF_JA, 0, 0, 1),
4513 			BPF_EXIT_INSN(),
4514 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4515 			BPF_EXIT_INSN(),
4516 		},
4517 		INTERNAL,
4518 		{ },
4519 		{ { 0, 1 } },
4520 	},
4521 	/* BPF_JMP | BPF_JSLT | BPF_K */
4522 	{
4523 		"JMP_JSLT_K: Signed jump: if (-2 < -1) return 1",
4524 		.u.insns_int = {
4525 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4526 			BPF_LD_IMM64(R1, 0xfffffffffffffffeLL),
4527 			BPF_JMP_IMM(BPF_JSLT, R1, -1, 1),
4528 			BPF_EXIT_INSN(),
4529 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4530 			BPF_EXIT_INSN(),
4531 		},
4532 		INTERNAL,
4533 		{ },
4534 		{ { 0, 1 } },
4535 	},
4536 	{
4537 		"JMP_JSLT_K: Signed jump: if (-1 < -1) return 0",
4538 		.u.insns_int = {
4539 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4540 			BPF_LD_IMM64(R1, 0xffffffffffffffffLL),
4541 			BPF_JMP_IMM(BPF_JSLT, R1, -1, 1),
4542 			BPF_EXIT_INSN(),
4543 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4544 			BPF_EXIT_INSN(),
4545 		},
4546 		INTERNAL,
4547 		{ },
4548 		{ { 0, 1 } },
4549 	},
4550 	/* BPF_JMP | BPF_JSGT | BPF_K */
4551 	{
4552 		"JMP_JSGT_K: Signed jump: if (-1 > -2) return 1",
4553 		.u.insns_int = {
4554 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4555 			BPF_LD_IMM64(R1, 0xffffffffffffffffLL),
4556 			BPF_JMP_IMM(BPF_JSGT, R1, -2, 1),
4557 			BPF_EXIT_INSN(),
4558 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4559 			BPF_EXIT_INSN(),
4560 		},
4561 		INTERNAL,
4562 		{ },
4563 		{ { 0, 1 } },
4564 	},
4565 	{
4566 		"JMP_JSGT_K: Signed jump: if (-1 > -1) return 0",
4567 		.u.insns_int = {
4568 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4569 			BPF_LD_IMM64(R1, 0xffffffffffffffffLL),
4570 			BPF_JMP_IMM(BPF_JSGT, R1, -1, 1),
4571 			BPF_EXIT_INSN(),
4572 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4573 			BPF_EXIT_INSN(),
4574 		},
4575 		INTERNAL,
4576 		{ },
4577 		{ { 0, 1 } },
4578 	},
4579 	/* BPF_JMP | BPF_JSLE | BPF_K */
4580 	{
4581 		"JMP_JSLE_K: Signed jump: if (-2 <= -1) return 1",
4582 		.u.insns_int = {
4583 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4584 			BPF_LD_IMM64(R1, 0xfffffffffffffffeLL),
4585 			BPF_JMP_IMM(BPF_JSLE, R1, -1, 1),
4586 			BPF_EXIT_INSN(),
4587 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4588 			BPF_EXIT_INSN(),
4589 		},
4590 		INTERNAL,
4591 		{ },
4592 		{ { 0, 1 } },
4593 	},
4594 	{
4595 		"JMP_JSLE_K: Signed jump: if (-1 <= -1) return 1",
4596 		.u.insns_int = {
4597 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4598 			BPF_LD_IMM64(R1, 0xffffffffffffffffLL),
4599 			BPF_JMP_IMM(BPF_JSLE, R1, -1, 1),
4600 			BPF_EXIT_INSN(),
4601 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4602 			BPF_EXIT_INSN(),
4603 		},
4604 		INTERNAL,
4605 		{ },
4606 		{ { 0, 1 } },
4607 	},
4608 	{
4609 		"JMP_JSLE_K: Signed jump: value walk 1",
4610 		.u.insns_int = {
4611 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4612 			BPF_LD_IMM64(R1, 3),
4613 			BPF_JMP_IMM(BPF_JSLE, R1, 0, 6),
4614 			BPF_ALU64_IMM(BPF_SUB, R1, 1),
4615 			BPF_JMP_IMM(BPF_JSLE, R1, 0, 4),
4616 			BPF_ALU64_IMM(BPF_SUB, R1, 1),
4617 			BPF_JMP_IMM(BPF_JSLE, R1, 0, 2),
4618 			BPF_ALU64_IMM(BPF_SUB, R1, 1),
4619 			BPF_JMP_IMM(BPF_JSLE, R1, 0, 1),
4620 			BPF_EXIT_INSN(),		/* bad exit */
4621 			BPF_ALU32_IMM(BPF_MOV, R0, 1),	/* good exit */
4622 			BPF_EXIT_INSN(),
4623 		},
4624 		INTERNAL,
4625 		{ },
4626 		{ { 0, 1 } },
4627 	},
4628 	{
4629 		"JMP_JSLE_K: Signed jump: value walk 2",
4630 		.u.insns_int = {
4631 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4632 			BPF_LD_IMM64(R1, 3),
4633 			BPF_JMP_IMM(BPF_JSLE, R1, 0, 4),
4634 			BPF_ALU64_IMM(BPF_SUB, R1, 2),
4635 			BPF_JMP_IMM(BPF_JSLE, R1, 0, 2),
4636 			BPF_ALU64_IMM(BPF_SUB, R1, 2),
4637 			BPF_JMP_IMM(BPF_JSLE, R1, 0, 1),
4638 			BPF_EXIT_INSN(),		/* bad exit */
4639 			BPF_ALU32_IMM(BPF_MOV, R0, 1),	/* good exit */
4640 			BPF_EXIT_INSN(),
4641 		},
4642 		INTERNAL,
4643 		{ },
4644 		{ { 0, 1 } },
4645 	},
4646 	/* BPF_JMP | BPF_JSGE | BPF_K */
4647 	{
4648 		"JMP_JSGE_K: Signed jump: if (-1 >= -2) return 1",
4649 		.u.insns_int = {
4650 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4651 			BPF_LD_IMM64(R1, 0xffffffffffffffffLL),
4652 			BPF_JMP_IMM(BPF_JSGE, R1, -2, 1),
4653 			BPF_EXIT_INSN(),
4654 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4655 			BPF_EXIT_INSN(),
4656 		},
4657 		INTERNAL,
4658 		{ },
4659 		{ { 0, 1 } },
4660 	},
4661 	{
4662 		"JMP_JSGE_K: Signed jump: if (-1 >= -1) return 1",
4663 		.u.insns_int = {
4664 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4665 			BPF_LD_IMM64(R1, 0xffffffffffffffffLL),
4666 			BPF_JMP_IMM(BPF_JSGE, R1, -1, 1),
4667 			BPF_EXIT_INSN(),
4668 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4669 			BPF_EXIT_INSN(),
4670 		},
4671 		INTERNAL,
4672 		{ },
4673 		{ { 0, 1 } },
4674 	},
4675 	{
4676 		"JMP_JSGE_K: Signed jump: value walk 1",
4677 		.u.insns_int = {
4678 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4679 			BPF_LD_IMM64(R1, -3),
4680 			BPF_JMP_IMM(BPF_JSGE, R1, 0, 6),
4681 			BPF_ALU64_IMM(BPF_ADD, R1, 1),
4682 			BPF_JMP_IMM(BPF_JSGE, R1, 0, 4),
4683 			BPF_ALU64_IMM(BPF_ADD, R1, 1),
4684 			BPF_JMP_IMM(BPF_JSGE, R1, 0, 2),
4685 			BPF_ALU64_IMM(BPF_ADD, R1, 1),
4686 			BPF_JMP_IMM(BPF_JSGE, R1, 0, 1),
4687 			BPF_EXIT_INSN(),		/* bad exit */
4688 			BPF_ALU32_IMM(BPF_MOV, R0, 1),	/* good exit */
4689 			BPF_EXIT_INSN(),
4690 		},
4691 		INTERNAL,
4692 		{ },
4693 		{ { 0, 1 } },
4694 	},
4695 	{
4696 		"JMP_JSGE_K: Signed jump: value walk 2",
4697 		.u.insns_int = {
4698 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4699 			BPF_LD_IMM64(R1, -3),
4700 			BPF_JMP_IMM(BPF_JSGE, R1, 0, 4),
4701 			BPF_ALU64_IMM(BPF_ADD, R1, 2),
4702 			BPF_JMP_IMM(BPF_JSGE, R1, 0, 2),
4703 			BPF_ALU64_IMM(BPF_ADD, R1, 2),
4704 			BPF_JMP_IMM(BPF_JSGE, R1, 0, 1),
4705 			BPF_EXIT_INSN(),		/* bad exit */
4706 			BPF_ALU32_IMM(BPF_MOV, R0, 1),	/* good exit */
4707 			BPF_EXIT_INSN(),
4708 		},
4709 		INTERNAL,
4710 		{ },
4711 		{ { 0, 1 } },
4712 	},
4713 	/* BPF_JMP | BPF_JGT | BPF_K */
4714 	{
4715 		"JMP_JGT_K: if (3 > 2) return 1",
4716 		.u.insns_int = {
4717 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4718 			BPF_LD_IMM64(R1, 3),
4719 			BPF_JMP_IMM(BPF_JGT, R1, 2, 1),
4720 			BPF_EXIT_INSN(),
4721 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4722 			BPF_EXIT_INSN(),
4723 		},
4724 		INTERNAL,
4725 		{ },
4726 		{ { 0, 1 } },
4727 	},
4728 	{
4729 		"JMP_JGT_K: Unsigned jump: if (-1 > 1) return 1",
4730 		.u.insns_int = {
4731 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4732 			BPF_LD_IMM64(R1, -1),
4733 			BPF_JMP_IMM(BPF_JGT, R1, 1, 1),
4734 			BPF_EXIT_INSN(),
4735 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4736 			BPF_EXIT_INSN(),
4737 		},
4738 		INTERNAL,
4739 		{ },
4740 		{ { 0, 1 } },
4741 	},
4742 	/* BPF_JMP | BPF_JLT | BPF_K */
4743 	{
4744 		"JMP_JLT_K: if (2 < 3) return 1",
4745 		.u.insns_int = {
4746 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4747 			BPF_LD_IMM64(R1, 2),
4748 			BPF_JMP_IMM(BPF_JLT, R1, 3, 1),
4749 			BPF_EXIT_INSN(),
4750 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4751 			BPF_EXIT_INSN(),
4752 		},
4753 		INTERNAL,
4754 		{ },
4755 		{ { 0, 1 } },
4756 	},
4757 	{
4758 		"JMP_JGT_K: Unsigned jump: if (1 < -1) return 1",
4759 		.u.insns_int = {
4760 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4761 			BPF_LD_IMM64(R1, 1),
4762 			BPF_JMP_IMM(BPF_JLT, R1, -1, 1),
4763 			BPF_EXIT_INSN(),
4764 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4765 			BPF_EXIT_INSN(),
4766 		},
4767 		INTERNAL,
4768 		{ },
4769 		{ { 0, 1 } },
4770 	},
4771 	/* BPF_JMP | BPF_JGE | BPF_K */
4772 	{
4773 		"JMP_JGE_K: if (3 >= 2) return 1",
4774 		.u.insns_int = {
4775 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4776 			BPF_LD_IMM64(R1, 3),
4777 			BPF_JMP_IMM(BPF_JGE, R1, 2, 1),
4778 			BPF_EXIT_INSN(),
4779 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4780 			BPF_EXIT_INSN(),
4781 		},
4782 		INTERNAL,
4783 		{ },
4784 		{ { 0, 1 } },
4785 	},
4786 	/* BPF_JMP | BPF_JLE | BPF_K */
4787 	{
4788 		"JMP_JLE_K: if (2 <= 3) return 1",
4789 		.u.insns_int = {
4790 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4791 			BPF_LD_IMM64(R1, 2),
4792 			BPF_JMP_IMM(BPF_JLE, R1, 3, 1),
4793 			BPF_EXIT_INSN(),
4794 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4795 			BPF_EXIT_INSN(),
4796 		},
4797 		INTERNAL,
4798 		{ },
4799 		{ { 0, 1 } },
4800 	},
4801 	/* BPF_JMP | BPF_JGT | BPF_K jump backwards */
4802 	{
4803 		"JMP_JGT_K: if (3 > 2) return 1 (jump backwards)",
4804 		.u.insns_int = {
4805 			BPF_JMP_IMM(BPF_JA, 0, 0, 2), /* goto start */
4806 			BPF_ALU32_IMM(BPF_MOV, R0, 1), /* out: */
4807 			BPF_EXIT_INSN(),
4808 			BPF_ALU32_IMM(BPF_MOV, R0, 0), /* start: */
4809 			BPF_LD_IMM64(R1, 3), /* note: this takes 2 insns */
4810 			BPF_JMP_IMM(BPF_JGT, R1, 2, -6), /* goto out */
4811 			BPF_EXIT_INSN(),
4812 		},
4813 		INTERNAL,
4814 		{ },
4815 		{ { 0, 1 } },
4816 	},
4817 	{
4818 		"JMP_JGE_K: if (3 >= 3) return 1",
4819 		.u.insns_int = {
4820 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4821 			BPF_LD_IMM64(R1, 3),
4822 			BPF_JMP_IMM(BPF_JGE, R1, 3, 1),
4823 			BPF_EXIT_INSN(),
4824 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4825 			BPF_EXIT_INSN(),
4826 		},
4827 		INTERNAL,
4828 		{ },
4829 		{ { 0, 1 } },
4830 	},
4831 	/* BPF_JMP | BPF_JLT | BPF_K jump backwards */
4832 	{
4833 		"JMP_JGT_K: if (2 < 3) return 1 (jump backwards)",
4834 		.u.insns_int = {
4835 			BPF_JMP_IMM(BPF_JA, 0, 0, 2), /* goto start */
4836 			BPF_ALU32_IMM(BPF_MOV, R0, 1), /* out: */
4837 			BPF_EXIT_INSN(),
4838 			BPF_ALU32_IMM(BPF_MOV, R0, 0), /* start: */
4839 			BPF_LD_IMM64(R1, 2), /* note: this takes 2 insns */
4840 			BPF_JMP_IMM(BPF_JLT, R1, 3, -6), /* goto out */
4841 			BPF_EXIT_INSN(),
4842 		},
4843 		INTERNAL,
4844 		{ },
4845 		{ { 0, 1 } },
4846 	},
4847 	{
4848 		"JMP_JLE_K: if (3 <= 3) return 1",
4849 		.u.insns_int = {
4850 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4851 			BPF_LD_IMM64(R1, 3),
4852 			BPF_JMP_IMM(BPF_JLE, R1, 3, 1),
4853 			BPF_EXIT_INSN(),
4854 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4855 			BPF_EXIT_INSN(),
4856 		},
4857 		INTERNAL,
4858 		{ },
4859 		{ { 0, 1 } },
4860 	},
4861 	/* BPF_JMP | BPF_JNE | BPF_K */
4862 	{
4863 		"JMP_JNE_K: if (3 != 2) return 1",
4864 		.u.insns_int = {
4865 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4866 			BPF_LD_IMM64(R1, 3),
4867 			BPF_JMP_IMM(BPF_JNE, R1, 2, 1),
4868 			BPF_EXIT_INSN(),
4869 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4870 			BPF_EXIT_INSN(),
4871 		},
4872 		INTERNAL,
4873 		{ },
4874 		{ { 0, 1 } },
4875 	},
4876 	/* BPF_JMP | BPF_JEQ | BPF_K */
4877 	{
4878 		"JMP_JEQ_K: if (3 == 3) return 1",
4879 		.u.insns_int = {
4880 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4881 			BPF_LD_IMM64(R1, 3),
4882 			BPF_JMP_IMM(BPF_JEQ, R1, 3, 1),
4883 			BPF_EXIT_INSN(),
4884 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4885 			BPF_EXIT_INSN(),
4886 		},
4887 		INTERNAL,
4888 		{ },
4889 		{ { 0, 1 } },
4890 	},
4891 	/* BPF_JMP | BPF_JSET | BPF_K */
4892 	{
4893 		"JMP_JSET_K: if (0x3 & 0x2) return 1",
4894 		.u.insns_int = {
4895 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4896 			BPF_LD_IMM64(R1, 3),
4897 			BPF_JMP_IMM(BPF_JSET, R1, 2, 1),
4898 			BPF_EXIT_INSN(),
4899 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4900 			BPF_EXIT_INSN(),
4901 		},
4902 		INTERNAL,
4903 		{ },
4904 		{ { 0, 1 } },
4905 	},
4906 	{
4907 		"JMP_JSET_K: if (0x3 & 0xffffffff) return 1",
4908 		.u.insns_int = {
4909 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4910 			BPF_LD_IMM64(R1, 3),
4911 			BPF_JMP_IMM(BPF_JSET, R1, 0xffffffff, 1),
4912 			BPF_EXIT_INSN(),
4913 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4914 			BPF_EXIT_INSN(),
4915 		},
4916 		INTERNAL,
4917 		{ },
4918 		{ { 0, 1 } },
4919 	},
4920 	/* BPF_JMP | BPF_JSGT | BPF_X */
4921 	{
4922 		"JMP_JSGT_X: Signed jump: if (-1 > -2) return 1",
4923 		.u.insns_int = {
4924 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4925 			BPF_LD_IMM64(R1, -1),
4926 			BPF_LD_IMM64(R2, -2),
4927 			BPF_JMP_REG(BPF_JSGT, R1, R2, 1),
4928 			BPF_EXIT_INSN(),
4929 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4930 			BPF_EXIT_INSN(),
4931 		},
4932 		INTERNAL,
4933 		{ },
4934 		{ { 0, 1 } },
4935 	},
4936 	{
4937 		"JMP_JSGT_X: Signed jump: if (-1 > -1) return 0",
4938 		.u.insns_int = {
4939 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4940 			BPF_LD_IMM64(R1, -1),
4941 			BPF_LD_IMM64(R2, -1),
4942 			BPF_JMP_REG(BPF_JSGT, R1, R2, 1),
4943 			BPF_EXIT_INSN(),
4944 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4945 			BPF_EXIT_INSN(),
4946 		},
4947 		INTERNAL,
4948 		{ },
4949 		{ { 0, 1 } },
4950 	},
4951 	/* BPF_JMP | BPF_JSLT | BPF_X */
4952 	{
4953 		"JMP_JSLT_X: Signed jump: if (-2 < -1) return 1",
4954 		.u.insns_int = {
4955 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4956 			BPF_LD_IMM64(R1, -1),
4957 			BPF_LD_IMM64(R2, -2),
4958 			BPF_JMP_REG(BPF_JSLT, R2, R1, 1),
4959 			BPF_EXIT_INSN(),
4960 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4961 			BPF_EXIT_INSN(),
4962 		},
4963 		INTERNAL,
4964 		{ },
4965 		{ { 0, 1 } },
4966 	},
4967 	{
4968 		"JMP_JSLT_X: Signed jump: if (-1 < -1) return 0",
4969 		.u.insns_int = {
4970 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4971 			BPF_LD_IMM64(R1, -1),
4972 			BPF_LD_IMM64(R2, -1),
4973 			BPF_JMP_REG(BPF_JSLT, R1, R2, 1),
4974 			BPF_EXIT_INSN(),
4975 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4976 			BPF_EXIT_INSN(),
4977 		},
4978 		INTERNAL,
4979 		{ },
4980 		{ { 0, 1 } },
4981 	},
4982 	/* BPF_JMP | BPF_JSGE | BPF_X */
4983 	{
4984 		"JMP_JSGE_X: Signed jump: if (-1 >= -2) return 1",
4985 		.u.insns_int = {
4986 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4987 			BPF_LD_IMM64(R1, -1),
4988 			BPF_LD_IMM64(R2, -2),
4989 			BPF_JMP_REG(BPF_JSGE, R1, R2, 1),
4990 			BPF_EXIT_INSN(),
4991 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4992 			BPF_EXIT_INSN(),
4993 		},
4994 		INTERNAL,
4995 		{ },
4996 		{ { 0, 1 } },
4997 	},
4998 	{
4999 		"JMP_JSGE_X: Signed jump: if (-1 >= -1) return 1",
5000 		.u.insns_int = {
5001 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5002 			BPF_LD_IMM64(R1, -1),
5003 			BPF_LD_IMM64(R2, -1),
5004 			BPF_JMP_REG(BPF_JSGE, R1, R2, 1),
5005 			BPF_EXIT_INSN(),
5006 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5007 			BPF_EXIT_INSN(),
5008 		},
5009 		INTERNAL,
5010 		{ },
5011 		{ { 0, 1 } },
5012 	},
5013 	/* BPF_JMP | BPF_JSLE | BPF_X */
5014 	{
5015 		"JMP_JSLE_X: Signed jump: if (-2 <= -1) return 1",
5016 		.u.insns_int = {
5017 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5018 			BPF_LD_IMM64(R1, -1),
5019 			BPF_LD_IMM64(R2, -2),
5020 			BPF_JMP_REG(BPF_JSLE, R2, R1, 1),
5021 			BPF_EXIT_INSN(),
5022 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5023 			BPF_EXIT_INSN(),
5024 		},
5025 		INTERNAL,
5026 		{ },
5027 		{ { 0, 1 } },
5028 	},
5029 	{
5030 		"JMP_JSLE_X: Signed jump: if (-1 <= -1) return 1",
5031 		.u.insns_int = {
5032 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5033 			BPF_LD_IMM64(R1, -1),
5034 			BPF_LD_IMM64(R2, -1),
5035 			BPF_JMP_REG(BPF_JSLE, R1, R2, 1),
5036 			BPF_EXIT_INSN(),
5037 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5038 			BPF_EXIT_INSN(),
5039 		},
5040 		INTERNAL,
5041 		{ },
5042 		{ { 0, 1 } },
5043 	},
5044 	/* BPF_JMP | BPF_JGT | BPF_X */
5045 	{
5046 		"JMP_JGT_X: if (3 > 2) return 1",
5047 		.u.insns_int = {
5048 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5049 			BPF_LD_IMM64(R1, 3),
5050 			BPF_LD_IMM64(R2, 2),
5051 			BPF_JMP_REG(BPF_JGT, R1, R2, 1),
5052 			BPF_EXIT_INSN(),
5053 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5054 			BPF_EXIT_INSN(),
5055 		},
5056 		INTERNAL,
5057 		{ },
5058 		{ { 0, 1 } },
5059 	},
5060 	{
5061 		"JMP_JGT_X: Unsigned jump: if (-1 > 1) return 1",
5062 		.u.insns_int = {
5063 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5064 			BPF_LD_IMM64(R1, -1),
5065 			BPF_LD_IMM64(R2, 1),
5066 			BPF_JMP_REG(BPF_JGT, R1, R2, 1),
5067 			BPF_EXIT_INSN(),
5068 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5069 			BPF_EXIT_INSN(),
5070 		},
5071 		INTERNAL,
5072 		{ },
5073 		{ { 0, 1 } },
5074 	},
5075 	/* BPF_JMP | BPF_JLT | BPF_X */
5076 	{
5077 		"JMP_JLT_X: if (2 < 3) return 1",
5078 		.u.insns_int = {
5079 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5080 			BPF_LD_IMM64(R1, 3),
5081 			BPF_LD_IMM64(R2, 2),
5082 			BPF_JMP_REG(BPF_JLT, R2, R1, 1),
5083 			BPF_EXIT_INSN(),
5084 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5085 			BPF_EXIT_INSN(),
5086 		},
5087 		INTERNAL,
5088 		{ },
5089 		{ { 0, 1 } },
5090 	},
5091 	{
5092 		"JMP_JLT_X: Unsigned jump: if (1 < -1) return 1",
5093 		.u.insns_int = {
5094 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5095 			BPF_LD_IMM64(R1, -1),
5096 			BPF_LD_IMM64(R2, 1),
5097 			BPF_JMP_REG(BPF_JLT, R2, R1, 1),
5098 			BPF_EXIT_INSN(),
5099 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5100 			BPF_EXIT_INSN(),
5101 		},
5102 		INTERNAL,
5103 		{ },
5104 		{ { 0, 1 } },
5105 	},
5106 	/* BPF_JMP | BPF_JGE | BPF_X */
5107 	{
5108 		"JMP_JGE_X: if (3 >= 2) return 1",
5109 		.u.insns_int = {
5110 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5111 			BPF_LD_IMM64(R1, 3),
5112 			BPF_LD_IMM64(R2, 2),
5113 			BPF_JMP_REG(BPF_JGE, R1, R2, 1),
5114 			BPF_EXIT_INSN(),
5115 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5116 			BPF_EXIT_INSN(),
5117 		},
5118 		INTERNAL,
5119 		{ },
5120 		{ { 0, 1 } },
5121 	},
5122 	{
5123 		"JMP_JGE_X: if (3 >= 3) return 1",
5124 		.u.insns_int = {
5125 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5126 			BPF_LD_IMM64(R1, 3),
5127 			BPF_LD_IMM64(R2, 3),
5128 			BPF_JMP_REG(BPF_JGE, R1, R2, 1),
5129 			BPF_EXIT_INSN(),
5130 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5131 			BPF_EXIT_INSN(),
5132 		},
5133 		INTERNAL,
5134 		{ },
5135 		{ { 0, 1 } },
5136 	},
5137 	/* BPF_JMP | BPF_JLE | BPF_X */
5138 	{
5139 		"JMP_JLE_X: if (2 <= 3) return 1",
5140 		.u.insns_int = {
5141 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5142 			BPF_LD_IMM64(R1, 3),
5143 			BPF_LD_IMM64(R2, 2),
5144 			BPF_JMP_REG(BPF_JLE, R2, R1, 1),
5145 			BPF_EXIT_INSN(),
5146 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5147 			BPF_EXIT_INSN(),
5148 		},
5149 		INTERNAL,
5150 		{ },
5151 		{ { 0, 1 } },
5152 	},
5153 	{
5154 		"JMP_JLE_X: if (3 <= 3) return 1",
5155 		.u.insns_int = {
5156 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5157 			BPF_LD_IMM64(R1, 3),
5158 			BPF_LD_IMM64(R2, 3),
5159 			BPF_JMP_REG(BPF_JLE, R1, R2, 1),
5160 			BPF_EXIT_INSN(),
5161 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5162 			BPF_EXIT_INSN(),
5163 		},
5164 		INTERNAL,
5165 		{ },
5166 		{ { 0, 1 } },
5167 	},
5168 	{
5169 		/* Mainly testing JIT + imm64 here. */
5170 		"JMP_JGE_X: ldimm64 test 1",
5171 		.u.insns_int = {
5172 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5173 			BPF_LD_IMM64(R1, 3),
5174 			BPF_LD_IMM64(R2, 2),
5175 			BPF_JMP_REG(BPF_JGE, R1, R2, 2),
5176 			BPF_LD_IMM64(R0, 0xffffffffffffffffULL),
5177 			BPF_LD_IMM64(R0, 0xeeeeeeeeeeeeeeeeULL),
5178 			BPF_EXIT_INSN(),
5179 		},
5180 		INTERNAL,
5181 		{ },
5182 		{ { 0, 0xeeeeeeeeU } },
5183 	},
5184 	{
5185 		"JMP_JGE_X: ldimm64 test 2",
5186 		.u.insns_int = {
5187 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5188 			BPF_LD_IMM64(R1, 3),
5189 			BPF_LD_IMM64(R2, 2),
5190 			BPF_JMP_REG(BPF_JGE, R1, R2, 0),
5191 			BPF_LD_IMM64(R0, 0xffffffffffffffffULL),
5192 			BPF_EXIT_INSN(),
5193 		},
5194 		INTERNAL,
5195 		{ },
5196 		{ { 0, 0xffffffffU } },
5197 	},
5198 	{
5199 		"JMP_JGE_X: ldimm64 test 3",
5200 		.u.insns_int = {
5201 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5202 			BPF_LD_IMM64(R1, 3),
5203 			BPF_LD_IMM64(R2, 2),
5204 			BPF_JMP_REG(BPF_JGE, R1, R2, 4),
5205 			BPF_LD_IMM64(R0, 0xffffffffffffffffULL),
5206 			BPF_LD_IMM64(R0, 0xeeeeeeeeeeeeeeeeULL),
5207 			BPF_EXIT_INSN(),
5208 		},
5209 		INTERNAL,
5210 		{ },
5211 		{ { 0, 1 } },
5212 	},
5213 	{
5214 		"JMP_JLE_X: ldimm64 test 1",
5215 		.u.insns_int = {
5216 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5217 			BPF_LD_IMM64(R1, 3),
5218 			BPF_LD_IMM64(R2, 2),
5219 			BPF_JMP_REG(BPF_JLE, R2, R1, 2),
5220 			BPF_LD_IMM64(R0, 0xffffffffffffffffULL),
5221 			BPF_LD_IMM64(R0, 0xeeeeeeeeeeeeeeeeULL),
5222 			BPF_EXIT_INSN(),
5223 		},
5224 		INTERNAL,
5225 		{ },
5226 		{ { 0, 0xeeeeeeeeU } },
5227 	},
5228 	{
5229 		"JMP_JLE_X: ldimm64 test 2",
5230 		.u.insns_int = {
5231 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5232 			BPF_LD_IMM64(R1, 3),
5233 			BPF_LD_IMM64(R2, 2),
5234 			BPF_JMP_REG(BPF_JLE, R2, R1, 0),
5235 			BPF_LD_IMM64(R0, 0xffffffffffffffffULL),
5236 			BPF_EXIT_INSN(),
5237 		},
5238 		INTERNAL,
5239 		{ },
5240 		{ { 0, 0xffffffffU } },
5241 	},
5242 	{
5243 		"JMP_JLE_X: ldimm64 test 3",
5244 		.u.insns_int = {
5245 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5246 			BPF_LD_IMM64(R1, 3),
5247 			BPF_LD_IMM64(R2, 2),
5248 			BPF_JMP_REG(BPF_JLE, R2, R1, 4),
5249 			BPF_LD_IMM64(R0, 0xffffffffffffffffULL),
5250 			BPF_LD_IMM64(R0, 0xeeeeeeeeeeeeeeeeULL),
5251 			BPF_EXIT_INSN(),
5252 		},
5253 		INTERNAL,
5254 		{ },
5255 		{ { 0, 1 } },
5256 	},
5257 	/* BPF_JMP | BPF_JNE | BPF_X */
5258 	{
5259 		"JMP_JNE_X: if (3 != 2) return 1",
5260 		.u.insns_int = {
5261 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5262 			BPF_LD_IMM64(R1, 3),
5263 			BPF_LD_IMM64(R2, 2),
5264 			BPF_JMP_REG(BPF_JNE, R1, R2, 1),
5265 			BPF_EXIT_INSN(),
5266 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5267 			BPF_EXIT_INSN(),
5268 		},
5269 		INTERNAL,
5270 		{ },
5271 		{ { 0, 1 } },
5272 	},
5273 	/* BPF_JMP | BPF_JEQ | BPF_X */
5274 	{
5275 		"JMP_JEQ_X: if (3 == 3) return 1",
5276 		.u.insns_int = {
5277 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5278 			BPF_LD_IMM64(R1, 3),
5279 			BPF_LD_IMM64(R2, 3),
5280 			BPF_JMP_REG(BPF_JEQ, R1, R2, 1),
5281 			BPF_EXIT_INSN(),
5282 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5283 			BPF_EXIT_INSN(),
5284 		},
5285 		INTERNAL,
5286 		{ },
5287 		{ { 0, 1 } },
5288 	},
5289 	/* BPF_JMP | BPF_JSET | BPF_X */
5290 	{
5291 		"JMP_JSET_X: if (0x3 & 0x2) return 1",
5292 		.u.insns_int = {
5293 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5294 			BPF_LD_IMM64(R1, 3),
5295 			BPF_LD_IMM64(R2, 2),
5296 			BPF_JMP_REG(BPF_JSET, R1, R2, 1),
5297 			BPF_EXIT_INSN(),
5298 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5299 			BPF_EXIT_INSN(),
5300 		},
5301 		INTERNAL,
5302 		{ },
5303 		{ { 0, 1 } },
5304 	},
5305 	{
5306 		"JMP_JSET_X: if (0x3 & 0xffffffff) return 1",
5307 		.u.insns_int = {
5308 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5309 			BPF_LD_IMM64(R1, 3),
5310 			BPF_LD_IMM64(R2, 0xffffffff),
5311 			BPF_JMP_REG(BPF_JSET, R1, R2, 1),
5312 			BPF_EXIT_INSN(),
5313 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5314 			BPF_EXIT_INSN(),
5315 		},
5316 		INTERNAL,
5317 		{ },
5318 		{ { 0, 1 } },
5319 	},
5320 	{
5321 		"JMP_JA: Jump, gap, jump, ...",
5322 		{ },
5323 		CLASSIC | FLAG_NO_DATA,
5324 		{ },
5325 		{ { 0, 0xababcbac } },
5326 		.fill_helper = bpf_fill_ja,
5327 	},
5328 	{	/* Mainly checking JIT here. */
5329 		"BPF_MAXINSNS: Maximum possible literals",
5330 		{ },
5331 		CLASSIC | FLAG_NO_DATA,
5332 		{ },
5333 		{ { 0, 0xffffffff } },
5334 		.fill_helper = bpf_fill_maxinsns1,
5335 	},
5336 	{	/* Mainly checking JIT here. */
5337 		"BPF_MAXINSNS: Single literal",
5338 		{ },
5339 		CLASSIC | FLAG_NO_DATA,
5340 		{ },
5341 		{ { 0, 0xfefefefe } },
5342 		.fill_helper = bpf_fill_maxinsns2,
5343 	},
5344 	{	/* Mainly checking JIT here. */
5345 		"BPF_MAXINSNS: Run/add until end",
5346 		{ },
5347 		CLASSIC | FLAG_NO_DATA,
5348 		{ },
5349 		{ { 0, 0x947bf368 } },
5350 		.fill_helper = bpf_fill_maxinsns3,
5351 	},
5352 	{
5353 		"BPF_MAXINSNS: Too many instructions",
5354 		{ },
5355 		CLASSIC | FLAG_NO_DATA | FLAG_EXPECTED_FAIL,
5356 		{ },
5357 		{ },
5358 		.fill_helper = bpf_fill_maxinsns4,
5359 	},
5360 	{	/* Mainly checking JIT here. */
5361 		"BPF_MAXINSNS: Very long jump",
5362 		{ },
5363 		CLASSIC | FLAG_NO_DATA,
5364 		{ },
5365 		{ { 0, 0xabababab } },
5366 		.fill_helper = bpf_fill_maxinsns5,
5367 	},
5368 	{	/* Mainly checking JIT here. */
5369 		"BPF_MAXINSNS: Ctx heavy transformations",
5370 		{ },
5371 		CLASSIC,
5372 		{ },
5373 		{
5374 			{  1, !!(SKB_VLAN_TCI & VLAN_TAG_PRESENT) },
5375 			{ 10, !!(SKB_VLAN_TCI & VLAN_TAG_PRESENT) }
5376 		},
5377 		.fill_helper = bpf_fill_maxinsns6,
5378 	},
5379 	{	/* Mainly checking JIT here. */
5380 		"BPF_MAXINSNS: Call heavy transformations",
5381 		{ },
5382 		CLASSIC | FLAG_NO_DATA,
5383 		{ },
5384 		{ { 1, 0 }, { 10, 0 } },
5385 		.fill_helper = bpf_fill_maxinsns7,
5386 	},
5387 	{	/* Mainly checking JIT here. */
5388 		"BPF_MAXINSNS: Jump heavy test",
5389 		{ },
5390 		CLASSIC | FLAG_NO_DATA,
5391 		{ },
5392 		{ { 0, 0xffffffff } },
5393 		.fill_helper = bpf_fill_maxinsns8,
5394 	},
5395 	{	/* Mainly checking JIT here. */
5396 		"BPF_MAXINSNS: Very long jump backwards",
5397 		{ },
5398 		INTERNAL | FLAG_NO_DATA,
5399 		{ },
5400 		{ { 0, 0xcbababab } },
5401 		.fill_helper = bpf_fill_maxinsns9,
5402 	},
5403 	{	/* Mainly checking JIT here. */
5404 		"BPF_MAXINSNS: Edge hopping nuthouse",
5405 		{ },
5406 		INTERNAL | FLAG_NO_DATA,
5407 		{ },
5408 		{ { 0, 0xabababac } },
5409 		.fill_helper = bpf_fill_maxinsns10,
5410 	},
5411 	{
5412 		"BPF_MAXINSNS: Jump, gap, jump, ...",
5413 		{ },
5414 		CLASSIC | FLAG_NO_DATA,
5415 		{ },
5416 		{ { 0, 0xababcbac } },
5417 		.fill_helper = bpf_fill_maxinsns11,
5418 	},
5419 	{
5420 		"BPF_MAXINSNS: ld_abs+get_processor_id",
5421 		{ },
5422 		CLASSIC,
5423 		{ },
5424 		{ { 1, 0xbee } },
5425 		.fill_helper = bpf_fill_ld_abs_get_processor_id,
5426 	},
5427 	{
5428 		"BPF_MAXINSNS: ld_abs+vlan_push/pop",
5429 		{ },
5430 		INTERNAL,
5431 		{ 0x34 },
5432 		{ { ETH_HLEN, 0xbef } },
5433 		.fill_helper = bpf_fill_ld_abs_vlan_push_pop,
5434 	},
5435 	{
5436 		"BPF_MAXINSNS: jump around ld_abs",
5437 		{ },
5438 		INTERNAL,
5439 		{ 10, 11 },
5440 		{ { 2, 10 } },
5441 		.fill_helper = bpf_fill_jump_around_ld_abs,
5442 	},
5443 	/*
5444 	 * LD_IND / LD_ABS on fragmented SKBs
5445 	 */
5446 	{
5447 		"LD_IND byte frag",
5448 		.u.insns = {
5449 			BPF_STMT(BPF_LDX | BPF_IMM, 0x40),
5450 			BPF_STMT(BPF_LD | BPF_IND | BPF_B, 0x0),
5451 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5452 		},
5453 		CLASSIC | FLAG_SKB_FRAG,
5454 		{ },
5455 		{ {0x40, 0x42} },
5456 		.frag_data = {
5457 			0x42, 0x00, 0x00, 0x00,
5458 			0x43, 0x44, 0x00, 0x00,
5459 			0x21, 0x07, 0x19, 0x83,
5460 		},
5461 	},
5462 	{
5463 		"LD_IND halfword frag",
5464 		.u.insns = {
5465 			BPF_STMT(BPF_LDX | BPF_IMM, 0x40),
5466 			BPF_STMT(BPF_LD | BPF_IND | BPF_H, 0x4),
5467 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5468 		},
5469 		CLASSIC | FLAG_SKB_FRAG,
5470 		{ },
5471 		{ {0x40, 0x4344} },
5472 		.frag_data = {
5473 			0x42, 0x00, 0x00, 0x00,
5474 			0x43, 0x44, 0x00, 0x00,
5475 			0x21, 0x07, 0x19, 0x83,
5476 		},
5477 	},
5478 	{
5479 		"LD_IND word frag",
5480 		.u.insns = {
5481 			BPF_STMT(BPF_LDX | BPF_IMM, 0x40),
5482 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, 0x8),
5483 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5484 		},
5485 		CLASSIC | FLAG_SKB_FRAG,
5486 		{ },
5487 		{ {0x40, 0x21071983} },
5488 		.frag_data = {
5489 			0x42, 0x00, 0x00, 0x00,
5490 			0x43, 0x44, 0x00, 0x00,
5491 			0x21, 0x07, 0x19, 0x83,
5492 		},
5493 	},
5494 	{
5495 		"LD_IND halfword mixed head/frag",
5496 		.u.insns = {
5497 			BPF_STMT(BPF_LDX | BPF_IMM, 0x40),
5498 			BPF_STMT(BPF_LD | BPF_IND | BPF_H, -0x1),
5499 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5500 		},
5501 		CLASSIC | FLAG_SKB_FRAG,
5502 		{ [0x3e] = 0x25, [0x3f] = 0x05, },
5503 		{ {0x40, 0x0519} },
5504 		.frag_data = { 0x19, 0x82 },
5505 	},
5506 	{
5507 		"LD_IND word mixed head/frag",
5508 		.u.insns = {
5509 			BPF_STMT(BPF_LDX | BPF_IMM, 0x40),
5510 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, -0x2),
5511 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5512 		},
5513 		CLASSIC | FLAG_SKB_FRAG,
5514 		{ [0x3e] = 0x25, [0x3f] = 0x05, },
5515 		{ {0x40, 0x25051982} },
5516 		.frag_data = { 0x19, 0x82 },
5517 	},
5518 	{
5519 		"LD_ABS byte frag",
5520 		.u.insns = {
5521 			BPF_STMT(BPF_LD | BPF_ABS | BPF_B, 0x40),
5522 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5523 		},
5524 		CLASSIC | FLAG_SKB_FRAG,
5525 		{ },
5526 		{ {0x40, 0x42} },
5527 		.frag_data = {
5528 			0x42, 0x00, 0x00, 0x00,
5529 			0x43, 0x44, 0x00, 0x00,
5530 			0x21, 0x07, 0x19, 0x83,
5531 		},
5532 	},
5533 	{
5534 		"LD_ABS halfword frag",
5535 		.u.insns = {
5536 			BPF_STMT(BPF_LD | BPF_ABS | BPF_H, 0x44),
5537 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5538 		},
5539 		CLASSIC | FLAG_SKB_FRAG,
5540 		{ },
5541 		{ {0x40, 0x4344} },
5542 		.frag_data = {
5543 			0x42, 0x00, 0x00, 0x00,
5544 			0x43, 0x44, 0x00, 0x00,
5545 			0x21, 0x07, 0x19, 0x83,
5546 		},
5547 	},
5548 	{
5549 		"LD_ABS word frag",
5550 		.u.insns = {
5551 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, 0x48),
5552 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5553 		},
5554 		CLASSIC | FLAG_SKB_FRAG,
5555 		{ },
5556 		{ {0x40, 0x21071983} },
5557 		.frag_data = {
5558 			0x42, 0x00, 0x00, 0x00,
5559 			0x43, 0x44, 0x00, 0x00,
5560 			0x21, 0x07, 0x19, 0x83,
5561 		},
5562 	},
5563 	{
5564 		"LD_ABS halfword mixed head/frag",
5565 		.u.insns = {
5566 			BPF_STMT(BPF_LD | BPF_ABS | BPF_H, 0x3f),
5567 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5568 		},
5569 		CLASSIC | FLAG_SKB_FRAG,
5570 		{ [0x3e] = 0x25, [0x3f] = 0x05, },
5571 		{ {0x40, 0x0519} },
5572 		.frag_data = { 0x19, 0x82 },
5573 	},
5574 	{
5575 		"LD_ABS word mixed head/frag",
5576 		.u.insns = {
5577 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, 0x3e),
5578 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5579 		},
5580 		CLASSIC | FLAG_SKB_FRAG,
5581 		{ [0x3e] = 0x25, [0x3f] = 0x05, },
5582 		{ {0x40, 0x25051982} },
5583 		.frag_data = { 0x19, 0x82 },
5584 	},
5585 	/*
5586 	 * LD_IND / LD_ABS on non fragmented SKBs
5587 	 */
5588 	{
5589 		/*
5590 		 * this tests that the JIT/interpreter correctly resets X
5591 		 * before using it in an LD_IND instruction.
5592 		 */
5593 		"LD_IND byte default X",
5594 		.u.insns = {
5595 			BPF_STMT(BPF_LD | BPF_IND | BPF_B, 0x1),
5596 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5597 		},
5598 		CLASSIC,
5599 		{ [0x1] = 0x42 },
5600 		{ {0x40, 0x42 } },
5601 	},
5602 	{
5603 		"LD_IND byte positive offset",
5604 		.u.insns = {
5605 			BPF_STMT(BPF_LDX | BPF_IMM, 0x3e),
5606 			BPF_STMT(BPF_LD | BPF_IND | BPF_B, 0x1),
5607 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5608 		},
5609 		CLASSIC,
5610 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
5611 		{ {0x40, 0x82 } },
5612 	},
5613 	{
5614 		"LD_IND byte negative offset",
5615 		.u.insns = {
5616 			BPF_STMT(BPF_LDX | BPF_IMM, 0x3e),
5617 			BPF_STMT(BPF_LD | BPF_IND | BPF_B, -0x1),
5618 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5619 		},
5620 		CLASSIC,
5621 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
5622 		{ {0x40, 0x05 } },
5623 	},
5624 	{
5625 		"LD_IND halfword positive offset",
5626 		.u.insns = {
5627 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
5628 			BPF_STMT(BPF_LD | BPF_IND | BPF_H, 0x2),
5629 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5630 		},
5631 		CLASSIC,
5632 		{
5633 			[0x1c] = 0xaa, [0x1d] = 0x55,
5634 			[0x1e] = 0xbb, [0x1f] = 0x66,
5635 			[0x20] = 0xcc, [0x21] = 0x77,
5636 			[0x22] = 0xdd, [0x23] = 0x88,
5637 		},
5638 		{ {0x40, 0xdd88 } },
5639 	},
5640 	{
5641 		"LD_IND halfword negative offset",
5642 		.u.insns = {
5643 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
5644 			BPF_STMT(BPF_LD | BPF_IND | BPF_H, -0x2),
5645 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5646 		},
5647 		CLASSIC,
5648 		{
5649 			[0x1c] = 0xaa, [0x1d] = 0x55,
5650 			[0x1e] = 0xbb, [0x1f] = 0x66,
5651 			[0x20] = 0xcc, [0x21] = 0x77,
5652 			[0x22] = 0xdd, [0x23] = 0x88,
5653 		},
5654 		{ {0x40, 0xbb66 } },
5655 	},
5656 	{
5657 		"LD_IND halfword unaligned",
5658 		.u.insns = {
5659 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
5660 			BPF_STMT(BPF_LD | BPF_IND | BPF_H, -0x1),
5661 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5662 		},
5663 		CLASSIC,
5664 		{
5665 			[0x1c] = 0xaa, [0x1d] = 0x55,
5666 			[0x1e] = 0xbb, [0x1f] = 0x66,
5667 			[0x20] = 0xcc, [0x21] = 0x77,
5668 			[0x22] = 0xdd, [0x23] = 0x88,
5669 		},
5670 		{ {0x40, 0x66cc } },
5671 	},
5672 	{
5673 		"LD_IND word positive offset",
5674 		.u.insns = {
5675 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
5676 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, 0x4),
5677 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5678 		},
5679 		CLASSIC,
5680 		{
5681 			[0x1c] = 0xaa, [0x1d] = 0x55,
5682 			[0x1e] = 0xbb, [0x1f] = 0x66,
5683 			[0x20] = 0xcc, [0x21] = 0x77,
5684 			[0x22] = 0xdd, [0x23] = 0x88,
5685 			[0x24] = 0xee, [0x25] = 0x99,
5686 			[0x26] = 0xff, [0x27] = 0xaa,
5687 		},
5688 		{ {0x40, 0xee99ffaa } },
5689 	},
5690 	{
5691 		"LD_IND word negative offset",
5692 		.u.insns = {
5693 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
5694 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, -0x4),
5695 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5696 		},
5697 		CLASSIC,
5698 		{
5699 			[0x1c] = 0xaa, [0x1d] = 0x55,
5700 			[0x1e] = 0xbb, [0x1f] = 0x66,
5701 			[0x20] = 0xcc, [0x21] = 0x77,
5702 			[0x22] = 0xdd, [0x23] = 0x88,
5703 			[0x24] = 0xee, [0x25] = 0x99,
5704 			[0x26] = 0xff, [0x27] = 0xaa,
5705 		},
5706 		{ {0x40, 0xaa55bb66 } },
5707 	},
5708 	{
5709 		"LD_IND word unaligned (addr & 3 == 2)",
5710 		.u.insns = {
5711 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
5712 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, -0x2),
5713 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5714 		},
5715 		CLASSIC,
5716 		{
5717 			[0x1c] = 0xaa, [0x1d] = 0x55,
5718 			[0x1e] = 0xbb, [0x1f] = 0x66,
5719 			[0x20] = 0xcc, [0x21] = 0x77,
5720 			[0x22] = 0xdd, [0x23] = 0x88,
5721 			[0x24] = 0xee, [0x25] = 0x99,
5722 			[0x26] = 0xff, [0x27] = 0xaa,
5723 		},
5724 		{ {0x40, 0xbb66cc77 } },
5725 	},
5726 	{
5727 		"LD_IND word unaligned (addr & 3 == 1)",
5728 		.u.insns = {
5729 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
5730 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, -0x3),
5731 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5732 		},
5733 		CLASSIC,
5734 		{
5735 			[0x1c] = 0xaa, [0x1d] = 0x55,
5736 			[0x1e] = 0xbb, [0x1f] = 0x66,
5737 			[0x20] = 0xcc, [0x21] = 0x77,
5738 			[0x22] = 0xdd, [0x23] = 0x88,
5739 			[0x24] = 0xee, [0x25] = 0x99,
5740 			[0x26] = 0xff, [0x27] = 0xaa,
5741 		},
5742 		{ {0x40, 0x55bb66cc } },
5743 	},
5744 	{
5745 		"LD_IND word unaligned (addr & 3 == 3)",
5746 		.u.insns = {
5747 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
5748 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, -0x1),
5749 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5750 		},
5751 		CLASSIC,
5752 		{
5753 			[0x1c] = 0xaa, [0x1d] = 0x55,
5754 			[0x1e] = 0xbb, [0x1f] = 0x66,
5755 			[0x20] = 0xcc, [0x21] = 0x77,
5756 			[0x22] = 0xdd, [0x23] = 0x88,
5757 			[0x24] = 0xee, [0x25] = 0x99,
5758 			[0x26] = 0xff, [0x27] = 0xaa,
5759 		},
5760 		{ {0x40, 0x66cc77dd } },
5761 	},
5762 	{
5763 		"LD_ABS byte",
5764 		.u.insns = {
5765 			BPF_STMT(BPF_LD | BPF_ABS | BPF_B, 0x20),
5766 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5767 		},
5768 		CLASSIC,
5769 		{
5770 			[0x1c] = 0xaa, [0x1d] = 0x55,
5771 			[0x1e] = 0xbb, [0x1f] = 0x66,
5772 			[0x20] = 0xcc, [0x21] = 0x77,
5773 			[0x22] = 0xdd, [0x23] = 0x88,
5774 			[0x24] = 0xee, [0x25] = 0x99,
5775 			[0x26] = 0xff, [0x27] = 0xaa,
5776 		},
5777 		{ {0x40, 0xcc } },
5778 	},
5779 	{
5780 		"LD_ABS halfword",
5781 		.u.insns = {
5782 			BPF_STMT(BPF_LD | BPF_ABS | BPF_H, 0x22),
5783 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5784 		},
5785 		CLASSIC,
5786 		{
5787 			[0x1c] = 0xaa, [0x1d] = 0x55,
5788 			[0x1e] = 0xbb, [0x1f] = 0x66,
5789 			[0x20] = 0xcc, [0x21] = 0x77,
5790 			[0x22] = 0xdd, [0x23] = 0x88,
5791 			[0x24] = 0xee, [0x25] = 0x99,
5792 			[0x26] = 0xff, [0x27] = 0xaa,
5793 		},
5794 		{ {0x40, 0xdd88 } },
5795 	},
5796 	{
5797 		"LD_ABS halfword unaligned",
5798 		.u.insns = {
5799 			BPF_STMT(BPF_LD | BPF_ABS | BPF_H, 0x25),
5800 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5801 		},
5802 		CLASSIC,
5803 		{
5804 			[0x1c] = 0xaa, [0x1d] = 0x55,
5805 			[0x1e] = 0xbb, [0x1f] = 0x66,
5806 			[0x20] = 0xcc, [0x21] = 0x77,
5807 			[0x22] = 0xdd, [0x23] = 0x88,
5808 			[0x24] = 0xee, [0x25] = 0x99,
5809 			[0x26] = 0xff, [0x27] = 0xaa,
5810 		},
5811 		{ {0x40, 0x99ff } },
5812 	},
5813 	{
5814 		"LD_ABS word",
5815 		.u.insns = {
5816 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, 0x1c),
5817 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5818 		},
5819 		CLASSIC,
5820 		{
5821 			[0x1c] = 0xaa, [0x1d] = 0x55,
5822 			[0x1e] = 0xbb, [0x1f] = 0x66,
5823 			[0x20] = 0xcc, [0x21] = 0x77,
5824 			[0x22] = 0xdd, [0x23] = 0x88,
5825 			[0x24] = 0xee, [0x25] = 0x99,
5826 			[0x26] = 0xff, [0x27] = 0xaa,
5827 		},
5828 		{ {0x40, 0xaa55bb66 } },
5829 	},
5830 	{
5831 		"LD_ABS word unaligned (addr & 3 == 2)",
5832 		.u.insns = {
5833 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, 0x22),
5834 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5835 		},
5836 		CLASSIC,
5837 		{
5838 			[0x1c] = 0xaa, [0x1d] = 0x55,
5839 			[0x1e] = 0xbb, [0x1f] = 0x66,
5840 			[0x20] = 0xcc, [0x21] = 0x77,
5841 			[0x22] = 0xdd, [0x23] = 0x88,
5842 			[0x24] = 0xee, [0x25] = 0x99,
5843 			[0x26] = 0xff, [0x27] = 0xaa,
5844 		},
5845 		{ {0x40, 0xdd88ee99 } },
5846 	},
5847 	{
5848 		"LD_ABS word unaligned (addr & 3 == 1)",
5849 		.u.insns = {
5850 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, 0x21),
5851 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5852 		},
5853 		CLASSIC,
5854 		{
5855 			[0x1c] = 0xaa, [0x1d] = 0x55,
5856 			[0x1e] = 0xbb, [0x1f] = 0x66,
5857 			[0x20] = 0xcc, [0x21] = 0x77,
5858 			[0x22] = 0xdd, [0x23] = 0x88,
5859 			[0x24] = 0xee, [0x25] = 0x99,
5860 			[0x26] = 0xff, [0x27] = 0xaa,
5861 		},
5862 		{ {0x40, 0x77dd88ee } },
5863 	},
5864 	{
5865 		"LD_ABS word unaligned (addr & 3 == 3)",
5866 		.u.insns = {
5867 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, 0x23),
5868 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5869 		},
5870 		CLASSIC,
5871 		{
5872 			[0x1c] = 0xaa, [0x1d] = 0x55,
5873 			[0x1e] = 0xbb, [0x1f] = 0x66,
5874 			[0x20] = 0xcc, [0x21] = 0x77,
5875 			[0x22] = 0xdd, [0x23] = 0x88,
5876 			[0x24] = 0xee, [0x25] = 0x99,
5877 			[0x26] = 0xff, [0x27] = 0xaa,
5878 		},
5879 		{ {0x40, 0x88ee99ff } },
5880 	},
5881 	/*
5882 	 * verify that the interpreter or JIT correctly sets A and X
5883 	 * to 0.
5884 	 */
5885 	{
5886 		"ADD default X",
5887 		.u.insns = {
5888 			/*
5889 			 * A = 0x42
5890 			 * A = A + X
5891 			 * ret A
5892 			 */
5893 			BPF_STMT(BPF_LD | BPF_IMM, 0x42),
5894 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
5895 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5896 		},
5897 		CLASSIC | FLAG_NO_DATA,
5898 		{},
5899 		{ {0x1, 0x42 } },
5900 	},
5901 	{
5902 		"ADD default A",
5903 		.u.insns = {
5904 			/*
5905 			 * A = A + 0x42
5906 			 * ret A
5907 			 */
5908 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 0x42),
5909 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5910 		},
5911 		CLASSIC | FLAG_NO_DATA,
5912 		{},
5913 		{ {0x1, 0x42 } },
5914 	},
5915 	{
5916 		"SUB default X",
5917 		.u.insns = {
5918 			/*
5919 			 * A = 0x66
5920 			 * A = A - X
5921 			 * ret A
5922 			 */
5923 			BPF_STMT(BPF_LD | BPF_IMM, 0x66),
5924 			BPF_STMT(BPF_ALU | BPF_SUB | BPF_X, 0),
5925 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5926 		},
5927 		CLASSIC | FLAG_NO_DATA,
5928 		{},
5929 		{ {0x1, 0x66 } },
5930 	},
5931 	{
5932 		"SUB default A",
5933 		.u.insns = {
5934 			/*
5935 			 * A = A - -0x66
5936 			 * ret A
5937 			 */
5938 			BPF_STMT(BPF_ALU | BPF_SUB | BPF_K, -0x66),
5939 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5940 		},
5941 		CLASSIC | FLAG_NO_DATA,
5942 		{},
5943 		{ {0x1, 0x66 } },
5944 	},
5945 	{
5946 		"MUL default X",
5947 		.u.insns = {
5948 			/*
5949 			 * A = 0x42
5950 			 * A = A * X
5951 			 * ret A
5952 			 */
5953 			BPF_STMT(BPF_LD | BPF_IMM, 0x42),
5954 			BPF_STMT(BPF_ALU | BPF_MUL | BPF_X, 0),
5955 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5956 		},
5957 		CLASSIC | FLAG_NO_DATA,
5958 		{},
5959 		{ {0x1, 0x0 } },
5960 	},
5961 	{
5962 		"MUL default A",
5963 		.u.insns = {
5964 			/*
5965 			 * A = A * 0x66
5966 			 * ret A
5967 			 */
5968 			BPF_STMT(BPF_ALU | BPF_MUL | BPF_K, 0x66),
5969 			BPF_STMT(BPF_RET | BPF_A, 0x0),
5970 		},
5971 		CLASSIC | FLAG_NO_DATA,
5972 		{},
5973 		{ {0x1, 0x0 } },
5974 	},
5975 	{
5976 		"DIV default X",
5977 		.u.insns = {
5978 			/*
5979 			 * A = 0x42
5980 			 * A = A / X ; this halt the filter execution if X is 0
5981 			 * ret 0x42
5982 			 */
5983 			BPF_STMT(BPF_LD | BPF_IMM, 0x42),
5984 			BPF_STMT(BPF_ALU | BPF_DIV | BPF_X, 0),
5985 			BPF_STMT(BPF_RET | BPF_K, 0x42),
5986 		},
5987 		CLASSIC | FLAG_NO_DATA,
5988 		{},
5989 		{ {0x1, 0x0 } },
5990 	},
5991 	{
5992 		"DIV default A",
5993 		.u.insns = {
5994 			/*
5995 			 * A = A / 1
5996 			 * ret A
5997 			 */
5998 			BPF_STMT(BPF_ALU | BPF_DIV | BPF_K, 0x1),
5999 			BPF_STMT(BPF_RET | BPF_A, 0x0),
6000 		},
6001 		CLASSIC | FLAG_NO_DATA,
6002 		{},
6003 		{ {0x1, 0x0 } },
6004 	},
6005 	{
6006 		"MOD default X",
6007 		.u.insns = {
6008 			/*
6009 			 * A = 0x42
6010 			 * A = A mod X ; this halt the filter execution if X is 0
6011 			 * ret 0x42
6012 			 */
6013 			BPF_STMT(BPF_LD | BPF_IMM, 0x42),
6014 			BPF_STMT(BPF_ALU | BPF_MOD | BPF_X, 0),
6015 			BPF_STMT(BPF_RET | BPF_K, 0x42),
6016 		},
6017 		CLASSIC | FLAG_NO_DATA,
6018 		{},
6019 		{ {0x1, 0x0 } },
6020 	},
6021 	{
6022 		"MOD default A",
6023 		.u.insns = {
6024 			/*
6025 			 * A = A mod 1
6026 			 * ret A
6027 			 */
6028 			BPF_STMT(BPF_ALU | BPF_MOD | BPF_K, 0x1),
6029 			BPF_STMT(BPF_RET | BPF_A, 0x0),
6030 		},
6031 		CLASSIC | FLAG_NO_DATA,
6032 		{},
6033 		{ {0x1, 0x0 } },
6034 	},
6035 	{
6036 		"JMP EQ default A",
6037 		.u.insns = {
6038 			/*
6039 			 * cmp A, 0x0, 0, 1
6040 			 * ret 0x42
6041 			 * ret 0x66
6042 			 */
6043 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x0, 0, 1),
6044 			BPF_STMT(BPF_RET | BPF_K, 0x42),
6045 			BPF_STMT(BPF_RET | BPF_K, 0x66),
6046 		},
6047 		CLASSIC | FLAG_NO_DATA,
6048 		{},
6049 		{ {0x1, 0x42 } },
6050 	},
6051 	{
6052 		"JMP EQ default X",
6053 		.u.insns = {
6054 			/*
6055 			 * A = 0x0
6056 			 * cmp A, X, 0, 1
6057 			 * ret 0x42
6058 			 * ret 0x66
6059 			 */
6060 			BPF_STMT(BPF_LD | BPF_IMM, 0x0),
6061 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_X, 0x0, 0, 1),
6062 			BPF_STMT(BPF_RET | BPF_K, 0x42),
6063 			BPF_STMT(BPF_RET | BPF_K, 0x66),
6064 		},
6065 		CLASSIC | FLAG_NO_DATA,
6066 		{},
6067 		{ {0x1, 0x42 } },
6068 	},
6069 };
6070 
6071 static struct net_device dev;
6072 
6073 static struct sk_buff *populate_skb(char *buf, int size)
6074 {
6075 	struct sk_buff *skb;
6076 
6077 	if (size >= MAX_DATA)
6078 		return NULL;
6079 
6080 	skb = alloc_skb(MAX_DATA, GFP_KERNEL);
6081 	if (!skb)
6082 		return NULL;
6083 
6084 	__skb_put_data(skb, buf, size);
6085 
6086 	/* Initialize a fake skb with test pattern. */
6087 	skb_reset_mac_header(skb);
6088 	skb->protocol = htons(ETH_P_IP);
6089 	skb->pkt_type = SKB_TYPE;
6090 	skb->mark = SKB_MARK;
6091 	skb->hash = SKB_HASH;
6092 	skb->queue_mapping = SKB_QUEUE_MAP;
6093 	skb->vlan_tci = SKB_VLAN_TCI;
6094 	skb->vlan_proto = htons(ETH_P_IP);
6095 	skb->dev = &dev;
6096 	skb->dev->ifindex = SKB_DEV_IFINDEX;
6097 	skb->dev->type = SKB_DEV_TYPE;
6098 	skb_set_network_header(skb, min(size, ETH_HLEN));
6099 
6100 	return skb;
6101 }
6102 
6103 static void *generate_test_data(struct bpf_test *test, int sub)
6104 {
6105 	struct sk_buff *skb;
6106 	struct page *page;
6107 
6108 	if (test->aux & FLAG_NO_DATA)
6109 		return NULL;
6110 
6111 	/* Test case expects an skb, so populate one. Various
6112 	 * subtests generate skbs of different sizes based on
6113 	 * the same data.
6114 	 */
6115 	skb = populate_skb(test->data, test->test[sub].data_size);
6116 	if (!skb)
6117 		return NULL;
6118 
6119 	if (test->aux & FLAG_SKB_FRAG) {
6120 		/*
6121 		 * when the test requires a fragmented skb, add a
6122 		 * single fragment to the skb, filled with
6123 		 * test->frag_data.
6124 		 */
6125 		void *ptr;
6126 
6127 		page = alloc_page(GFP_KERNEL);
6128 
6129 		if (!page)
6130 			goto err_kfree_skb;
6131 
6132 		ptr = kmap(page);
6133 		if (!ptr)
6134 			goto err_free_page;
6135 		memcpy(ptr, test->frag_data, MAX_DATA);
6136 		kunmap(page);
6137 		skb_add_rx_frag(skb, 0, page, 0, MAX_DATA, MAX_DATA);
6138 	}
6139 
6140 	return skb;
6141 
6142 err_free_page:
6143 	__free_page(page);
6144 err_kfree_skb:
6145 	kfree_skb(skb);
6146 	return NULL;
6147 }
6148 
6149 static void release_test_data(const struct bpf_test *test, void *data)
6150 {
6151 	if (test->aux & FLAG_NO_DATA)
6152 		return;
6153 
6154 	kfree_skb(data);
6155 }
6156 
6157 static int filter_length(int which)
6158 {
6159 	struct sock_filter *fp;
6160 	int len;
6161 
6162 	if (tests[which].fill_helper)
6163 		return tests[which].u.ptr.len;
6164 
6165 	fp = tests[which].u.insns;
6166 	for (len = MAX_INSNS - 1; len > 0; --len)
6167 		if (fp[len].code != 0 || fp[len].k != 0)
6168 			break;
6169 
6170 	return len + 1;
6171 }
6172 
6173 static void *filter_pointer(int which)
6174 {
6175 	if (tests[which].fill_helper)
6176 		return tests[which].u.ptr.insns;
6177 	else
6178 		return tests[which].u.insns;
6179 }
6180 
6181 static struct bpf_prog *generate_filter(int which, int *err)
6182 {
6183 	__u8 test_type = tests[which].aux & TEST_TYPE_MASK;
6184 	unsigned int flen = filter_length(which);
6185 	void *fptr = filter_pointer(which);
6186 	struct sock_fprog_kern fprog;
6187 	struct bpf_prog *fp;
6188 
6189 	switch (test_type) {
6190 	case CLASSIC:
6191 		fprog.filter = fptr;
6192 		fprog.len = flen;
6193 
6194 		*err = bpf_prog_create(&fp, &fprog);
6195 		if (tests[which].aux & FLAG_EXPECTED_FAIL) {
6196 			if (*err == -EINVAL) {
6197 				pr_cont("PASS\n");
6198 				/* Verifier rejected filter as expected. */
6199 				*err = 0;
6200 				return NULL;
6201 			} else {
6202 				pr_cont("UNEXPECTED_PASS\n");
6203 				/* Verifier didn't reject the test that's
6204 				 * bad enough, just return!
6205 				 */
6206 				*err = -EINVAL;
6207 				return NULL;
6208 			}
6209 		}
6210 		/* We don't expect to fail. */
6211 		if (*err) {
6212 			pr_cont("FAIL to attach err=%d len=%d\n",
6213 				*err, fprog.len);
6214 			return NULL;
6215 		}
6216 		break;
6217 
6218 	case INTERNAL:
6219 		fp = bpf_prog_alloc(bpf_prog_size(flen), 0);
6220 		if (fp == NULL) {
6221 			pr_cont("UNEXPECTED_FAIL no memory left\n");
6222 			*err = -ENOMEM;
6223 			return NULL;
6224 		}
6225 
6226 		fp->len = flen;
6227 		/* Type doesn't really matter here as long as it's not unspec. */
6228 		fp->type = BPF_PROG_TYPE_SOCKET_FILTER;
6229 		memcpy(fp->insnsi, fptr, fp->len * sizeof(struct bpf_insn));
6230 		fp->aux->stack_depth = tests[which].stack_depth;
6231 
6232 		/* We cannot error here as we don't need type compatibility
6233 		 * checks.
6234 		 */
6235 		fp = bpf_prog_select_runtime(fp, err);
6236 		break;
6237 	}
6238 
6239 	*err = 0;
6240 	return fp;
6241 }
6242 
6243 static void release_filter(struct bpf_prog *fp, int which)
6244 {
6245 	__u8 test_type = tests[which].aux & TEST_TYPE_MASK;
6246 
6247 	switch (test_type) {
6248 	case CLASSIC:
6249 		bpf_prog_destroy(fp);
6250 		break;
6251 	case INTERNAL:
6252 		bpf_prog_free(fp);
6253 		break;
6254 	}
6255 }
6256 
6257 static int __run_one(const struct bpf_prog *fp, const void *data,
6258 		     int runs, u64 *duration)
6259 {
6260 	u64 start, finish;
6261 	int ret = 0, i;
6262 
6263 	start = ktime_get_ns();
6264 
6265 	for (i = 0; i < runs; i++)
6266 		ret = BPF_PROG_RUN(fp, data);
6267 
6268 	finish = ktime_get_ns();
6269 
6270 	*duration = finish - start;
6271 	do_div(*duration, runs);
6272 
6273 	return ret;
6274 }
6275 
6276 static int run_one(const struct bpf_prog *fp, struct bpf_test *test)
6277 {
6278 	int err_cnt = 0, i, runs = MAX_TESTRUNS;
6279 
6280 	for (i = 0; i < MAX_SUBTESTS; i++) {
6281 		void *data;
6282 		u64 duration;
6283 		u32 ret;
6284 
6285 		if (test->test[i].data_size == 0 &&
6286 		    test->test[i].result == 0)
6287 			break;
6288 
6289 		data = generate_test_data(test, i);
6290 		if (!data && !(test->aux & FLAG_NO_DATA)) {
6291 			pr_cont("data generation failed ");
6292 			err_cnt++;
6293 			break;
6294 		}
6295 		ret = __run_one(fp, data, runs, &duration);
6296 		release_test_data(test, data);
6297 
6298 		if (ret == test->test[i].result) {
6299 			pr_cont("%lld ", duration);
6300 		} else {
6301 			pr_cont("ret %d != %d ", ret,
6302 				test->test[i].result);
6303 			err_cnt++;
6304 		}
6305 	}
6306 
6307 	return err_cnt;
6308 }
6309 
6310 static char test_name[64];
6311 module_param_string(test_name, test_name, sizeof(test_name), 0);
6312 
6313 static int test_id = -1;
6314 module_param(test_id, int, 0);
6315 
6316 static int test_range[2] = { 0, ARRAY_SIZE(tests) - 1 };
6317 module_param_array(test_range, int, NULL, 0);
6318 
6319 static __init int find_test_index(const char *test_name)
6320 {
6321 	int i;
6322 
6323 	for (i = 0; i < ARRAY_SIZE(tests); i++) {
6324 		if (!strcmp(tests[i].descr, test_name))
6325 			return i;
6326 	}
6327 	return -1;
6328 }
6329 
6330 static __init int prepare_bpf_tests(void)
6331 {
6332 	int i;
6333 
6334 	if (test_id >= 0) {
6335 		/*
6336 		 * if a test_id was specified, use test_range to
6337 		 * cover only that test.
6338 		 */
6339 		if (test_id >= ARRAY_SIZE(tests)) {
6340 			pr_err("test_bpf: invalid test_id specified.\n");
6341 			return -EINVAL;
6342 		}
6343 
6344 		test_range[0] = test_id;
6345 		test_range[1] = test_id;
6346 	} else if (*test_name) {
6347 		/*
6348 		 * if a test_name was specified, find it and setup
6349 		 * test_range to cover only that test.
6350 		 */
6351 		int idx = find_test_index(test_name);
6352 
6353 		if (idx < 0) {
6354 			pr_err("test_bpf: no test named '%s' found.\n",
6355 			       test_name);
6356 			return -EINVAL;
6357 		}
6358 		test_range[0] = idx;
6359 		test_range[1] = idx;
6360 	} else {
6361 		/*
6362 		 * check that the supplied test_range is valid.
6363 		 */
6364 		if (test_range[0] >= ARRAY_SIZE(tests) ||
6365 		    test_range[1] >= ARRAY_SIZE(tests) ||
6366 		    test_range[0] < 0 || test_range[1] < 0) {
6367 			pr_err("test_bpf: test_range is out of bound.\n");
6368 			return -EINVAL;
6369 		}
6370 
6371 		if (test_range[1] < test_range[0]) {
6372 			pr_err("test_bpf: test_range is ending before it starts.\n");
6373 			return -EINVAL;
6374 		}
6375 	}
6376 
6377 	for (i = 0; i < ARRAY_SIZE(tests); i++) {
6378 		if (tests[i].fill_helper &&
6379 		    tests[i].fill_helper(&tests[i]) < 0)
6380 			return -ENOMEM;
6381 	}
6382 
6383 	return 0;
6384 }
6385 
6386 static __init void destroy_bpf_tests(void)
6387 {
6388 	int i;
6389 
6390 	for (i = 0; i < ARRAY_SIZE(tests); i++) {
6391 		if (tests[i].fill_helper)
6392 			kfree(tests[i].u.ptr.insns);
6393 	}
6394 }
6395 
6396 static bool exclude_test(int test_id)
6397 {
6398 	return test_id < test_range[0] || test_id > test_range[1];
6399 }
6400 
6401 static __init int test_bpf(void)
6402 {
6403 	int i, err_cnt = 0, pass_cnt = 0;
6404 	int jit_cnt = 0, run_cnt = 0;
6405 
6406 	for (i = 0; i < ARRAY_SIZE(tests); i++) {
6407 		struct bpf_prog *fp;
6408 		int err;
6409 
6410 		if (exclude_test(i))
6411 			continue;
6412 
6413 		pr_info("#%d %s ", i, tests[i].descr);
6414 
6415 		fp = generate_filter(i, &err);
6416 		if (fp == NULL) {
6417 			if (err == 0) {
6418 				pass_cnt++;
6419 				continue;
6420 			}
6421 
6422 			return err;
6423 		}
6424 
6425 		pr_cont("jited:%u ", fp->jited);
6426 
6427 		run_cnt++;
6428 		if (fp->jited)
6429 			jit_cnt++;
6430 
6431 		err = run_one(fp, &tests[i]);
6432 		release_filter(fp, i);
6433 
6434 		if (err) {
6435 			pr_cont("FAIL (%d times)\n", err);
6436 			err_cnt++;
6437 		} else {
6438 			pr_cont("PASS\n");
6439 			pass_cnt++;
6440 		}
6441 	}
6442 
6443 	pr_info("Summary: %d PASSED, %d FAILED, [%d/%d JIT'ed]\n",
6444 		pass_cnt, err_cnt, jit_cnt, run_cnt);
6445 
6446 	return err_cnt ? -EINVAL : 0;
6447 }
6448 
6449 static int __init test_bpf_init(void)
6450 {
6451 	int ret;
6452 
6453 	ret = prepare_bpf_tests();
6454 	if (ret < 0)
6455 		return ret;
6456 
6457 	ret = test_bpf();
6458 
6459 	destroy_bpf_tests();
6460 	return ret;
6461 }
6462 
6463 static void __exit test_bpf_exit(void)
6464 {
6465 }
6466 
6467 module_init(test_bpf_init);
6468 module_exit(test_bpf_exit);
6469 
6470 MODULE_LICENSE("GPL");
6471