1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Testsuite for BPF interpreter and BPF JIT compiler
4  *
5  * Copyright (c) 2011-2014 PLUMgrid, http://plumgrid.com
6  */
7 
8 #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
9 
10 #include <linux/init.h>
11 #include <linux/module.h>
12 #include <linux/filter.h>
13 #include <linux/bpf.h>
14 #include <linux/skbuff.h>
15 #include <linux/netdevice.h>
16 #include <linux/if_vlan.h>
17 #include <linux/random.h>
18 #include <linux/highmem.h>
19 #include <linux/sched.h>
20 
21 /* General test specific settings */
22 #define MAX_SUBTESTS	3
23 #define MAX_TESTRUNS	1000
24 #define MAX_DATA	128
25 #define MAX_INSNS	512
26 #define MAX_K		0xffffFFFF
27 
28 /* Few constants used to init test 'skb' */
29 #define SKB_TYPE	3
30 #define SKB_MARK	0x1234aaaa
31 #define SKB_HASH	0x1234aaab
32 #define SKB_QUEUE_MAP	123
33 #define SKB_VLAN_TCI	0xffff
34 #define SKB_VLAN_PRESENT	1
35 #define SKB_DEV_IFINDEX	577
36 #define SKB_DEV_TYPE	588
37 
38 /* Redefine REGs to make tests less verbose */
39 #define R0		BPF_REG_0
40 #define R1		BPF_REG_1
41 #define R2		BPF_REG_2
42 #define R3		BPF_REG_3
43 #define R4		BPF_REG_4
44 #define R5		BPF_REG_5
45 #define R6		BPF_REG_6
46 #define R7		BPF_REG_7
47 #define R8		BPF_REG_8
48 #define R9		BPF_REG_9
49 #define R10		BPF_REG_10
50 
51 /* Flags that can be passed to test cases */
52 #define FLAG_NO_DATA		BIT(0)
53 #define FLAG_EXPECTED_FAIL	BIT(1)
54 #define FLAG_SKB_FRAG		BIT(2)
55 #define FLAG_VERIFIER_ZEXT	BIT(3)
56 #define FLAG_LARGE_MEM		BIT(4)
57 
58 enum {
59 	CLASSIC  = BIT(6),	/* Old BPF instructions only. */
60 	INTERNAL = BIT(7),	/* Extended instruction set.  */
61 };
62 
63 #define TEST_TYPE_MASK		(CLASSIC | INTERNAL)
64 
65 struct bpf_test {
66 	const char *descr;
67 	union {
68 		struct sock_filter insns[MAX_INSNS];
69 		struct bpf_insn insns_int[MAX_INSNS];
70 		struct {
71 			void *insns;
72 			unsigned int len;
73 		} ptr;
74 	} u;
75 	__u8 aux;
76 	__u8 data[MAX_DATA];
77 	struct {
78 		int data_size;
79 		__u32 result;
80 	} test[MAX_SUBTESTS];
81 	int (*fill_helper)(struct bpf_test *self);
82 	int expected_errcode; /* used when FLAG_EXPECTED_FAIL is set in the aux */
83 	__u8 frag_data[MAX_DATA];
84 	int stack_depth; /* for eBPF only, since tests don't call verifier */
85 	int nr_testruns; /* Custom run count, defaults to MAX_TESTRUNS if 0 */
86 };
87 
88 /* Large test cases need separate allocation and fill handler. */
89 
bpf_fill_maxinsns1(struct bpf_test * self)90 static int bpf_fill_maxinsns1(struct bpf_test *self)
91 {
92 	unsigned int len = BPF_MAXINSNS;
93 	struct sock_filter *insn;
94 	__u32 k = ~0;
95 	int i;
96 
97 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
98 	if (!insn)
99 		return -ENOMEM;
100 
101 	for (i = 0; i < len; i++, k--)
102 		insn[i] = __BPF_STMT(BPF_RET | BPF_K, k);
103 
104 	self->u.ptr.insns = insn;
105 	self->u.ptr.len = len;
106 
107 	return 0;
108 }
109 
bpf_fill_maxinsns2(struct bpf_test * self)110 static int bpf_fill_maxinsns2(struct bpf_test *self)
111 {
112 	unsigned int len = BPF_MAXINSNS;
113 	struct sock_filter *insn;
114 	int i;
115 
116 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
117 	if (!insn)
118 		return -ENOMEM;
119 
120 	for (i = 0; i < len; i++)
121 		insn[i] = __BPF_STMT(BPF_RET | BPF_K, 0xfefefefe);
122 
123 	self->u.ptr.insns = insn;
124 	self->u.ptr.len = len;
125 
126 	return 0;
127 }
128 
bpf_fill_maxinsns3(struct bpf_test * self)129 static int bpf_fill_maxinsns3(struct bpf_test *self)
130 {
131 	unsigned int len = BPF_MAXINSNS;
132 	struct sock_filter *insn;
133 	struct rnd_state rnd;
134 	int i;
135 
136 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
137 	if (!insn)
138 		return -ENOMEM;
139 
140 	prandom_seed_state(&rnd, 3141592653589793238ULL);
141 
142 	for (i = 0; i < len - 1; i++) {
143 		__u32 k = prandom_u32_state(&rnd);
144 
145 		insn[i] = __BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, k);
146 	}
147 
148 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_A, 0);
149 
150 	self->u.ptr.insns = insn;
151 	self->u.ptr.len = len;
152 
153 	return 0;
154 }
155 
bpf_fill_maxinsns4(struct bpf_test * self)156 static int bpf_fill_maxinsns4(struct bpf_test *self)
157 {
158 	unsigned int len = BPF_MAXINSNS + 1;
159 	struct sock_filter *insn;
160 	int i;
161 
162 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
163 	if (!insn)
164 		return -ENOMEM;
165 
166 	for (i = 0; i < len; i++)
167 		insn[i] = __BPF_STMT(BPF_RET | BPF_K, 0xfefefefe);
168 
169 	self->u.ptr.insns = insn;
170 	self->u.ptr.len = len;
171 
172 	return 0;
173 }
174 
bpf_fill_maxinsns5(struct bpf_test * self)175 static int bpf_fill_maxinsns5(struct bpf_test *self)
176 {
177 	unsigned int len = BPF_MAXINSNS;
178 	struct sock_filter *insn;
179 	int i;
180 
181 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
182 	if (!insn)
183 		return -ENOMEM;
184 
185 	insn[0] = __BPF_JUMP(BPF_JMP | BPF_JA, len - 2, 0, 0);
186 
187 	for (i = 1; i < len - 1; i++)
188 		insn[i] = __BPF_STMT(BPF_RET | BPF_K, 0xfefefefe);
189 
190 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_K, 0xabababab);
191 
192 	self->u.ptr.insns = insn;
193 	self->u.ptr.len = len;
194 
195 	return 0;
196 }
197 
bpf_fill_maxinsns6(struct bpf_test * self)198 static int bpf_fill_maxinsns6(struct bpf_test *self)
199 {
200 	unsigned int len = BPF_MAXINSNS;
201 	struct sock_filter *insn;
202 	int i;
203 
204 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
205 	if (!insn)
206 		return -ENOMEM;
207 
208 	for (i = 0; i < len - 1; i++)
209 		insn[i] = __BPF_STMT(BPF_LD | BPF_W | BPF_ABS, SKF_AD_OFF +
210 				     SKF_AD_VLAN_TAG_PRESENT);
211 
212 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_A, 0);
213 
214 	self->u.ptr.insns = insn;
215 	self->u.ptr.len = len;
216 
217 	return 0;
218 }
219 
bpf_fill_maxinsns7(struct bpf_test * self)220 static int bpf_fill_maxinsns7(struct bpf_test *self)
221 {
222 	unsigned int len = BPF_MAXINSNS;
223 	struct sock_filter *insn;
224 	int i;
225 
226 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
227 	if (!insn)
228 		return -ENOMEM;
229 
230 	for (i = 0; i < len - 4; i++)
231 		insn[i] = __BPF_STMT(BPF_LD | BPF_W | BPF_ABS, SKF_AD_OFF +
232 				     SKF_AD_CPU);
233 
234 	insn[len - 4] = __BPF_STMT(BPF_MISC | BPF_TAX, 0);
235 	insn[len - 3] = __BPF_STMT(BPF_LD | BPF_W | BPF_ABS, SKF_AD_OFF +
236 				   SKF_AD_CPU);
237 	insn[len - 2] = __BPF_STMT(BPF_ALU | BPF_SUB | BPF_X, 0);
238 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_A, 0);
239 
240 	self->u.ptr.insns = insn;
241 	self->u.ptr.len = len;
242 
243 	return 0;
244 }
245 
bpf_fill_maxinsns8(struct bpf_test * self)246 static int bpf_fill_maxinsns8(struct bpf_test *self)
247 {
248 	unsigned int len = BPF_MAXINSNS;
249 	struct sock_filter *insn;
250 	int i, jmp_off = len - 3;
251 
252 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
253 	if (!insn)
254 		return -ENOMEM;
255 
256 	insn[0] = __BPF_STMT(BPF_LD | BPF_IMM, 0xffffffff);
257 
258 	for (i = 1; i < len - 1; i++)
259 		insn[i] = __BPF_JUMP(BPF_JMP | BPF_JGT, 0xffffffff, jmp_off--, 0);
260 
261 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_A, 0);
262 
263 	self->u.ptr.insns = insn;
264 	self->u.ptr.len = len;
265 
266 	return 0;
267 }
268 
bpf_fill_maxinsns9(struct bpf_test * self)269 static int bpf_fill_maxinsns9(struct bpf_test *self)
270 {
271 	unsigned int len = BPF_MAXINSNS;
272 	struct bpf_insn *insn;
273 	int i;
274 
275 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
276 	if (!insn)
277 		return -ENOMEM;
278 
279 	insn[0] = BPF_JMP_IMM(BPF_JA, 0, 0, len - 2);
280 	insn[1] = BPF_ALU32_IMM(BPF_MOV, R0, 0xcbababab);
281 	insn[2] = BPF_EXIT_INSN();
282 
283 	for (i = 3; i < len - 2; i++)
284 		insn[i] = BPF_ALU32_IMM(BPF_MOV, R0, 0xfefefefe);
285 
286 	insn[len - 2] = BPF_EXIT_INSN();
287 	insn[len - 1] = BPF_JMP_IMM(BPF_JA, 0, 0, -(len - 1));
288 
289 	self->u.ptr.insns = insn;
290 	self->u.ptr.len = len;
291 
292 	return 0;
293 }
294 
bpf_fill_maxinsns10(struct bpf_test * self)295 static int bpf_fill_maxinsns10(struct bpf_test *self)
296 {
297 	unsigned int len = BPF_MAXINSNS, hlen = len - 2;
298 	struct bpf_insn *insn;
299 	int i;
300 
301 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
302 	if (!insn)
303 		return -ENOMEM;
304 
305 	for (i = 0; i < hlen / 2; i++)
306 		insn[i] = BPF_JMP_IMM(BPF_JA, 0, 0, hlen - 2 - 2 * i);
307 	for (i = hlen - 1; i > hlen / 2; i--)
308 		insn[i] = BPF_JMP_IMM(BPF_JA, 0, 0, hlen - 1 - 2 * i);
309 
310 	insn[hlen / 2] = BPF_JMP_IMM(BPF_JA, 0, 0, hlen / 2 - 1);
311 	insn[hlen]     = BPF_ALU32_IMM(BPF_MOV, R0, 0xabababac);
312 	insn[hlen + 1] = BPF_EXIT_INSN();
313 
314 	self->u.ptr.insns = insn;
315 	self->u.ptr.len = len;
316 
317 	return 0;
318 }
319 
__bpf_fill_ja(struct bpf_test * self,unsigned int len,unsigned int plen)320 static int __bpf_fill_ja(struct bpf_test *self, unsigned int len,
321 			 unsigned int plen)
322 {
323 	struct sock_filter *insn;
324 	unsigned int rlen;
325 	int i, j;
326 
327 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
328 	if (!insn)
329 		return -ENOMEM;
330 
331 	rlen = (len % plen) - 1;
332 
333 	for (i = 0; i + plen < len; i += plen)
334 		for (j = 0; j < plen; j++)
335 			insn[i + j] = __BPF_JUMP(BPF_JMP | BPF_JA,
336 						 plen - 1 - j, 0, 0);
337 	for (j = 0; j < rlen; j++)
338 		insn[i + j] = __BPF_JUMP(BPF_JMP | BPF_JA, rlen - 1 - j,
339 					 0, 0);
340 
341 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_K, 0xababcbac);
342 
343 	self->u.ptr.insns = insn;
344 	self->u.ptr.len = len;
345 
346 	return 0;
347 }
348 
bpf_fill_maxinsns11(struct bpf_test * self)349 static int bpf_fill_maxinsns11(struct bpf_test *self)
350 {
351 	/* Hits 70 passes on x86_64 and triggers NOPs padding. */
352 	return __bpf_fill_ja(self, BPF_MAXINSNS, 68);
353 }
354 
bpf_fill_maxinsns12(struct bpf_test * self)355 static int bpf_fill_maxinsns12(struct bpf_test *self)
356 {
357 	unsigned int len = BPF_MAXINSNS;
358 	struct sock_filter *insn;
359 	int i = 0;
360 
361 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
362 	if (!insn)
363 		return -ENOMEM;
364 
365 	insn[0] = __BPF_JUMP(BPF_JMP | BPF_JA, len - 2, 0, 0);
366 
367 	for (i = 1; i < len - 1; i++)
368 		insn[i] = __BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 0);
369 
370 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_K, 0xabababab);
371 
372 	self->u.ptr.insns = insn;
373 	self->u.ptr.len = len;
374 
375 	return 0;
376 }
377 
bpf_fill_maxinsns13(struct bpf_test * self)378 static int bpf_fill_maxinsns13(struct bpf_test *self)
379 {
380 	unsigned int len = BPF_MAXINSNS;
381 	struct sock_filter *insn;
382 	int i = 0;
383 
384 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
385 	if (!insn)
386 		return -ENOMEM;
387 
388 	for (i = 0; i < len - 3; i++)
389 		insn[i] = __BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 0);
390 
391 	insn[len - 3] = __BPF_STMT(BPF_LD | BPF_IMM, 0xabababab);
392 	insn[len - 2] = __BPF_STMT(BPF_ALU | BPF_XOR | BPF_X, 0);
393 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_A, 0);
394 
395 	self->u.ptr.insns = insn;
396 	self->u.ptr.len = len;
397 
398 	return 0;
399 }
400 
bpf_fill_ja(struct bpf_test * self)401 static int bpf_fill_ja(struct bpf_test *self)
402 {
403 	/* Hits exactly 11 passes on x86_64 JIT. */
404 	return __bpf_fill_ja(self, 12, 9);
405 }
406 
bpf_fill_ld_abs_get_processor_id(struct bpf_test * self)407 static int bpf_fill_ld_abs_get_processor_id(struct bpf_test *self)
408 {
409 	unsigned int len = BPF_MAXINSNS;
410 	struct sock_filter *insn;
411 	int i;
412 
413 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
414 	if (!insn)
415 		return -ENOMEM;
416 
417 	for (i = 0; i < len - 1; i += 2) {
418 		insn[i] = __BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 0);
419 		insn[i + 1] = __BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
420 					 SKF_AD_OFF + SKF_AD_CPU);
421 	}
422 
423 	insn[len - 1] = __BPF_STMT(BPF_RET | BPF_K, 0xbee);
424 
425 	self->u.ptr.insns = insn;
426 	self->u.ptr.len = len;
427 
428 	return 0;
429 }
430 
__bpf_fill_stxdw(struct bpf_test * self,int size)431 static int __bpf_fill_stxdw(struct bpf_test *self, int size)
432 {
433 	unsigned int len = BPF_MAXINSNS;
434 	struct bpf_insn *insn;
435 	int i;
436 
437 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
438 	if (!insn)
439 		return -ENOMEM;
440 
441 	insn[0] = BPF_ALU32_IMM(BPF_MOV, R0, 1);
442 	insn[1] = BPF_ST_MEM(size, R10, -40, 42);
443 
444 	for (i = 2; i < len - 2; i++)
445 		insn[i] = BPF_STX_XADD(size, R10, R0, -40);
446 
447 	insn[len - 2] = BPF_LDX_MEM(size, R0, R10, -40);
448 	insn[len - 1] = BPF_EXIT_INSN();
449 
450 	self->u.ptr.insns = insn;
451 	self->u.ptr.len = len;
452 	self->stack_depth = 40;
453 
454 	return 0;
455 }
456 
bpf_fill_stxw(struct bpf_test * self)457 static int bpf_fill_stxw(struct bpf_test *self)
458 {
459 	return __bpf_fill_stxdw(self, BPF_W);
460 }
461 
bpf_fill_stxdw(struct bpf_test * self)462 static int bpf_fill_stxdw(struct bpf_test *self)
463 {
464 	return __bpf_fill_stxdw(self, BPF_DW);
465 }
466 
__bpf_ld_imm64(struct bpf_insn insns[2],u8 reg,s64 imm64)467 static int __bpf_ld_imm64(struct bpf_insn insns[2], u8 reg, s64 imm64)
468 {
469 	struct bpf_insn tmp[] = {BPF_LD_IMM64(reg, imm64)};
470 
471 	memcpy(insns, tmp, sizeof(tmp));
472 	return 2;
473 }
474 
475 /*
476  * Branch conversion tests. Complex operations can expand to a lot
477  * of instructions when JITed. This in turn may cause jump offsets
478  * to overflow the field size of the native instruction, triggering
479  * a branch conversion mechanism in some JITs.
480  */
__bpf_fill_max_jmp(struct bpf_test * self,int jmp,int imm)481 static int __bpf_fill_max_jmp(struct bpf_test *self, int jmp, int imm)
482 {
483 	struct bpf_insn *insns;
484 	int len = S16_MAX + 5;
485 	int i;
486 
487 	insns = kmalloc_array(len, sizeof(*insns), GFP_KERNEL);
488 	if (!insns)
489 		return -ENOMEM;
490 
491 	i = __bpf_ld_imm64(insns, R1, 0x0123456789abcdefULL);
492 	insns[i++] = BPF_ALU64_IMM(BPF_MOV, R0, 1);
493 	insns[i++] = BPF_JMP_IMM(jmp, R0, imm, S16_MAX);
494 	insns[i++] = BPF_ALU64_IMM(BPF_MOV, R0, 2);
495 	insns[i++] = BPF_EXIT_INSN();
496 
497 	while (i < len - 1) {
498 		static const int ops[] = {
499 			BPF_LSH, BPF_RSH, BPF_ARSH, BPF_ADD,
500 			BPF_SUB, BPF_MUL, BPF_DIV, BPF_MOD,
501 		};
502 		int op = ops[(i >> 1) % ARRAY_SIZE(ops)];
503 
504 		if (i & 1)
505 			insns[i++] = BPF_ALU32_REG(op, R0, R1);
506 		else
507 			insns[i++] = BPF_ALU64_REG(op, R0, R1);
508 	}
509 
510 	insns[i++] = BPF_EXIT_INSN();
511 	self->u.ptr.insns = insns;
512 	self->u.ptr.len = len;
513 	BUG_ON(i != len);
514 
515 	return 0;
516 }
517 
518 /* Branch taken by runtime decision */
bpf_fill_max_jmp_taken(struct bpf_test * self)519 static int bpf_fill_max_jmp_taken(struct bpf_test *self)
520 {
521 	return __bpf_fill_max_jmp(self, BPF_JEQ, 1);
522 }
523 
524 /* Branch not taken by runtime decision */
bpf_fill_max_jmp_not_taken(struct bpf_test * self)525 static int bpf_fill_max_jmp_not_taken(struct bpf_test *self)
526 {
527 	return __bpf_fill_max_jmp(self, BPF_JEQ, 0);
528 }
529 
530 /* Branch always taken, known at JIT time */
bpf_fill_max_jmp_always_taken(struct bpf_test * self)531 static int bpf_fill_max_jmp_always_taken(struct bpf_test *self)
532 {
533 	return __bpf_fill_max_jmp(self, BPF_JGE, 0);
534 }
535 
536 /* Branch never taken, known at JIT time */
bpf_fill_max_jmp_never_taken(struct bpf_test * self)537 static int bpf_fill_max_jmp_never_taken(struct bpf_test *self)
538 {
539 	return __bpf_fill_max_jmp(self, BPF_JLT, 0);
540 }
541 
542 /* ALU result computation used in tests */
__bpf_alu_result(u64 * res,u64 v1,u64 v2,u8 op)543 static bool __bpf_alu_result(u64 *res, u64 v1, u64 v2, u8 op)
544 {
545 	*res = 0;
546 	switch (op) {
547 	case BPF_MOV:
548 		*res = v2;
549 		break;
550 	case BPF_AND:
551 		*res = v1 & v2;
552 		break;
553 	case BPF_OR:
554 		*res = v1 | v2;
555 		break;
556 	case BPF_XOR:
557 		*res = v1 ^ v2;
558 		break;
559 	case BPF_LSH:
560 		*res = v1 << v2;
561 		break;
562 	case BPF_RSH:
563 		*res = v1 >> v2;
564 		break;
565 	case BPF_ARSH:
566 		*res = v1 >> v2;
567 		if (v2 > 0 && v1 > S64_MAX)
568 			*res |= ~0ULL << (64 - v2);
569 		break;
570 	case BPF_ADD:
571 		*res = v1 + v2;
572 		break;
573 	case BPF_SUB:
574 		*res = v1 - v2;
575 		break;
576 	case BPF_MUL:
577 		*res = v1 * v2;
578 		break;
579 	case BPF_DIV:
580 		if (v2 == 0)
581 			return false;
582 		*res = div64_u64(v1, v2);
583 		break;
584 	case BPF_MOD:
585 		if (v2 == 0)
586 			return false;
587 		div64_u64_rem(v1, v2, res);
588 		break;
589 	}
590 	return true;
591 }
592 
593 /* Test an ALU shift operation for all valid shift values */
__bpf_fill_alu_shift(struct bpf_test * self,u8 op,u8 mode,bool alu32)594 static int __bpf_fill_alu_shift(struct bpf_test *self, u8 op,
595 				u8 mode, bool alu32)
596 {
597 	static const s64 regs[] = {
598 		0x0123456789abcdefLL, /* dword > 0, word < 0 */
599 		0xfedcba9876543210LL, /* dword < 0, word > 0 */
600 		0xfedcba0198765432LL, /* dword < 0, word < 0 */
601 		0x0123458967abcdefLL, /* dword > 0, word > 0 */
602 	};
603 	int bits = alu32 ? 32 : 64;
604 	int len = (2 + 7 * bits) * ARRAY_SIZE(regs) + 3;
605 	struct bpf_insn *insn;
606 	int imm, k;
607 	int i = 0;
608 
609 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
610 	if (!insn)
611 		return -ENOMEM;
612 
613 	insn[i++] = BPF_ALU64_IMM(BPF_MOV, R0, 0);
614 
615 	for (k = 0; k < ARRAY_SIZE(regs); k++) {
616 		s64 reg = regs[k];
617 
618 		i += __bpf_ld_imm64(&insn[i], R3, reg);
619 
620 		for (imm = 0; imm < bits; imm++) {
621 			u64 val;
622 
623 			/* Perform operation */
624 			insn[i++] = BPF_ALU64_REG(BPF_MOV, R1, R3);
625 			insn[i++] = BPF_ALU64_IMM(BPF_MOV, R2, imm);
626 			if (alu32) {
627 				if (mode == BPF_K)
628 					insn[i++] = BPF_ALU32_IMM(op, R1, imm);
629 				else
630 					insn[i++] = BPF_ALU32_REG(op, R1, R2);
631 
632 				if (op == BPF_ARSH)
633 					reg = (s32)reg;
634 				else
635 					reg = (u32)reg;
636 				__bpf_alu_result(&val, reg, imm, op);
637 				val = (u32)val;
638 			} else {
639 				if (mode == BPF_K)
640 					insn[i++] = BPF_ALU64_IMM(op, R1, imm);
641 				else
642 					insn[i++] = BPF_ALU64_REG(op, R1, R2);
643 				__bpf_alu_result(&val, reg, imm, op);
644 			}
645 
646 			/*
647 			 * When debugging a JIT that fails this test, one
648 			 * can write the immediate value to R0 here to find
649 			 * out which operand values that fail.
650 			 */
651 
652 			/* Load reference and check the result */
653 			i += __bpf_ld_imm64(&insn[i], R4, val);
654 			insn[i++] = BPF_JMP_REG(BPF_JEQ, R1, R4, 1);
655 			insn[i++] = BPF_EXIT_INSN();
656 		}
657 	}
658 
659 	insn[i++] = BPF_ALU64_IMM(BPF_MOV, R0, 1);
660 	insn[i++] = BPF_EXIT_INSN();
661 
662 	self->u.ptr.insns = insn;
663 	self->u.ptr.len = len;
664 	BUG_ON(i != len);
665 
666 	return 0;
667 }
668 
bpf_fill_alu64_lsh_imm(struct bpf_test * self)669 static int bpf_fill_alu64_lsh_imm(struct bpf_test *self)
670 {
671 	return __bpf_fill_alu_shift(self, BPF_LSH, BPF_K, false);
672 }
673 
bpf_fill_alu64_rsh_imm(struct bpf_test * self)674 static int bpf_fill_alu64_rsh_imm(struct bpf_test *self)
675 {
676 	return __bpf_fill_alu_shift(self, BPF_RSH, BPF_K, false);
677 }
678 
bpf_fill_alu64_arsh_imm(struct bpf_test * self)679 static int bpf_fill_alu64_arsh_imm(struct bpf_test *self)
680 {
681 	return __bpf_fill_alu_shift(self, BPF_ARSH, BPF_K, false);
682 }
683 
bpf_fill_alu64_lsh_reg(struct bpf_test * self)684 static int bpf_fill_alu64_lsh_reg(struct bpf_test *self)
685 {
686 	return __bpf_fill_alu_shift(self, BPF_LSH, BPF_X, false);
687 }
688 
bpf_fill_alu64_rsh_reg(struct bpf_test * self)689 static int bpf_fill_alu64_rsh_reg(struct bpf_test *self)
690 {
691 	return __bpf_fill_alu_shift(self, BPF_RSH, BPF_X, false);
692 }
693 
bpf_fill_alu64_arsh_reg(struct bpf_test * self)694 static int bpf_fill_alu64_arsh_reg(struct bpf_test *self)
695 {
696 	return __bpf_fill_alu_shift(self, BPF_ARSH, BPF_X, false);
697 }
698 
bpf_fill_alu32_lsh_imm(struct bpf_test * self)699 static int bpf_fill_alu32_lsh_imm(struct bpf_test *self)
700 {
701 	return __bpf_fill_alu_shift(self, BPF_LSH, BPF_K, true);
702 }
703 
bpf_fill_alu32_rsh_imm(struct bpf_test * self)704 static int bpf_fill_alu32_rsh_imm(struct bpf_test *self)
705 {
706 	return __bpf_fill_alu_shift(self, BPF_RSH, BPF_K, true);
707 }
708 
bpf_fill_alu32_arsh_imm(struct bpf_test * self)709 static int bpf_fill_alu32_arsh_imm(struct bpf_test *self)
710 {
711 	return __bpf_fill_alu_shift(self, BPF_ARSH, BPF_K, true);
712 }
713 
bpf_fill_alu32_lsh_reg(struct bpf_test * self)714 static int bpf_fill_alu32_lsh_reg(struct bpf_test *self)
715 {
716 	return __bpf_fill_alu_shift(self, BPF_LSH, BPF_X, true);
717 }
718 
bpf_fill_alu32_rsh_reg(struct bpf_test * self)719 static int bpf_fill_alu32_rsh_reg(struct bpf_test *self)
720 {
721 	return __bpf_fill_alu_shift(self, BPF_RSH, BPF_X, true);
722 }
723 
bpf_fill_alu32_arsh_reg(struct bpf_test * self)724 static int bpf_fill_alu32_arsh_reg(struct bpf_test *self)
725 {
726 	return __bpf_fill_alu_shift(self, BPF_ARSH, BPF_X, true);
727 }
728 
729 /*
730  * Test an ALU register shift operation for all valid shift values
731  * for the case when the source and destination are the same.
732  */
__bpf_fill_alu_shift_same_reg(struct bpf_test * self,u8 op,bool alu32)733 static int __bpf_fill_alu_shift_same_reg(struct bpf_test *self, u8 op,
734 					 bool alu32)
735 {
736 	int bits = alu32 ? 32 : 64;
737 	int len = 3 + 6 * bits;
738 	struct bpf_insn *insn;
739 	int i = 0;
740 	u64 val;
741 
742 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
743 	if (!insn)
744 		return -ENOMEM;
745 
746 	insn[i++] = BPF_ALU64_IMM(BPF_MOV, R0, 0);
747 
748 	for (val = 0; val < bits; val++) {
749 		u64 res;
750 
751 		/* Perform operation */
752 		insn[i++] = BPF_ALU64_IMM(BPF_MOV, R1, val);
753 		if (alu32)
754 			insn[i++] = BPF_ALU32_REG(op, R1, R1);
755 		else
756 			insn[i++] = BPF_ALU64_REG(op, R1, R1);
757 
758 		/* Compute the reference result */
759 		__bpf_alu_result(&res, val, val, op);
760 		if (alu32)
761 			res = (u32)res;
762 		i += __bpf_ld_imm64(&insn[i], R2, res);
763 
764 		/* Check the actual result */
765 		insn[i++] = BPF_JMP_REG(BPF_JEQ, R1, R2, 1);
766 		insn[i++] = BPF_EXIT_INSN();
767 	}
768 
769 	insn[i++] = BPF_ALU64_IMM(BPF_MOV, R0, 1);
770 	insn[i++] = BPF_EXIT_INSN();
771 
772 	self->u.ptr.insns = insn;
773 	self->u.ptr.len = len;
774 	BUG_ON(i != len);
775 
776 	return 0;
777 }
778 
bpf_fill_alu64_lsh_same_reg(struct bpf_test * self)779 static int bpf_fill_alu64_lsh_same_reg(struct bpf_test *self)
780 {
781 	return __bpf_fill_alu_shift_same_reg(self, BPF_LSH, false);
782 }
783 
bpf_fill_alu64_rsh_same_reg(struct bpf_test * self)784 static int bpf_fill_alu64_rsh_same_reg(struct bpf_test *self)
785 {
786 	return __bpf_fill_alu_shift_same_reg(self, BPF_RSH, false);
787 }
788 
bpf_fill_alu64_arsh_same_reg(struct bpf_test * self)789 static int bpf_fill_alu64_arsh_same_reg(struct bpf_test *self)
790 {
791 	return __bpf_fill_alu_shift_same_reg(self, BPF_ARSH, false);
792 }
793 
bpf_fill_alu32_lsh_same_reg(struct bpf_test * self)794 static int bpf_fill_alu32_lsh_same_reg(struct bpf_test *self)
795 {
796 	return __bpf_fill_alu_shift_same_reg(self, BPF_LSH, true);
797 }
798 
bpf_fill_alu32_rsh_same_reg(struct bpf_test * self)799 static int bpf_fill_alu32_rsh_same_reg(struct bpf_test *self)
800 {
801 	return __bpf_fill_alu_shift_same_reg(self, BPF_RSH, true);
802 }
803 
bpf_fill_alu32_arsh_same_reg(struct bpf_test * self)804 static int bpf_fill_alu32_arsh_same_reg(struct bpf_test *self)
805 {
806 	return __bpf_fill_alu_shift_same_reg(self, BPF_ARSH, true);
807 }
808 
809 /*
810  * Common operand pattern generator for exhaustive power-of-two magnitudes
811  * tests. The block size parameters can be adjusted to increase/reduce the
812  * number of combinatons tested and thereby execution speed and memory
813  * footprint.
814  */
815 
value(int msb,int delta,int sign)816 static inline s64 value(int msb, int delta, int sign)
817 {
818 	return sign * (1LL << msb) + delta;
819 }
820 
__bpf_fill_pattern(struct bpf_test * self,void * arg,int dbits,int sbits,int block1,int block2,int (* emit)(struct bpf_test *,void *,struct bpf_insn *,s64,s64))821 static int __bpf_fill_pattern(struct bpf_test *self, void *arg,
822 			      int dbits, int sbits, int block1, int block2,
823 			      int (*emit)(struct bpf_test*, void*,
824 					  struct bpf_insn*, s64, s64))
825 {
826 	static const int sgn[][2] = {{1, 1}, {1, -1}, {-1, 1}, {-1, -1}};
827 	struct bpf_insn *insns;
828 	int di, si, bt, db, sb;
829 	int count, len, k;
830 	int extra = 1 + 2;
831 	int i = 0;
832 
833 	/* Total number of iterations for the two pattern */
834 	count = (dbits - 1) * (sbits - 1) * block1 * block1 * ARRAY_SIZE(sgn);
835 	count += (max(dbits, sbits) - 1) * block2 * block2 * ARRAY_SIZE(sgn);
836 
837 	/* Compute the maximum number of insns and allocate the buffer */
838 	len = extra + count * (*emit)(self, arg, NULL, 0, 0);
839 	insns = kmalloc_array(len, sizeof(*insns), GFP_KERNEL);
840 	if (!insns)
841 		return -ENOMEM;
842 
843 	/* Add head instruction(s) */
844 	insns[i++] = BPF_ALU64_IMM(BPF_MOV, R0, 0);
845 
846 	/*
847 	 * Pattern 1: all combinations of power-of-two magnitudes and sign,
848 	 * and with a block of contiguous values around each magnitude.
849 	 */
850 	for (di = 0; di < dbits - 1; di++)                 /* Dst magnitudes */
851 		for (si = 0; si < sbits - 1; si++)         /* Src magnitudes */
852 			for (k = 0; k < ARRAY_SIZE(sgn); k++) /* Sign combos */
853 				for (db = -(block1 / 2);
854 				     db < (block1 + 1) / 2; db++)
855 					for (sb = -(block1 / 2);
856 					     sb < (block1 + 1) / 2; sb++) {
857 						s64 dst, src;
858 
859 						dst = value(di, db, sgn[k][0]);
860 						src = value(si, sb, sgn[k][1]);
861 						i += (*emit)(self, arg,
862 							     &insns[i],
863 							     dst, src);
864 					}
865 	/*
866 	 * Pattern 2: all combinations for a larger block of values
867 	 * for each power-of-two magnitude and sign, where the magnitude is
868 	 * the same for both operands.
869 	 */
870 	for (bt = 0; bt < max(dbits, sbits) - 1; bt++)        /* Magnitude   */
871 		for (k = 0; k < ARRAY_SIZE(sgn); k++)         /* Sign combos */
872 			for (db = -(block2 / 2); db < (block2 + 1) / 2; db++)
873 				for (sb = -(block2 / 2);
874 				     sb < (block2 + 1) / 2; sb++) {
875 					s64 dst, src;
876 
877 					dst = value(bt % dbits, db, sgn[k][0]);
878 					src = value(bt % sbits, sb, sgn[k][1]);
879 					i += (*emit)(self, arg, &insns[i],
880 						     dst, src);
881 				}
882 
883 	/* Append tail instructions */
884 	insns[i++] = BPF_ALU64_IMM(BPF_MOV, R0, 1);
885 	insns[i++] = BPF_EXIT_INSN();
886 	BUG_ON(i > len);
887 
888 	self->u.ptr.insns = insns;
889 	self->u.ptr.len = i;
890 
891 	return 0;
892 }
893 
894 /*
895  * Block size parameters used in pattern tests below. une as needed to
896  * increase/reduce the number combinations tested, see following examples.
897  *        block   values per operand MSB
898  * ----------------------------------------
899  *           0     none
900  *           1     (1 << MSB)
901  *           2     (1 << MSB) + [-1, 0]
902  *           3     (1 << MSB) + [-1, 0, 1]
903  */
904 #define PATTERN_BLOCK1 1
905 #define PATTERN_BLOCK2 5
906 
907 /* Number of test runs for a pattern test */
908 #define NR_PATTERN_RUNS 1
909 
910 /*
911  * Exhaustive tests of ALU operations for all combinations of power-of-two
912  * magnitudes of the operands, both for positive and negative values. The
913  * test is designed to verify e.g. the ALU and ALU64 operations for JITs that
914  * emit different code depending on the magnitude of the immediate value.
915  */
__bpf_emit_alu64_imm(struct bpf_test * self,void * arg,struct bpf_insn * insns,s64 dst,s64 imm)916 static int __bpf_emit_alu64_imm(struct bpf_test *self, void *arg,
917 				struct bpf_insn *insns, s64 dst, s64 imm)
918 {
919 	int op = *(int *)arg;
920 	int i = 0;
921 	u64 res;
922 
923 	if (!insns)
924 		return 7;
925 
926 	if (__bpf_alu_result(&res, dst, (s32)imm, op)) {
927 		i += __bpf_ld_imm64(&insns[i], R1, dst);
928 		i += __bpf_ld_imm64(&insns[i], R3, res);
929 		insns[i++] = BPF_ALU64_IMM(op, R1, imm);
930 		insns[i++] = BPF_JMP_REG(BPF_JEQ, R1, R3, 1);
931 		insns[i++] = BPF_EXIT_INSN();
932 	}
933 
934 	return i;
935 }
936 
__bpf_emit_alu32_imm(struct bpf_test * self,void * arg,struct bpf_insn * insns,s64 dst,s64 imm)937 static int __bpf_emit_alu32_imm(struct bpf_test *self, void *arg,
938 				struct bpf_insn *insns, s64 dst, s64 imm)
939 {
940 	int op = *(int *)arg;
941 	int i = 0;
942 	u64 res;
943 
944 	if (!insns)
945 		return 7;
946 
947 	if (__bpf_alu_result(&res, (u32)dst, (u32)imm, op)) {
948 		i += __bpf_ld_imm64(&insns[i], R1, dst);
949 		i += __bpf_ld_imm64(&insns[i], R3, (u32)res);
950 		insns[i++] = BPF_ALU32_IMM(op, R1, imm);
951 		insns[i++] = BPF_JMP_REG(BPF_JEQ, R1, R3, 1);
952 		insns[i++] = BPF_EXIT_INSN();
953 	}
954 
955 	return i;
956 }
957 
__bpf_emit_alu64_reg(struct bpf_test * self,void * arg,struct bpf_insn * insns,s64 dst,s64 src)958 static int __bpf_emit_alu64_reg(struct bpf_test *self, void *arg,
959 				struct bpf_insn *insns, s64 dst, s64 src)
960 {
961 	int op = *(int *)arg;
962 	int i = 0;
963 	u64 res;
964 
965 	if (!insns)
966 		return 9;
967 
968 	if (__bpf_alu_result(&res, dst, src, op)) {
969 		i += __bpf_ld_imm64(&insns[i], R1, dst);
970 		i += __bpf_ld_imm64(&insns[i], R2, src);
971 		i += __bpf_ld_imm64(&insns[i], R3, res);
972 		insns[i++] = BPF_ALU64_REG(op, R1, R2);
973 		insns[i++] = BPF_JMP_REG(BPF_JEQ, R1, R3, 1);
974 		insns[i++] = BPF_EXIT_INSN();
975 	}
976 
977 	return i;
978 }
979 
__bpf_emit_alu32_reg(struct bpf_test * self,void * arg,struct bpf_insn * insns,s64 dst,s64 src)980 static int __bpf_emit_alu32_reg(struct bpf_test *self, void *arg,
981 				struct bpf_insn *insns, s64 dst, s64 src)
982 {
983 	int op = *(int *)arg;
984 	int i = 0;
985 	u64 res;
986 
987 	if (!insns)
988 		return 9;
989 
990 	if (__bpf_alu_result(&res, (u32)dst, (u32)src, op)) {
991 		i += __bpf_ld_imm64(&insns[i], R1, dst);
992 		i += __bpf_ld_imm64(&insns[i], R2, src);
993 		i += __bpf_ld_imm64(&insns[i], R3, (u32)res);
994 		insns[i++] = BPF_ALU32_REG(op, R1, R2);
995 		insns[i++] = BPF_JMP_REG(BPF_JEQ, R1, R3, 1);
996 		insns[i++] = BPF_EXIT_INSN();
997 	}
998 
999 	return i;
1000 }
1001 
__bpf_fill_alu64_imm(struct bpf_test * self,int op)1002 static int __bpf_fill_alu64_imm(struct bpf_test *self, int op)
1003 {
1004 	return __bpf_fill_pattern(self, &op, 64, 32,
1005 				  PATTERN_BLOCK1, PATTERN_BLOCK2,
1006 				  &__bpf_emit_alu64_imm);
1007 }
1008 
__bpf_fill_alu32_imm(struct bpf_test * self,int op)1009 static int __bpf_fill_alu32_imm(struct bpf_test *self, int op)
1010 {
1011 	return __bpf_fill_pattern(self, &op, 64, 32,
1012 				  PATTERN_BLOCK1, PATTERN_BLOCK2,
1013 				  &__bpf_emit_alu32_imm);
1014 }
1015 
__bpf_fill_alu64_reg(struct bpf_test * self,int op)1016 static int __bpf_fill_alu64_reg(struct bpf_test *self, int op)
1017 {
1018 	return __bpf_fill_pattern(self, &op, 64, 64,
1019 				  PATTERN_BLOCK1, PATTERN_BLOCK2,
1020 				  &__bpf_emit_alu64_reg);
1021 }
1022 
__bpf_fill_alu32_reg(struct bpf_test * self,int op)1023 static int __bpf_fill_alu32_reg(struct bpf_test *self, int op)
1024 {
1025 	return __bpf_fill_pattern(self, &op, 64, 64,
1026 				  PATTERN_BLOCK1, PATTERN_BLOCK2,
1027 				  &__bpf_emit_alu32_reg);
1028 }
1029 
1030 /* ALU64 immediate operations */
bpf_fill_alu64_mov_imm(struct bpf_test * self)1031 static int bpf_fill_alu64_mov_imm(struct bpf_test *self)
1032 {
1033 	return __bpf_fill_alu64_imm(self, BPF_MOV);
1034 }
1035 
bpf_fill_alu64_and_imm(struct bpf_test * self)1036 static int bpf_fill_alu64_and_imm(struct bpf_test *self)
1037 {
1038 	return __bpf_fill_alu64_imm(self, BPF_AND);
1039 }
1040 
bpf_fill_alu64_or_imm(struct bpf_test * self)1041 static int bpf_fill_alu64_or_imm(struct bpf_test *self)
1042 {
1043 	return __bpf_fill_alu64_imm(self, BPF_OR);
1044 }
1045 
bpf_fill_alu64_xor_imm(struct bpf_test * self)1046 static int bpf_fill_alu64_xor_imm(struct bpf_test *self)
1047 {
1048 	return __bpf_fill_alu64_imm(self, BPF_XOR);
1049 }
1050 
bpf_fill_alu64_add_imm(struct bpf_test * self)1051 static int bpf_fill_alu64_add_imm(struct bpf_test *self)
1052 {
1053 	return __bpf_fill_alu64_imm(self, BPF_ADD);
1054 }
1055 
bpf_fill_alu64_sub_imm(struct bpf_test * self)1056 static int bpf_fill_alu64_sub_imm(struct bpf_test *self)
1057 {
1058 	return __bpf_fill_alu64_imm(self, BPF_SUB);
1059 }
1060 
bpf_fill_alu64_mul_imm(struct bpf_test * self)1061 static int bpf_fill_alu64_mul_imm(struct bpf_test *self)
1062 {
1063 	return __bpf_fill_alu64_imm(self, BPF_MUL);
1064 }
1065 
bpf_fill_alu64_div_imm(struct bpf_test * self)1066 static int bpf_fill_alu64_div_imm(struct bpf_test *self)
1067 {
1068 	return __bpf_fill_alu64_imm(self, BPF_DIV);
1069 }
1070 
bpf_fill_alu64_mod_imm(struct bpf_test * self)1071 static int bpf_fill_alu64_mod_imm(struct bpf_test *self)
1072 {
1073 	return __bpf_fill_alu64_imm(self, BPF_MOD);
1074 }
1075 
1076 /* ALU32 immediate operations */
bpf_fill_alu32_mov_imm(struct bpf_test * self)1077 static int bpf_fill_alu32_mov_imm(struct bpf_test *self)
1078 {
1079 	return __bpf_fill_alu32_imm(self, BPF_MOV);
1080 }
1081 
bpf_fill_alu32_and_imm(struct bpf_test * self)1082 static int bpf_fill_alu32_and_imm(struct bpf_test *self)
1083 {
1084 	return __bpf_fill_alu32_imm(self, BPF_AND);
1085 }
1086 
bpf_fill_alu32_or_imm(struct bpf_test * self)1087 static int bpf_fill_alu32_or_imm(struct bpf_test *self)
1088 {
1089 	return __bpf_fill_alu32_imm(self, BPF_OR);
1090 }
1091 
bpf_fill_alu32_xor_imm(struct bpf_test * self)1092 static int bpf_fill_alu32_xor_imm(struct bpf_test *self)
1093 {
1094 	return __bpf_fill_alu32_imm(self, BPF_XOR);
1095 }
1096 
bpf_fill_alu32_add_imm(struct bpf_test * self)1097 static int bpf_fill_alu32_add_imm(struct bpf_test *self)
1098 {
1099 	return __bpf_fill_alu32_imm(self, BPF_ADD);
1100 }
1101 
bpf_fill_alu32_sub_imm(struct bpf_test * self)1102 static int bpf_fill_alu32_sub_imm(struct bpf_test *self)
1103 {
1104 	return __bpf_fill_alu32_imm(self, BPF_SUB);
1105 }
1106 
bpf_fill_alu32_mul_imm(struct bpf_test * self)1107 static int bpf_fill_alu32_mul_imm(struct bpf_test *self)
1108 {
1109 	return __bpf_fill_alu32_imm(self, BPF_MUL);
1110 }
1111 
bpf_fill_alu32_div_imm(struct bpf_test * self)1112 static int bpf_fill_alu32_div_imm(struct bpf_test *self)
1113 {
1114 	return __bpf_fill_alu32_imm(self, BPF_DIV);
1115 }
1116 
bpf_fill_alu32_mod_imm(struct bpf_test * self)1117 static int bpf_fill_alu32_mod_imm(struct bpf_test *self)
1118 {
1119 	return __bpf_fill_alu32_imm(self, BPF_MOD);
1120 }
1121 
1122 /* ALU64 register operations */
bpf_fill_alu64_mov_reg(struct bpf_test * self)1123 static int bpf_fill_alu64_mov_reg(struct bpf_test *self)
1124 {
1125 	return __bpf_fill_alu64_reg(self, BPF_MOV);
1126 }
1127 
bpf_fill_alu64_and_reg(struct bpf_test * self)1128 static int bpf_fill_alu64_and_reg(struct bpf_test *self)
1129 {
1130 	return __bpf_fill_alu64_reg(self, BPF_AND);
1131 }
1132 
bpf_fill_alu64_or_reg(struct bpf_test * self)1133 static int bpf_fill_alu64_or_reg(struct bpf_test *self)
1134 {
1135 	return __bpf_fill_alu64_reg(self, BPF_OR);
1136 }
1137 
bpf_fill_alu64_xor_reg(struct bpf_test * self)1138 static int bpf_fill_alu64_xor_reg(struct bpf_test *self)
1139 {
1140 	return __bpf_fill_alu64_reg(self, BPF_XOR);
1141 }
1142 
bpf_fill_alu64_add_reg(struct bpf_test * self)1143 static int bpf_fill_alu64_add_reg(struct bpf_test *self)
1144 {
1145 	return __bpf_fill_alu64_reg(self, BPF_ADD);
1146 }
1147 
bpf_fill_alu64_sub_reg(struct bpf_test * self)1148 static int bpf_fill_alu64_sub_reg(struct bpf_test *self)
1149 {
1150 	return __bpf_fill_alu64_reg(self, BPF_SUB);
1151 }
1152 
bpf_fill_alu64_mul_reg(struct bpf_test * self)1153 static int bpf_fill_alu64_mul_reg(struct bpf_test *self)
1154 {
1155 	return __bpf_fill_alu64_reg(self, BPF_MUL);
1156 }
1157 
bpf_fill_alu64_div_reg(struct bpf_test * self)1158 static int bpf_fill_alu64_div_reg(struct bpf_test *self)
1159 {
1160 	return __bpf_fill_alu64_reg(self, BPF_DIV);
1161 }
1162 
bpf_fill_alu64_mod_reg(struct bpf_test * self)1163 static int bpf_fill_alu64_mod_reg(struct bpf_test *self)
1164 {
1165 	return __bpf_fill_alu64_reg(self, BPF_MOD);
1166 }
1167 
1168 /* ALU32 register operations */
bpf_fill_alu32_mov_reg(struct bpf_test * self)1169 static int bpf_fill_alu32_mov_reg(struct bpf_test *self)
1170 {
1171 	return __bpf_fill_alu32_reg(self, BPF_MOV);
1172 }
1173 
bpf_fill_alu32_and_reg(struct bpf_test * self)1174 static int bpf_fill_alu32_and_reg(struct bpf_test *self)
1175 {
1176 	return __bpf_fill_alu32_reg(self, BPF_AND);
1177 }
1178 
bpf_fill_alu32_or_reg(struct bpf_test * self)1179 static int bpf_fill_alu32_or_reg(struct bpf_test *self)
1180 {
1181 	return __bpf_fill_alu32_reg(self, BPF_OR);
1182 }
1183 
bpf_fill_alu32_xor_reg(struct bpf_test * self)1184 static int bpf_fill_alu32_xor_reg(struct bpf_test *self)
1185 {
1186 	return __bpf_fill_alu32_reg(self, BPF_XOR);
1187 }
1188 
bpf_fill_alu32_add_reg(struct bpf_test * self)1189 static int bpf_fill_alu32_add_reg(struct bpf_test *self)
1190 {
1191 	return __bpf_fill_alu32_reg(self, BPF_ADD);
1192 }
1193 
bpf_fill_alu32_sub_reg(struct bpf_test * self)1194 static int bpf_fill_alu32_sub_reg(struct bpf_test *self)
1195 {
1196 	return __bpf_fill_alu32_reg(self, BPF_SUB);
1197 }
1198 
bpf_fill_alu32_mul_reg(struct bpf_test * self)1199 static int bpf_fill_alu32_mul_reg(struct bpf_test *self)
1200 {
1201 	return __bpf_fill_alu32_reg(self, BPF_MUL);
1202 }
1203 
bpf_fill_alu32_div_reg(struct bpf_test * self)1204 static int bpf_fill_alu32_div_reg(struct bpf_test *self)
1205 {
1206 	return __bpf_fill_alu32_reg(self, BPF_DIV);
1207 }
1208 
bpf_fill_alu32_mod_reg(struct bpf_test * self)1209 static int bpf_fill_alu32_mod_reg(struct bpf_test *self)
1210 {
1211 	return __bpf_fill_alu32_reg(self, BPF_MOD);
1212 }
1213 
1214 /*
1215  * Test JITs that implement complex ALU operations as function
1216  * calls, and must re-arrange operands for argument passing.
1217  */
__bpf_fill_alu_imm_regs(struct bpf_test * self,u8 op,bool alu32)1218 static int __bpf_fill_alu_imm_regs(struct bpf_test *self, u8 op, bool alu32)
1219 {
1220 	int len = 2 + 10 * 10;
1221 	struct bpf_insn *insns;
1222 	u64 dst, res;
1223 	int i = 0;
1224 	u32 imm;
1225 	int rd;
1226 
1227 	insns = kmalloc_array(len, sizeof(*insns), GFP_KERNEL);
1228 	if (!insns)
1229 		return -ENOMEM;
1230 
1231 	/* Operand and result values according to operation */
1232 	if (alu32)
1233 		dst = 0x76543210U;
1234 	else
1235 		dst = 0x7edcba9876543210ULL;
1236 	imm = 0x01234567U;
1237 
1238 	if (op == BPF_LSH || op == BPF_RSH || op == BPF_ARSH)
1239 		imm &= 31;
1240 
1241 	__bpf_alu_result(&res, dst, imm, op);
1242 
1243 	if (alu32)
1244 		res = (u32)res;
1245 
1246 	/* Check all operand registers */
1247 	for (rd = R0; rd <= R9; rd++) {
1248 		i += __bpf_ld_imm64(&insns[i], rd, dst);
1249 
1250 		if (alu32)
1251 			insns[i++] = BPF_ALU32_IMM(op, rd, imm);
1252 		else
1253 			insns[i++] = BPF_ALU64_IMM(op, rd, imm);
1254 
1255 		insns[i++] = BPF_JMP32_IMM(BPF_JEQ, rd, res, 2);
1256 		insns[i++] = BPF_MOV64_IMM(R0, __LINE__);
1257 		insns[i++] = BPF_EXIT_INSN();
1258 
1259 		insns[i++] = BPF_ALU64_IMM(BPF_RSH, rd, 32);
1260 		insns[i++] = BPF_JMP32_IMM(BPF_JEQ, rd, res >> 32, 2);
1261 		insns[i++] = BPF_MOV64_IMM(R0, __LINE__);
1262 		insns[i++] = BPF_EXIT_INSN();
1263 	}
1264 
1265 	insns[i++] = BPF_MOV64_IMM(R0, 1);
1266 	insns[i++] = BPF_EXIT_INSN();
1267 
1268 	self->u.ptr.insns = insns;
1269 	self->u.ptr.len = len;
1270 	BUG_ON(i != len);
1271 
1272 	return 0;
1273 }
1274 
1275 /* ALU64 K registers */
bpf_fill_alu64_mov_imm_regs(struct bpf_test * self)1276 static int bpf_fill_alu64_mov_imm_regs(struct bpf_test *self)
1277 {
1278 	return __bpf_fill_alu_imm_regs(self, BPF_MOV, false);
1279 }
1280 
bpf_fill_alu64_and_imm_regs(struct bpf_test * self)1281 static int bpf_fill_alu64_and_imm_regs(struct bpf_test *self)
1282 {
1283 	return __bpf_fill_alu_imm_regs(self, BPF_AND, false);
1284 }
1285 
bpf_fill_alu64_or_imm_regs(struct bpf_test * self)1286 static int bpf_fill_alu64_or_imm_regs(struct bpf_test *self)
1287 {
1288 	return __bpf_fill_alu_imm_regs(self, BPF_OR, false);
1289 }
1290 
bpf_fill_alu64_xor_imm_regs(struct bpf_test * self)1291 static int bpf_fill_alu64_xor_imm_regs(struct bpf_test *self)
1292 {
1293 	return __bpf_fill_alu_imm_regs(self, BPF_XOR, false);
1294 }
1295 
bpf_fill_alu64_lsh_imm_regs(struct bpf_test * self)1296 static int bpf_fill_alu64_lsh_imm_regs(struct bpf_test *self)
1297 {
1298 	return __bpf_fill_alu_imm_regs(self, BPF_LSH, false);
1299 }
1300 
bpf_fill_alu64_rsh_imm_regs(struct bpf_test * self)1301 static int bpf_fill_alu64_rsh_imm_regs(struct bpf_test *self)
1302 {
1303 	return __bpf_fill_alu_imm_regs(self, BPF_RSH, false);
1304 }
1305 
bpf_fill_alu64_arsh_imm_regs(struct bpf_test * self)1306 static int bpf_fill_alu64_arsh_imm_regs(struct bpf_test *self)
1307 {
1308 	return __bpf_fill_alu_imm_regs(self, BPF_ARSH, false);
1309 }
1310 
bpf_fill_alu64_add_imm_regs(struct bpf_test * self)1311 static int bpf_fill_alu64_add_imm_regs(struct bpf_test *self)
1312 {
1313 	return __bpf_fill_alu_imm_regs(self, BPF_ADD, false);
1314 }
1315 
bpf_fill_alu64_sub_imm_regs(struct bpf_test * self)1316 static int bpf_fill_alu64_sub_imm_regs(struct bpf_test *self)
1317 {
1318 	return __bpf_fill_alu_imm_regs(self, BPF_SUB, false);
1319 }
1320 
bpf_fill_alu64_mul_imm_regs(struct bpf_test * self)1321 static int bpf_fill_alu64_mul_imm_regs(struct bpf_test *self)
1322 {
1323 	return __bpf_fill_alu_imm_regs(self, BPF_MUL, false);
1324 }
1325 
bpf_fill_alu64_div_imm_regs(struct bpf_test * self)1326 static int bpf_fill_alu64_div_imm_regs(struct bpf_test *self)
1327 {
1328 	return __bpf_fill_alu_imm_regs(self, BPF_DIV, false);
1329 }
1330 
bpf_fill_alu64_mod_imm_regs(struct bpf_test * self)1331 static int bpf_fill_alu64_mod_imm_regs(struct bpf_test *self)
1332 {
1333 	return __bpf_fill_alu_imm_regs(self, BPF_MOD, false);
1334 }
1335 
1336 /* ALU32 K registers */
bpf_fill_alu32_mov_imm_regs(struct bpf_test * self)1337 static int bpf_fill_alu32_mov_imm_regs(struct bpf_test *self)
1338 {
1339 	return __bpf_fill_alu_imm_regs(self, BPF_MOV, true);
1340 }
1341 
bpf_fill_alu32_and_imm_regs(struct bpf_test * self)1342 static int bpf_fill_alu32_and_imm_regs(struct bpf_test *self)
1343 {
1344 	return __bpf_fill_alu_imm_regs(self, BPF_AND, true);
1345 }
1346 
bpf_fill_alu32_or_imm_regs(struct bpf_test * self)1347 static int bpf_fill_alu32_or_imm_regs(struct bpf_test *self)
1348 {
1349 	return __bpf_fill_alu_imm_regs(self, BPF_OR, true);
1350 }
1351 
bpf_fill_alu32_xor_imm_regs(struct bpf_test * self)1352 static int bpf_fill_alu32_xor_imm_regs(struct bpf_test *self)
1353 {
1354 	return __bpf_fill_alu_imm_regs(self, BPF_XOR, true);
1355 }
1356 
bpf_fill_alu32_lsh_imm_regs(struct bpf_test * self)1357 static int bpf_fill_alu32_lsh_imm_regs(struct bpf_test *self)
1358 {
1359 	return __bpf_fill_alu_imm_regs(self, BPF_LSH, true);
1360 }
1361 
bpf_fill_alu32_rsh_imm_regs(struct bpf_test * self)1362 static int bpf_fill_alu32_rsh_imm_regs(struct bpf_test *self)
1363 {
1364 	return __bpf_fill_alu_imm_regs(self, BPF_RSH, true);
1365 }
1366 
bpf_fill_alu32_arsh_imm_regs(struct bpf_test * self)1367 static int bpf_fill_alu32_arsh_imm_regs(struct bpf_test *self)
1368 {
1369 	return __bpf_fill_alu_imm_regs(self, BPF_ARSH, true);
1370 }
1371 
bpf_fill_alu32_add_imm_regs(struct bpf_test * self)1372 static int bpf_fill_alu32_add_imm_regs(struct bpf_test *self)
1373 {
1374 	return __bpf_fill_alu_imm_regs(self, BPF_ADD, true);
1375 }
1376 
bpf_fill_alu32_sub_imm_regs(struct bpf_test * self)1377 static int bpf_fill_alu32_sub_imm_regs(struct bpf_test *self)
1378 {
1379 	return __bpf_fill_alu_imm_regs(self, BPF_SUB, true);
1380 }
1381 
bpf_fill_alu32_mul_imm_regs(struct bpf_test * self)1382 static int bpf_fill_alu32_mul_imm_regs(struct bpf_test *self)
1383 {
1384 	return __bpf_fill_alu_imm_regs(self, BPF_MUL, true);
1385 }
1386 
bpf_fill_alu32_div_imm_regs(struct bpf_test * self)1387 static int bpf_fill_alu32_div_imm_regs(struct bpf_test *self)
1388 {
1389 	return __bpf_fill_alu_imm_regs(self, BPF_DIV, true);
1390 }
1391 
bpf_fill_alu32_mod_imm_regs(struct bpf_test * self)1392 static int bpf_fill_alu32_mod_imm_regs(struct bpf_test *self)
1393 {
1394 	return __bpf_fill_alu_imm_regs(self, BPF_MOD, true);
1395 }
1396 
1397 /*
1398  * Test JITs that implement complex ALU operations as function
1399  * calls, and must re-arrange operands for argument passing.
1400  */
__bpf_fill_alu_reg_pairs(struct bpf_test * self,u8 op,bool alu32)1401 static int __bpf_fill_alu_reg_pairs(struct bpf_test *self, u8 op, bool alu32)
1402 {
1403 	int len = 2 + 10 * 10 * 12;
1404 	u64 dst, src, res, same;
1405 	struct bpf_insn *insns;
1406 	int rd, rs;
1407 	int i = 0;
1408 
1409 	insns = kmalloc_array(len, sizeof(*insns), GFP_KERNEL);
1410 	if (!insns)
1411 		return -ENOMEM;
1412 
1413 	/* Operand and result values according to operation */
1414 	if (alu32) {
1415 		dst = 0x76543210U;
1416 		src = 0x01234567U;
1417 	} else {
1418 		dst = 0x7edcba9876543210ULL;
1419 		src = 0x0123456789abcdefULL;
1420 	}
1421 
1422 	if (op == BPF_LSH || op == BPF_RSH || op == BPF_ARSH)
1423 		src &= 31;
1424 
1425 	__bpf_alu_result(&res, dst, src, op);
1426 	__bpf_alu_result(&same, src, src, op);
1427 
1428 	if (alu32) {
1429 		res = (u32)res;
1430 		same = (u32)same;
1431 	}
1432 
1433 	/* Check all combinations of operand registers */
1434 	for (rd = R0; rd <= R9; rd++) {
1435 		for (rs = R0; rs <= R9; rs++) {
1436 			u64 val = rd == rs ? same : res;
1437 
1438 			i += __bpf_ld_imm64(&insns[i], rd, dst);
1439 			i += __bpf_ld_imm64(&insns[i], rs, src);
1440 
1441 			if (alu32)
1442 				insns[i++] = BPF_ALU32_REG(op, rd, rs);
1443 			else
1444 				insns[i++] = BPF_ALU64_REG(op, rd, rs);
1445 
1446 			insns[i++] = BPF_JMP32_IMM(BPF_JEQ, rd, val, 2);
1447 			insns[i++] = BPF_MOV64_IMM(R0, __LINE__);
1448 			insns[i++] = BPF_EXIT_INSN();
1449 
1450 			insns[i++] = BPF_ALU64_IMM(BPF_RSH, rd, 32);
1451 			insns[i++] = BPF_JMP32_IMM(BPF_JEQ, rd, val >> 32, 2);
1452 			insns[i++] = BPF_MOV64_IMM(R0, __LINE__);
1453 			insns[i++] = BPF_EXIT_INSN();
1454 		}
1455 	}
1456 
1457 	insns[i++] = BPF_MOV64_IMM(R0, 1);
1458 	insns[i++] = BPF_EXIT_INSN();
1459 
1460 	self->u.ptr.insns = insns;
1461 	self->u.ptr.len = len;
1462 	BUG_ON(i != len);
1463 
1464 	return 0;
1465 }
1466 
1467 /* ALU64 X register combinations */
bpf_fill_alu64_mov_reg_pairs(struct bpf_test * self)1468 static int bpf_fill_alu64_mov_reg_pairs(struct bpf_test *self)
1469 {
1470 	return __bpf_fill_alu_reg_pairs(self, BPF_MOV, false);
1471 }
1472 
bpf_fill_alu64_and_reg_pairs(struct bpf_test * self)1473 static int bpf_fill_alu64_and_reg_pairs(struct bpf_test *self)
1474 {
1475 	return __bpf_fill_alu_reg_pairs(self, BPF_AND, false);
1476 }
1477 
bpf_fill_alu64_or_reg_pairs(struct bpf_test * self)1478 static int bpf_fill_alu64_or_reg_pairs(struct bpf_test *self)
1479 {
1480 	return __bpf_fill_alu_reg_pairs(self, BPF_OR, false);
1481 }
1482 
bpf_fill_alu64_xor_reg_pairs(struct bpf_test * self)1483 static int bpf_fill_alu64_xor_reg_pairs(struct bpf_test *self)
1484 {
1485 	return __bpf_fill_alu_reg_pairs(self, BPF_XOR, false);
1486 }
1487 
bpf_fill_alu64_lsh_reg_pairs(struct bpf_test * self)1488 static int bpf_fill_alu64_lsh_reg_pairs(struct bpf_test *self)
1489 {
1490 	return __bpf_fill_alu_reg_pairs(self, BPF_LSH, false);
1491 }
1492 
bpf_fill_alu64_rsh_reg_pairs(struct bpf_test * self)1493 static int bpf_fill_alu64_rsh_reg_pairs(struct bpf_test *self)
1494 {
1495 	return __bpf_fill_alu_reg_pairs(self, BPF_RSH, false);
1496 }
1497 
bpf_fill_alu64_arsh_reg_pairs(struct bpf_test * self)1498 static int bpf_fill_alu64_arsh_reg_pairs(struct bpf_test *self)
1499 {
1500 	return __bpf_fill_alu_reg_pairs(self, BPF_ARSH, false);
1501 }
1502 
bpf_fill_alu64_add_reg_pairs(struct bpf_test * self)1503 static int bpf_fill_alu64_add_reg_pairs(struct bpf_test *self)
1504 {
1505 	return __bpf_fill_alu_reg_pairs(self, BPF_ADD, false);
1506 }
1507 
bpf_fill_alu64_sub_reg_pairs(struct bpf_test * self)1508 static int bpf_fill_alu64_sub_reg_pairs(struct bpf_test *self)
1509 {
1510 	return __bpf_fill_alu_reg_pairs(self, BPF_SUB, false);
1511 }
1512 
bpf_fill_alu64_mul_reg_pairs(struct bpf_test * self)1513 static int bpf_fill_alu64_mul_reg_pairs(struct bpf_test *self)
1514 {
1515 	return __bpf_fill_alu_reg_pairs(self, BPF_MUL, false);
1516 }
1517 
bpf_fill_alu64_div_reg_pairs(struct bpf_test * self)1518 static int bpf_fill_alu64_div_reg_pairs(struct bpf_test *self)
1519 {
1520 	return __bpf_fill_alu_reg_pairs(self, BPF_DIV, false);
1521 }
1522 
bpf_fill_alu64_mod_reg_pairs(struct bpf_test * self)1523 static int bpf_fill_alu64_mod_reg_pairs(struct bpf_test *self)
1524 {
1525 	return __bpf_fill_alu_reg_pairs(self, BPF_MOD, false);
1526 }
1527 
1528 /* ALU32 X register combinations */
bpf_fill_alu32_mov_reg_pairs(struct bpf_test * self)1529 static int bpf_fill_alu32_mov_reg_pairs(struct bpf_test *self)
1530 {
1531 	return __bpf_fill_alu_reg_pairs(self, BPF_MOV, true);
1532 }
1533 
bpf_fill_alu32_and_reg_pairs(struct bpf_test * self)1534 static int bpf_fill_alu32_and_reg_pairs(struct bpf_test *self)
1535 {
1536 	return __bpf_fill_alu_reg_pairs(self, BPF_AND, true);
1537 }
1538 
bpf_fill_alu32_or_reg_pairs(struct bpf_test * self)1539 static int bpf_fill_alu32_or_reg_pairs(struct bpf_test *self)
1540 {
1541 	return __bpf_fill_alu_reg_pairs(self, BPF_OR, true);
1542 }
1543 
bpf_fill_alu32_xor_reg_pairs(struct bpf_test * self)1544 static int bpf_fill_alu32_xor_reg_pairs(struct bpf_test *self)
1545 {
1546 	return __bpf_fill_alu_reg_pairs(self, BPF_XOR, true);
1547 }
1548 
bpf_fill_alu32_lsh_reg_pairs(struct bpf_test * self)1549 static int bpf_fill_alu32_lsh_reg_pairs(struct bpf_test *self)
1550 {
1551 	return __bpf_fill_alu_reg_pairs(self, BPF_LSH, true);
1552 }
1553 
bpf_fill_alu32_rsh_reg_pairs(struct bpf_test * self)1554 static int bpf_fill_alu32_rsh_reg_pairs(struct bpf_test *self)
1555 {
1556 	return __bpf_fill_alu_reg_pairs(self, BPF_RSH, true);
1557 }
1558 
bpf_fill_alu32_arsh_reg_pairs(struct bpf_test * self)1559 static int bpf_fill_alu32_arsh_reg_pairs(struct bpf_test *self)
1560 {
1561 	return __bpf_fill_alu_reg_pairs(self, BPF_ARSH, true);
1562 }
1563 
bpf_fill_alu32_add_reg_pairs(struct bpf_test * self)1564 static int bpf_fill_alu32_add_reg_pairs(struct bpf_test *self)
1565 {
1566 	return __bpf_fill_alu_reg_pairs(self, BPF_ADD, true);
1567 }
1568 
bpf_fill_alu32_sub_reg_pairs(struct bpf_test * self)1569 static int bpf_fill_alu32_sub_reg_pairs(struct bpf_test *self)
1570 {
1571 	return __bpf_fill_alu_reg_pairs(self, BPF_SUB, true);
1572 }
1573 
bpf_fill_alu32_mul_reg_pairs(struct bpf_test * self)1574 static int bpf_fill_alu32_mul_reg_pairs(struct bpf_test *self)
1575 {
1576 	return __bpf_fill_alu_reg_pairs(self, BPF_MUL, true);
1577 }
1578 
bpf_fill_alu32_div_reg_pairs(struct bpf_test * self)1579 static int bpf_fill_alu32_div_reg_pairs(struct bpf_test *self)
1580 {
1581 	return __bpf_fill_alu_reg_pairs(self, BPF_DIV, true);
1582 }
1583 
bpf_fill_alu32_mod_reg_pairs(struct bpf_test * self)1584 static int bpf_fill_alu32_mod_reg_pairs(struct bpf_test *self)
1585 {
1586 	return __bpf_fill_alu_reg_pairs(self, BPF_MOD, true);
1587 }
1588 
1589 /*
1590  * Exhaustive tests of atomic operations for all power-of-two operand
1591  * magnitudes, both for positive and negative values.
1592  */
1593 
__bpf_emit_atomic64(struct bpf_test * self,void * arg,struct bpf_insn * insns,s64 dst,s64 src)1594 static int __bpf_emit_atomic64(struct bpf_test *self, void *arg,
1595 			       struct bpf_insn *insns, s64 dst, s64 src)
1596 {
1597 	int op = *(int *)arg;
1598 	u64 keep, fetch, res;
1599 	int i = 0;
1600 
1601 	if (!insns)
1602 		return 21;
1603 
1604 	switch (op) {
1605 	case BPF_XCHG:
1606 		res = src;
1607 		break;
1608 	default:
1609 		__bpf_alu_result(&res, dst, src, BPF_OP(op));
1610 	}
1611 
1612 	keep = 0x0123456789abcdefULL;
1613 	if (op & BPF_FETCH)
1614 		fetch = dst;
1615 	else
1616 		fetch = src;
1617 
1618 	i += __bpf_ld_imm64(&insns[i], R0, keep);
1619 	i += __bpf_ld_imm64(&insns[i], R1, dst);
1620 	i += __bpf_ld_imm64(&insns[i], R2, src);
1621 	i += __bpf_ld_imm64(&insns[i], R3, res);
1622 	i += __bpf_ld_imm64(&insns[i], R4, fetch);
1623 	i += __bpf_ld_imm64(&insns[i], R5, keep);
1624 
1625 	insns[i++] = BPF_STX_MEM(BPF_DW, R10, R1, -8);
1626 	insns[i++] = BPF_ATOMIC_OP(BPF_DW, op, R10, R2, -8);
1627 	insns[i++] = BPF_LDX_MEM(BPF_DW, R1, R10, -8);
1628 
1629 	insns[i++] = BPF_JMP_REG(BPF_JEQ, R1, R3, 1);
1630 	insns[i++] = BPF_EXIT_INSN();
1631 
1632 	insns[i++] = BPF_JMP_REG(BPF_JEQ, R2, R4, 1);
1633 	insns[i++] = BPF_EXIT_INSN();
1634 
1635 	insns[i++] = BPF_JMP_REG(BPF_JEQ, R0, R5, 1);
1636 	insns[i++] = BPF_EXIT_INSN();
1637 
1638 	return i;
1639 }
1640 
__bpf_emit_atomic32(struct bpf_test * self,void * arg,struct bpf_insn * insns,s64 dst,s64 src)1641 static int __bpf_emit_atomic32(struct bpf_test *self, void *arg,
1642 			       struct bpf_insn *insns, s64 dst, s64 src)
1643 {
1644 	int op = *(int *)arg;
1645 	u64 keep, fetch, res;
1646 	int i = 0;
1647 
1648 	if (!insns)
1649 		return 21;
1650 
1651 	switch (op) {
1652 	case BPF_XCHG:
1653 		res = src;
1654 		break;
1655 	default:
1656 		__bpf_alu_result(&res, (u32)dst, (u32)src, BPF_OP(op));
1657 	}
1658 
1659 	keep = 0x0123456789abcdefULL;
1660 	if (op & BPF_FETCH)
1661 		fetch = (u32)dst;
1662 	else
1663 		fetch = src;
1664 
1665 	i += __bpf_ld_imm64(&insns[i], R0, keep);
1666 	i += __bpf_ld_imm64(&insns[i], R1, (u32)dst);
1667 	i += __bpf_ld_imm64(&insns[i], R2, src);
1668 	i += __bpf_ld_imm64(&insns[i], R3, (u32)res);
1669 	i += __bpf_ld_imm64(&insns[i], R4, fetch);
1670 	i += __bpf_ld_imm64(&insns[i], R5, keep);
1671 
1672 	insns[i++] = BPF_STX_MEM(BPF_W, R10, R1, -4);
1673 	insns[i++] = BPF_ATOMIC_OP(BPF_W, op, R10, R2, -4);
1674 	insns[i++] = BPF_LDX_MEM(BPF_W, R1, R10, -4);
1675 
1676 	insns[i++] = BPF_JMP_REG(BPF_JEQ, R1, R3, 1);
1677 	insns[i++] = BPF_EXIT_INSN();
1678 
1679 	insns[i++] = BPF_JMP_REG(BPF_JEQ, R2, R4, 1);
1680 	insns[i++] = BPF_EXIT_INSN();
1681 
1682 	insns[i++] = BPF_JMP_REG(BPF_JEQ, R0, R5, 1);
1683 	insns[i++] = BPF_EXIT_INSN();
1684 
1685 	return i;
1686 }
1687 
__bpf_emit_cmpxchg64(struct bpf_test * self,void * arg,struct bpf_insn * insns,s64 dst,s64 src)1688 static int __bpf_emit_cmpxchg64(struct bpf_test *self, void *arg,
1689 				struct bpf_insn *insns, s64 dst, s64 src)
1690 {
1691 	int i = 0;
1692 
1693 	if (!insns)
1694 		return 23;
1695 
1696 	i += __bpf_ld_imm64(&insns[i], R0, ~dst);
1697 	i += __bpf_ld_imm64(&insns[i], R1, dst);
1698 	i += __bpf_ld_imm64(&insns[i], R2, src);
1699 
1700 	/* Result unsuccessful */
1701 	insns[i++] = BPF_STX_MEM(BPF_DW, R10, R1, -8);
1702 	insns[i++] = BPF_ATOMIC_OP(BPF_DW, BPF_CMPXCHG, R10, R2, -8);
1703 	insns[i++] = BPF_LDX_MEM(BPF_DW, R3, R10, -8);
1704 
1705 	insns[i++] = BPF_JMP_REG(BPF_JEQ, R1, R3, 2);
1706 	insns[i++] = BPF_MOV64_IMM(R0, __LINE__);
1707 	insns[i++] = BPF_EXIT_INSN();
1708 
1709 	insns[i++] = BPF_JMP_REG(BPF_JEQ, R0, R3, 2);
1710 	insns[i++] = BPF_MOV64_IMM(R0, __LINE__);
1711 	insns[i++] = BPF_EXIT_INSN();
1712 
1713 	/* Result successful */
1714 	insns[i++] = BPF_ATOMIC_OP(BPF_DW, BPF_CMPXCHG, R10, R2, -8);
1715 	insns[i++] = BPF_LDX_MEM(BPF_DW, R3, R10, -8);
1716 
1717 	insns[i++] = BPF_JMP_REG(BPF_JEQ, R2, R3, 2);
1718 	insns[i++] = BPF_MOV64_IMM(R0, __LINE__);
1719 	insns[i++] = BPF_EXIT_INSN();
1720 
1721 	insns[i++] = BPF_JMP_REG(BPF_JEQ, R0, R1, 2);
1722 	insns[i++] = BPF_MOV64_IMM(R0, __LINE__);
1723 	insns[i++] = BPF_EXIT_INSN();
1724 
1725 	return i;
1726 }
1727 
__bpf_emit_cmpxchg32(struct bpf_test * self,void * arg,struct bpf_insn * insns,s64 dst,s64 src)1728 static int __bpf_emit_cmpxchg32(struct bpf_test *self, void *arg,
1729 				struct bpf_insn *insns, s64 dst, s64 src)
1730 {
1731 	int i = 0;
1732 
1733 	if (!insns)
1734 		return 27;
1735 
1736 	i += __bpf_ld_imm64(&insns[i], R0, ~dst);
1737 	i += __bpf_ld_imm64(&insns[i], R1, (u32)dst);
1738 	i += __bpf_ld_imm64(&insns[i], R2, src);
1739 
1740 	/* Result unsuccessful */
1741 	insns[i++] = BPF_STX_MEM(BPF_W, R10, R1, -4);
1742 	insns[i++] = BPF_ATOMIC_OP(BPF_W, BPF_CMPXCHG, R10, R2, -4);
1743 	insns[i++] = BPF_ZEXT_REG(R0), /* Zext always inserted by verifier */
1744 	insns[i++] = BPF_LDX_MEM(BPF_W, R3, R10, -4);
1745 
1746 	insns[i++] = BPF_JMP32_REG(BPF_JEQ, R1, R3, 2);
1747 	insns[i++] = BPF_MOV32_IMM(R0, __LINE__);
1748 	insns[i++] = BPF_EXIT_INSN();
1749 
1750 	insns[i++] = BPF_JMP_REG(BPF_JEQ, R0, R3, 2);
1751 	insns[i++] = BPF_MOV32_IMM(R0, __LINE__);
1752 	insns[i++] = BPF_EXIT_INSN();
1753 
1754 	/* Result successful */
1755 	i += __bpf_ld_imm64(&insns[i], R0, dst);
1756 	insns[i++] = BPF_ATOMIC_OP(BPF_W, BPF_CMPXCHG, R10, R2, -4);
1757 	insns[i++] = BPF_ZEXT_REG(R0), /* Zext always inserted by verifier */
1758 	insns[i++] = BPF_LDX_MEM(BPF_W, R3, R10, -4);
1759 
1760 	insns[i++] = BPF_JMP32_REG(BPF_JEQ, R2, R3, 2);
1761 	insns[i++] = BPF_MOV32_IMM(R0, __LINE__);
1762 	insns[i++] = BPF_EXIT_INSN();
1763 
1764 	insns[i++] = BPF_JMP_REG(BPF_JEQ, R0, R1, 2);
1765 	insns[i++] = BPF_MOV32_IMM(R0, __LINE__);
1766 	insns[i++] = BPF_EXIT_INSN();
1767 
1768 	return i;
1769 }
1770 
__bpf_fill_atomic64(struct bpf_test * self,int op)1771 static int __bpf_fill_atomic64(struct bpf_test *self, int op)
1772 {
1773 	return __bpf_fill_pattern(self, &op, 64, 64,
1774 				  0, PATTERN_BLOCK2,
1775 				  &__bpf_emit_atomic64);
1776 }
1777 
__bpf_fill_atomic32(struct bpf_test * self,int op)1778 static int __bpf_fill_atomic32(struct bpf_test *self, int op)
1779 {
1780 	return __bpf_fill_pattern(self, &op, 64, 64,
1781 				  0, PATTERN_BLOCK2,
1782 				  &__bpf_emit_atomic32);
1783 }
1784 
1785 /* 64-bit atomic operations */
bpf_fill_atomic64_add(struct bpf_test * self)1786 static int bpf_fill_atomic64_add(struct bpf_test *self)
1787 {
1788 	return __bpf_fill_atomic64(self, BPF_ADD);
1789 }
1790 
bpf_fill_atomic64_and(struct bpf_test * self)1791 static int bpf_fill_atomic64_and(struct bpf_test *self)
1792 {
1793 	return __bpf_fill_atomic64(self, BPF_AND);
1794 }
1795 
bpf_fill_atomic64_or(struct bpf_test * self)1796 static int bpf_fill_atomic64_or(struct bpf_test *self)
1797 {
1798 	return __bpf_fill_atomic64(self, BPF_OR);
1799 }
1800 
bpf_fill_atomic64_xor(struct bpf_test * self)1801 static int bpf_fill_atomic64_xor(struct bpf_test *self)
1802 {
1803 	return __bpf_fill_atomic64(self, BPF_XOR);
1804 }
1805 
bpf_fill_atomic64_add_fetch(struct bpf_test * self)1806 static int bpf_fill_atomic64_add_fetch(struct bpf_test *self)
1807 {
1808 	return __bpf_fill_atomic64(self, BPF_ADD | BPF_FETCH);
1809 }
1810 
bpf_fill_atomic64_and_fetch(struct bpf_test * self)1811 static int bpf_fill_atomic64_and_fetch(struct bpf_test *self)
1812 {
1813 	return __bpf_fill_atomic64(self, BPF_AND | BPF_FETCH);
1814 }
1815 
bpf_fill_atomic64_or_fetch(struct bpf_test * self)1816 static int bpf_fill_atomic64_or_fetch(struct bpf_test *self)
1817 {
1818 	return __bpf_fill_atomic64(self, BPF_OR | BPF_FETCH);
1819 }
1820 
bpf_fill_atomic64_xor_fetch(struct bpf_test * self)1821 static int bpf_fill_atomic64_xor_fetch(struct bpf_test *self)
1822 {
1823 	return __bpf_fill_atomic64(self, BPF_XOR | BPF_FETCH);
1824 }
1825 
bpf_fill_atomic64_xchg(struct bpf_test * self)1826 static int bpf_fill_atomic64_xchg(struct bpf_test *self)
1827 {
1828 	return __bpf_fill_atomic64(self, BPF_XCHG);
1829 }
1830 
bpf_fill_cmpxchg64(struct bpf_test * self)1831 static int bpf_fill_cmpxchg64(struct bpf_test *self)
1832 {
1833 	return __bpf_fill_pattern(self, NULL, 64, 64, 0, PATTERN_BLOCK2,
1834 				  &__bpf_emit_cmpxchg64);
1835 }
1836 
1837 /* 32-bit atomic operations */
bpf_fill_atomic32_add(struct bpf_test * self)1838 static int bpf_fill_atomic32_add(struct bpf_test *self)
1839 {
1840 	return __bpf_fill_atomic32(self, BPF_ADD);
1841 }
1842 
bpf_fill_atomic32_and(struct bpf_test * self)1843 static int bpf_fill_atomic32_and(struct bpf_test *self)
1844 {
1845 	return __bpf_fill_atomic32(self, BPF_AND);
1846 }
1847 
bpf_fill_atomic32_or(struct bpf_test * self)1848 static int bpf_fill_atomic32_or(struct bpf_test *self)
1849 {
1850 	return __bpf_fill_atomic32(self, BPF_OR);
1851 }
1852 
bpf_fill_atomic32_xor(struct bpf_test * self)1853 static int bpf_fill_atomic32_xor(struct bpf_test *self)
1854 {
1855 	return __bpf_fill_atomic32(self, BPF_XOR);
1856 }
1857 
bpf_fill_atomic32_add_fetch(struct bpf_test * self)1858 static int bpf_fill_atomic32_add_fetch(struct bpf_test *self)
1859 {
1860 	return __bpf_fill_atomic32(self, BPF_ADD | BPF_FETCH);
1861 }
1862 
bpf_fill_atomic32_and_fetch(struct bpf_test * self)1863 static int bpf_fill_atomic32_and_fetch(struct bpf_test *self)
1864 {
1865 	return __bpf_fill_atomic32(self, BPF_AND | BPF_FETCH);
1866 }
1867 
bpf_fill_atomic32_or_fetch(struct bpf_test * self)1868 static int bpf_fill_atomic32_or_fetch(struct bpf_test *self)
1869 {
1870 	return __bpf_fill_atomic32(self, BPF_OR | BPF_FETCH);
1871 }
1872 
bpf_fill_atomic32_xor_fetch(struct bpf_test * self)1873 static int bpf_fill_atomic32_xor_fetch(struct bpf_test *self)
1874 {
1875 	return __bpf_fill_atomic32(self, BPF_XOR | BPF_FETCH);
1876 }
1877 
bpf_fill_atomic32_xchg(struct bpf_test * self)1878 static int bpf_fill_atomic32_xchg(struct bpf_test *self)
1879 {
1880 	return __bpf_fill_atomic32(self, BPF_XCHG);
1881 }
1882 
bpf_fill_cmpxchg32(struct bpf_test * self)1883 static int bpf_fill_cmpxchg32(struct bpf_test *self)
1884 {
1885 	return __bpf_fill_pattern(self, NULL, 64, 64, 0, PATTERN_BLOCK2,
1886 				  &__bpf_emit_cmpxchg32);
1887 }
1888 
1889 /*
1890  * Test JITs that implement ATOMIC operations as function calls or
1891  * other primitives, and must re-arrange operands for argument passing.
1892  */
__bpf_fill_atomic_reg_pairs(struct bpf_test * self,u8 width,u8 op)1893 static int __bpf_fill_atomic_reg_pairs(struct bpf_test *self, u8 width, u8 op)
1894 {
1895 	struct bpf_insn *insn;
1896 	int len = 2 + 34 * 10 * 10;
1897 	u64 mem, upd, res;
1898 	int rd, rs, i = 0;
1899 
1900 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
1901 	if (!insn)
1902 		return -ENOMEM;
1903 
1904 	/* Operand and memory values */
1905 	if (width == BPF_DW) {
1906 		mem = 0x0123456789abcdefULL;
1907 		upd = 0xfedcba9876543210ULL;
1908 	} else { /* BPF_W */
1909 		mem = 0x01234567U;
1910 		upd = 0x76543210U;
1911 	}
1912 
1913 	/* Memory updated according to operation */
1914 	switch (op) {
1915 	case BPF_XCHG:
1916 		res = upd;
1917 		break;
1918 	case BPF_CMPXCHG:
1919 		res = mem;
1920 		break;
1921 	default:
1922 		__bpf_alu_result(&res, mem, upd, BPF_OP(op));
1923 	}
1924 
1925 	/* Test all operand registers */
1926 	for (rd = R0; rd <= R9; rd++) {
1927 		for (rs = R0; rs <= R9; rs++) {
1928 			u64 cmp, src;
1929 
1930 			/* Initialize value in memory */
1931 			i += __bpf_ld_imm64(&insn[i], R0, mem);
1932 			insn[i++] = BPF_STX_MEM(width, R10, R0, -8);
1933 
1934 			/* Initialize registers in order */
1935 			i += __bpf_ld_imm64(&insn[i], R0, ~mem);
1936 			i += __bpf_ld_imm64(&insn[i], rs, upd);
1937 			insn[i++] = BPF_MOV64_REG(rd, R10);
1938 
1939 			/* Perform atomic operation */
1940 			insn[i++] = BPF_ATOMIC_OP(width, op, rd, rs, -8);
1941 			if (op == BPF_CMPXCHG && width == BPF_W)
1942 				insn[i++] = BPF_ZEXT_REG(R0);
1943 
1944 			/* Check R0 register value */
1945 			if (op == BPF_CMPXCHG)
1946 				cmp = mem;  /* Expect value from memory */
1947 			else if (R0 == rd || R0 == rs)
1948 				cmp = 0;    /* Aliased, checked below */
1949 			else
1950 				cmp = ~mem; /* Expect value to be preserved */
1951 			if (cmp) {
1952 				insn[i++] = BPF_JMP32_IMM(BPF_JEQ, R0,
1953 							   (u32)cmp, 2);
1954 				insn[i++] = BPF_MOV32_IMM(R0, __LINE__);
1955 				insn[i++] = BPF_EXIT_INSN();
1956 				insn[i++] = BPF_ALU64_IMM(BPF_RSH, R0, 32);
1957 				insn[i++] = BPF_JMP32_IMM(BPF_JEQ, R0,
1958 							   cmp >> 32, 2);
1959 				insn[i++] = BPF_MOV32_IMM(R0, __LINE__);
1960 				insn[i++] = BPF_EXIT_INSN();
1961 			}
1962 
1963 			/* Check source register value */
1964 			if (rs == R0 && op == BPF_CMPXCHG)
1965 				src = 0;   /* Aliased with R0, checked above */
1966 			else if (rs == rd && (op == BPF_CMPXCHG ||
1967 					      !(op & BPF_FETCH)))
1968 				src = 0;   /* Aliased with rd, checked below */
1969 			else if (op == BPF_CMPXCHG)
1970 				src = upd; /* Expect value to be preserved */
1971 			else if (op & BPF_FETCH)
1972 				src = mem; /* Expect fetched value from mem */
1973 			else /* no fetch */
1974 				src = upd; /* Expect value to be preserved */
1975 			if (src) {
1976 				insn[i++] = BPF_JMP32_IMM(BPF_JEQ, rs,
1977 							   (u32)src, 2);
1978 				insn[i++] = BPF_MOV32_IMM(R0, __LINE__);
1979 				insn[i++] = BPF_EXIT_INSN();
1980 				insn[i++] = BPF_ALU64_IMM(BPF_RSH, rs, 32);
1981 				insn[i++] = BPF_JMP32_IMM(BPF_JEQ, rs,
1982 							   src >> 32, 2);
1983 				insn[i++] = BPF_MOV32_IMM(R0, __LINE__);
1984 				insn[i++] = BPF_EXIT_INSN();
1985 			}
1986 
1987 			/* Check destination register value */
1988 			if (!(rd == R0 && op == BPF_CMPXCHG) &&
1989 			    !(rd == rs && (op & BPF_FETCH))) {
1990 				insn[i++] = BPF_JMP_REG(BPF_JEQ, rd, R10, 2);
1991 				insn[i++] = BPF_MOV32_IMM(R0, __LINE__);
1992 				insn[i++] = BPF_EXIT_INSN();
1993 			}
1994 
1995 			/* Check value in memory */
1996 			if (rs != rd) {                  /* No aliasing */
1997 				i += __bpf_ld_imm64(&insn[i], R1, res);
1998 			} else if (op == BPF_XCHG) {     /* Aliased, XCHG */
1999 				insn[i++] = BPF_MOV64_REG(R1, R10);
2000 			} else if (op == BPF_CMPXCHG) {  /* Aliased, CMPXCHG */
2001 				i += __bpf_ld_imm64(&insn[i], R1, mem);
2002 			} else {                        /* Aliased, ALU oper */
2003 				i += __bpf_ld_imm64(&insn[i], R1, mem);
2004 				insn[i++] = BPF_ALU64_REG(BPF_OP(op), R1, R10);
2005 			}
2006 
2007 			insn[i++] = BPF_LDX_MEM(width, R0, R10, -8);
2008 			if (width == BPF_DW)
2009 				insn[i++] = BPF_JMP_REG(BPF_JEQ, R0, R1, 2);
2010 			else /* width == BPF_W */
2011 				insn[i++] = BPF_JMP32_REG(BPF_JEQ, R0, R1, 2);
2012 			insn[i++] = BPF_MOV32_IMM(R0, __LINE__);
2013 			insn[i++] = BPF_EXIT_INSN();
2014 		}
2015 	}
2016 
2017 	insn[i++] = BPF_MOV64_IMM(R0, 1);
2018 	insn[i++] = BPF_EXIT_INSN();
2019 
2020 	self->u.ptr.insns = insn;
2021 	self->u.ptr.len = i;
2022 	BUG_ON(i > len);
2023 
2024 	return 0;
2025 }
2026 
2027 /* 64-bit atomic register tests */
bpf_fill_atomic64_add_reg_pairs(struct bpf_test * self)2028 static int bpf_fill_atomic64_add_reg_pairs(struct bpf_test *self)
2029 {
2030 	return __bpf_fill_atomic_reg_pairs(self, BPF_DW, BPF_ADD);
2031 }
2032 
bpf_fill_atomic64_and_reg_pairs(struct bpf_test * self)2033 static int bpf_fill_atomic64_and_reg_pairs(struct bpf_test *self)
2034 {
2035 	return __bpf_fill_atomic_reg_pairs(self, BPF_DW, BPF_AND);
2036 }
2037 
bpf_fill_atomic64_or_reg_pairs(struct bpf_test * self)2038 static int bpf_fill_atomic64_or_reg_pairs(struct bpf_test *self)
2039 {
2040 	return __bpf_fill_atomic_reg_pairs(self, BPF_DW, BPF_OR);
2041 }
2042 
bpf_fill_atomic64_xor_reg_pairs(struct bpf_test * self)2043 static int bpf_fill_atomic64_xor_reg_pairs(struct bpf_test *self)
2044 {
2045 	return __bpf_fill_atomic_reg_pairs(self, BPF_DW, BPF_XOR);
2046 }
2047 
bpf_fill_atomic64_add_fetch_reg_pairs(struct bpf_test * self)2048 static int bpf_fill_atomic64_add_fetch_reg_pairs(struct bpf_test *self)
2049 {
2050 	return __bpf_fill_atomic_reg_pairs(self, BPF_DW, BPF_ADD | BPF_FETCH);
2051 }
2052 
bpf_fill_atomic64_and_fetch_reg_pairs(struct bpf_test * self)2053 static int bpf_fill_atomic64_and_fetch_reg_pairs(struct bpf_test *self)
2054 {
2055 	return __bpf_fill_atomic_reg_pairs(self, BPF_DW, BPF_AND | BPF_FETCH);
2056 }
2057 
bpf_fill_atomic64_or_fetch_reg_pairs(struct bpf_test * self)2058 static int bpf_fill_atomic64_or_fetch_reg_pairs(struct bpf_test *self)
2059 {
2060 	return __bpf_fill_atomic_reg_pairs(self, BPF_DW, BPF_OR | BPF_FETCH);
2061 }
2062 
bpf_fill_atomic64_xor_fetch_reg_pairs(struct bpf_test * self)2063 static int bpf_fill_atomic64_xor_fetch_reg_pairs(struct bpf_test *self)
2064 {
2065 	return __bpf_fill_atomic_reg_pairs(self, BPF_DW, BPF_XOR | BPF_FETCH);
2066 }
2067 
bpf_fill_atomic64_xchg_reg_pairs(struct bpf_test * self)2068 static int bpf_fill_atomic64_xchg_reg_pairs(struct bpf_test *self)
2069 {
2070 	return __bpf_fill_atomic_reg_pairs(self, BPF_DW, BPF_XCHG);
2071 }
2072 
bpf_fill_atomic64_cmpxchg_reg_pairs(struct bpf_test * self)2073 static int bpf_fill_atomic64_cmpxchg_reg_pairs(struct bpf_test *self)
2074 {
2075 	return __bpf_fill_atomic_reg_pairs(self, BPF_DW, BPF_CMPXCHG);
2076 }
2077 
2078 /* 32-bit atomic register tests */
bpf_fill_atomic32_add_reg_pairs(struct bpf_test * self)2079 static int bpf_fill_atomic32_add_reg_pairs(struct bpf_test *self)
2080 {
2081 	return __bpf_fill_atomic_reg_pairs(self, BPF_W, BPF_ADD);
2082 }
2083 
bpf_fill_atomic32_and_reg_pairs(struct bpf_test * self)2084 static int bpf_fill_atomic32_and_reg_pairs(struct bpf_test *self)
2085 {
2086 	return __bpf_fill_atomic_reg_pairs(self, BPF_W, BPF_AND);
2087 }
2088 
bpf_fill_atomic32_or_reg_pairs(struct bpf_test * self)2089 static int bpf_fill_atomic32_or_reg_pairs(struct bpf_test *self)
2090 {
2091 	return __bpf_fill_atomic_reg_pairs(self, BPF_W, BPF_OR);
2092 }
2093 
bpf_fill_atomic32_xor_reg_pairs(struct bpf_test * self)2094 static int bpf_fill_atomic32_xor_reg_pairs(struct bpf_test *self)
2095 {
2096 	return __bpf_fill_atomic_reg_pairs(self, BPF_W, BPF_XOR);
2097 }
2098 
bpf_fill_atomic32_add_fetch_reg_pairs(struct bpf_test * self)2099 static int bpf_fill_atomic32_add_fetch_reg_pairs(struct bpf_test *self)
2100 {
2101 	return __bpf_fill_atomic_reg_pairs(self, BPF_W, BPF_ADD | BPF_FETCH);
2102 }
2103 
bpf_fill_atomic32_and_fetch_reg_pairs(struct bpf_test * self)2104 static int bpf_fill_atomic32_and_fetch_reg_pairs(struct bpf_test *self)
2105 {
2106 	return __bpf_fill_atomic_reg_pairs(self, BPF_W, BPF_AND | BPF_FETCH);
2107 }
2108 
bpf_fill_atomic32_or_fetch_reg_pairs(struct bpf_test * self)2109 static int bpf_fill_atomic32_or_fetch_reg_pairs(struct bpf_test *self)
2110 {
2111 	return __bpf_fill_atomic_reg_pairs(self, BPF_W, BPF_OR | BPF_FETCH);
2112 }
2113 
bpf_fill_atomic32_xor_fetch_reg_pairs(struct bpf_test * self)2114 static int bpf_fill_atomic32_xor_fetch_reg_pairs(struct bpf_test *self)
2115 {
2116 	return __bpf_fill_atomic_reg_pairs(self, BPF_W, BPF_XOR | BPF_FETCH);
2117 }
2118 
bpf_fill_atomic32_xchg_reg_pairs(struct bpf_test * self)2119 static int bpf_fill_atomic32_xchg_reg_pairs(struct bpf_test *self)
2120 {
2121 	return __bpf_fill_atomic_reg_pairs(self, BPF_W, BPF_XCHG);
2122 }
2123 
bpf_fill_atomic32_cmpxchg_reg_pairs(struct bpf_test * self)2124 static int bpf_fill_atomic32_cmpxchg_reg_pairs(struct bpf_test *self)
2125 {
2126 	return __bpf_fill_atomic_reg_pairs(self, BPF_W, BPF_CMPXCHG);
2127 }
2128 
2129 /*
2130  * Test the two-instruction 64-bit immediate load operation for all
2131  * power-of-two magnitudes of the immediate operand. For each MSB, a block
2132  * of immediate values centered around the power-of-two MSB are tested,
2133  * both for positive and negative values. The test is designed to verify
2134  * the operation for JITs that emit different code depending on the magnitude
2135  * of the immediate value. This is often the case if the native instruction
2136  * immediate field width is narrower than 32 bits.
2137  */
bpf_fill_ld_imm64_magn(struct bpf_test * self)2138 static int bpf_fill_ld_imm64_magn(struct bpf_test *self)
2139 {
2140 	int block = 64; /* Increase for more tests per MSB position */
2141 	int len = 3 + 8 * 63 * block * 2;
2142 	struct bpf_insn *insn;
2143 	int bit, adj, sign;
2144 	int i = 0;
2145 
2146 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
2147 	if (!insn)
2148 		return -ENOMEM;
2149 
2150 	insn[i++] = BPF_ALU64_IMM(BPF_MOV, R0, 0);
2151 
2152 	for (bit = 0; bit <= 62; bit++) {
2153 		for (adj = -block / 2; adj < block / 2; adj++) {
2154 			for (sign = -1; sign <= 1; sign += 2) {
2155 				s64 imm = sign * ((1LL << bit) + adj);
2156 
2157 				/* Perform operation */
2158 				i += __bpf_ld_imm64(&insn[i], R1, imm);
2159 
2160 				/* Load reference */
2161 				insn[i++] = BPF_ALU32_IMM(BPF_MOV, R2, imm);
2162 				insn[i++] = BPF_ALU32_IMM(BPF_MOV, R3,
2163 							  (u32)(imm >> 32));
2164 				insn[i++] = BPF_ALU64_IMM(BPF_LSH, R3, 32);
2165 				insn[i++] = BPF_ALU64_REG(BPF_OR, R2, R3);
2166 
2167 				/* Check result */
2168 				insn[i++] = BPF_JMP_REG(BPF_JEQ, R1, R2, 1);
2169 				insn[i++] = BPF_EXIT_INSN();
2170 			}
2171 		}
2172 	}
2173 
2174 	insn[i++] = BPF_ALU64_IMM(BPF_MOV, R0, 1);
2175 	insn[i++] = BPF_EXIT_INSN();
2176 
2177 	self->u.ptr.insns = insn;
2178 	self->u.ptr.len = len;
2179 	BUG_ON(i != len);
2180 
2181 	return 0;
2182 }
2183 
2184 /*
2185  * Test the two-instruction 64-bit immediate load operation for different
2186  * combinations of bytes. Each byte in the 64-bit word is constructed as
2187  * (base & mask) | (rand() & ~mask), where rand() is a deterministic LCG.
2188  * All patterns (base1, mask1) and (base2, mask2) bytes are tested.
2189  */
__bpf_fill_ld_imm64_bytes(struct bpf_test * self,u8 base1,u8 mask1,u8 base2,u8 mask2)2190 static int __bpf_fill_ld_imm64_bytes(struct bpf_test *self,
2191 				     u8 base1, u8 mask1,
2192 				     u8 base2, u8 mask2)
2193 {
2194 	struct bpf_insn *insn;
2195 	int len = 3 + 8 * BIT(8);
2196 	int pattern, index;
2197 	u32 rand = 1;
2198 	int i = 0;
2199 
2200 	insn = kmalloc_array(len, sizeof(*insn), GFP_KERNEL);
2201 	if (!insn)
2202 		return -ENOMEM;
2203 
2204 	insn[i++] = BPF_ALU64_IMM(BPF_MOV, R0, 0);
2205 
2206 	for (pattern = 0; pattern < BIT(8); pattern++) {
2207 		u64 imm = 0;
2208 
2209 		for (index = 0; index < 8; index++) {
2210 			int byte;
2211 
2212 			if (pattern & BIT(index))
2213 				byte = (base1 & mask1) | (rand & ~mask1);
2214 			else
2215 				byte = (base2 & mask2) | (rand & ~mask2);
2216 			imm = (imm << 8) | byte;
2217 		}
2218 
2219 		/* Update our LCG */
2220 		rand = rand * 1664525 + 1013904223;
2221 
2222 		/* Perform operation */
2223 		i += __bpf_ld_imm64(&insn[i], R1, imm);
2224 
2225 		/* Load reference */
2226 		insn[i++] = BPF_ALU32_IMM(BPF_MOV, R2, imm);
2227 		insn[i++] = BPF_ALU32_IMM(BPF_MOV, R3, (u32)(imm >> 32));
2228 		insn[i++] = BPF_ALU64_IMM(BPF_LSH, R3, 32);
2229 		insn[i++] = BPF_ALU64_REG(BPF_OR, R2, R3);
2230 
2231 		/* Check result */
2232 		insn[i++] = BPF_JMP_REG(BPF_JEQ, R1, R2, 1);
2233 		insn[i++] = BPF_EXIT_INSN();
2234 	}
2235 
2236 	insn[i++] = BPF_ALU64_IMM(BPF_MOV, R0, 1);
2237 	insn[i++] = BPF_EXIT_INSN();
2238 
2239 	self->u.ptr.insns = insn;
2240 	self->u.ptr.len = len;
2241 	BUG_ON(i != len);
2242 
2243 	return 0;
2244 }
2245 
bpf_fill_ld_imm64_checker(struct bpf_test * self)2246 static int bpf_fill_ld_imm64_checker(struct bpf_test *self)
2247 {
2248 	return __bpf_fill_ld_imm64_bytes(self, 0, 0xff, 0xff, 0xff);
2249 }
2250 
bpf_fill_ld_imm64_pos_neg(struct bpf_test * self)2251 static int bpf_fill_ld_imm64_pos_neg(struct bpf_test *self)
2252 {
2253 	return __bpf_fill_ld_imm64_bytes(self, 1, 0x81, 0x80, 0x80);
2254 }
2255 
bpf_fill_ld_imm64_pos_zero(struct bpf_test * self)2256 static int bpf_fill_ld_imm64_pos_zero(struct bpf_test *self)
2257 {
2258 	return __bpf_fill_ld_imm64_bytes(self, 1, 0x81, 0, 0xff);
2259 }
2260 
bpf_fill_ld_imm64_neg_zero(struct bpf_test * self)2261 static int bpf_fill_ld_imm64_neg_zero(struct bpf_test *self)
2262 {
2263 	return __bpf_fill_ld_imm64_bytes(self, 0x80, 0x80, 0, 0xff);
2264 }
2265 
2266 /*
2267  * Exhaustive tests of JMP operations for all combinations of power-of-two
2268  * magnitudes of the operands, both for positive and negative values. The
2269  * test is designed to verify e.g. the JMP and JMP32 operations for JITs that
2270  * emit different code depending on the magnitude of the immediate value.
2271  */
2272 
__bpf_match_jmp_cond(s64 v1,s64 v2,u8 op)2273 static bool __bpf_match_jmp_cond(s64 v1, s64 v2, u8 op)
2274 {
2275 	switch (op) {
2276 	case BPF_JSET:
2277 		return !!(v1 & v2);
2278 	case BPF_JEQ:
2279 		return v1 == v2;
2280 	case BPF_JNE:
2281 		return v1 != v2;
2282 	case BPF_JGT:
2283 		return (u64)v1 > (u64)v2;
2284 	case BPF_JGE:
2285 		return (u64)v1 >= (u64)v2;
2286 	case BPF_JLT:
2287 		return (u64)v1 < (u64)v2;
2288 	case BPF_JLE:
2289 		return (u64)v1 <= (u64)v2;
2290 	case BPF_JSGT:
2291 		return v1 > v2;
2292 	case BPF_JSGE:
2293 		return v1 >= v2;
2294 	case BPF_JSLT:
2295 		return v1 < v2;
2296 	case BPF_JSLE:
2297 		return v1 <= v2;
2298 	}
2299 	return false;
2300 }
2301 
__bpf_emit_jmp_imm(struct bpf_test * self,void * arg,struct bpf_insn * insns,s64 dst,s64 imm)2302 static int __bpf_emit_jmp_imm(struct bpf_test *self, void *arg,
2303 			      struct bpf_insn *insns, s64 dst, s64 imm)
2304 {
2305 	int op = *(int *)arg;
2306 
2307 	if (insns) {
2308 		bool match = __bpf_match_jmp_cond(dst, (s32)imm, op);
2309 		int i = 0;
2310 
2311 		insns[i++] = BPF_ALU32_IMM(BPF_MOV, R0, match);
2312 
2313 		i += __bpf_ld_imm64(&insns[i], R1, dst);
2314 		insns[i++] = BPF_JMP_IMM(op, R1, imm, 1);
2315 		if (!match)
2316 			insns[i++] = BPF_JMP_IMM(BPF_JA, 0, 0, 1);
2317 		insns[i++] = BPF_EXIT_INSN();
2318 
2319 		return i;
2320 	}
2321 
2322 	return 5 + 1;
2323 }
2324 
__bpf_emit_jmp32_imm(struct bpf_test * self,void * arg,struct bpf_insn * insns,s64 dst,s64 imm)2325 static int __bpf_emit_jmp32_imm(struct bpf_test *self, void *arg,
2326 				struct bpf_insn *insns, s64 dst, s64 imm)
2327 {
2328 	int op = *(int *)arg;
2329 
2330 	if (insns) {
2331 		bool match = __bpf_match_jmp_cond((s32)dst, (s32)imm, op);
2332 		int i = 0;
2333 
2334 		i += __bpf_ld_imm64(&insns[i], R1, dst);
2335 		insns[i++] = BPF_JMP32_IMM(op, R1, imm, 1);
2336 		if (!match)
2337 			insns[i++] = BPF_JMP_IMM(BPF_JA, 0, 0, 1);
2338 		insns[i++] = BPF_EXIT_INSN();
2339 
2340 		return i;
2341 	}
2342 
2343 	return 5;
2344 }
2345 
__bpf_emit_jmp_reg(struct bpf_test * self,void * arg,struct bpf_insn * insns,s64 dst,s64 src)2346 static int __bpf_emit_jmp_reg(struct bpf_test *self, void *arg,
2347 			      struct bpf_insn *insns, s64 dst, s64 src)
2348 {
2349 	int op = *(int *)arg;
2350 
2351 	if (insns) {
2352 		bool match = __bpf_match_jmp_cond(dst, src, op);
2353 		int i = 0;
2354 
2355 		i += __bpf_ld_imm64(&insns[i], R1, dst);
2356 		i += __bpf_ld_imm64(&insns[i], R2, src);
2357 		insns[i++] = BPF_JMP_REG(op, R1, R2, 1);
2358 		if (!match)
2359 			insns[i++] = BPF_JMP_IMM(BPF_JA, 0, 0, 1);
2360 		insns[i++] = BPF_EXIT_INSN();
2361 
2362 		return i;
2363 	}
2364 
2365 	return 7;
2366 }
2367 
__bpf_emit_jmp32_reg(struct bpf_test * self,void * arg,struct bpf_insn * insns,s64 dst,s64 src)2368 static int __bpf_emit_jmp32_reg(struct bpf_test *self, void *arg,
2369 				struct bpf_insn *insns, s64 dst, s64 src)
2370 {
2371 	int op = *(int *)arg;
2372 
2373 	if (insns) {
2374 		bool match = __bpf_match_jmp_cond((s32)dst, (s32)src, op);
2375 		int i = 0;
2376 
2377 		i += __bpf_ld_imm64(&insns[i], R1, dst);
2378 		i += __bpf_ld_imm64(&insns[i], R2, src);
2379 		insns[i++] = BPF_JMP32_REG(op, R1, R2, 1);
2380 		if (!match)
2381 			insns[i++] = BPF_JMP_IMM(BPF_JA, 0, 0, 1);
2382 		insns[i++] = BPF_EXIT_INSN();
2383 
2384 		return i;
2385 	}
2386 
2387 	return 7;
2388 }
2389 
__bpf_fill_jmp_imm(struct bpf_test * self,int op)2390 static int __bpf_fill_jmp_imm(struct bpf_test *self, int op)
2391 {
2392 	return __bpf_fill_pattern(self, &op, 64, 32,
2393 				  PATTERN_BLOCK1, PATTERN_BLOCK2,
2394 				  &__bpf_emit_jmp_imm);
2395 }
2396 
__bpf_fill_jmp32_imm(struct bpf_test * self,int op)2397 static int __bpf_fill_jmp32_imm(struct bpf_test *self, int op)
2398 {
2399 	return __bpf_fill_pattern(self, &op, 64, 32,
2400 				  PATTERN_BLOCK1, PATTERN_BLOCK2,
2401 				  &__bpf_emit_jmp32_imm);
2402 }
2403 
__bpf_fill_jmp_reg(struct bpf_test * self,int op)2404 static int __bpf_fill_jmp_reg(struct bpf_test *self, int op)
2405 {
2406 	return __bpf_fill_pattern(self, &op, 64, 64,
2407 				  PATTERN_BLOCK1, PATTERN_BLOCK2,
2408 				  &__bpf_emit_jmp_reg);
2409 }
2410 
__bpf_fill_jmp32_reg(struct bpf_test * self,int op)2411 static int __bpf_fill_jmp32_reg(struct bpf_test *self, int op)
2412 {
2413 	return __bpf_fill_pattern(self, &op, 64, 64,
2414 				  PATTERN_BLOCK1, PATTERN_BLOCK2,
2415 				  &__bpf_emit_jmp32_reg);
2416 }
2417 
2418 /* JMP immediate tests */
bpf_fill_jmp_jset_imm(struct bpf_test * self)2419 static int bpf_fill_jmp_jset_imm(struct bpf_test *self)
2420 {
2421 	return __bpf_fill_jmp_imm(self, BPF_JSET);
2422 }
2423 
bpf_fill_jmp_jeq_imm(struct bpf_test * self)2424 static int bpf_fill_jmp_jeq_imm(struct bpf_test *self)
2425 {
2426 	return __bpf_fill_jmp_imm(self, BPF_JEQ);
2427 }
2428 
bpf_fill_jmp_jne_imm(struct bpf_test * self)2429 static int bpf_fill_jmp_jne_imm(struct bpf_test *self)
2430 {
2431 	return __bpf_fill_jmp_imm(self, BPF_JNE);
2432 }
2433 
bpf_fill_jmp_jgt_imm(struct bpf_test * self)2434 static int bpf_fill_jmp_jgt_imm(struct bpf_test *self)
2435 {
2436 	return __bpf_fill_jmp_imm(self, BPF_JGT);
2437 }
2438 
bpf_fill_jmp_jge_imm(struct bpf_test * self)2439 static int bpf_fill_jmp_jge_imm(struct bpf_test *self)
2440 {
2441 	return __bpf_fill_jmp_imm(self, BPF_JGE);
2442 }
2443 
bpf_fill_jmp_jlt_imm(struct bpf_test * self)2444 static int bpf_fill_jmp_jlt_imm(struct bpf_test *self)
2445 {
2446 	return __bpf_fill_jmp_imm(self, BPF_JLT);
2447 }
2448 
bpf_fill_jmp_jle_imm(struct bpf_test * self)2449 static int bpf_fill_jmp_jle_imm(struct bpf_test *self)
2450 {
2451 	return __bpf_fill_jmp_imm(self, BPF_JLE);
2452 }
2453 
bpf_fill_jmp_jsgt_imm(struct bpf_test * self)2454 static int bpf_fill_jmp_jsgt_imm(struct bpf_test *self)
2455 {
2456 	return __bpf_fill_jmp_imm(self, BPF_JSGT);
2457 }
2458 
bpf_fill_jmp_jsge_imm(struct bpf_test * self)2459 static int bpf_fill_jmp_jsge_imm(struct bpf_test *self)
2460 {
2461 	return __bpf_fill_jmp_imm(self, BPF_JSGE);
2462 }
2463 
bpf_fill_jmp_jslt_imm(struct bpf_test * self)2464 static int bpf_fill_jmp_jslt_imm(struct bpf_test *self)
2465 {
2466 	return __bpf_fill_jmp_imm(self, BPF_JSLT);
2467 }
2468 
bpf_fill_jmp_jsle_imm(struct bpf_test * self)2469 static int bpf_fill_jmp_jsle_imm(struct bpf_test *self)
2470 {
2471 	return __bpf_fill_jmp_imm(self, BPF_JSLE);
2472 }
2473 
2474 /* JMP32 immediate tests */
bpf_fill_jmp32_jset_imm(struct bpf_test * self)2475 static int bpf_fill_jmp32_jset_imm(struct bpf_test *self)
2476 {
2477 	return __bpf_fill_jmp32_imm(self, BPF_JSET);
2478 }
2479 
bpf_fill_jmp32_jeq_imm(struct bpf_test * self)2480 static int bpf_fill_jmp32_jeq_imm(struct bpf_test *self)
2481 {
2482 	return __bpf_fill_jmp32_imm(self, BPF_JEQ);
2483 }
2484 
bpf_fill_jmp32_jne_imm(struct bpf_test * self)2485 static int bpf_fill_jmp32_jne_imm(struct bpf_test *self)
2486 {
2487 	return __bpf_fill_jmp32_imm(self, BPF_JNE);
2488 }
2489 
bpf_fill_jmp32_jgt_imm(struct bpf_test * self)2490 static int bpf_fill_jmp32_jgt_imm(struct bpf_test *self)
2491 {
2492 	return __bpf_fill_jmp32_imm(self, BPF_JGT);
2493 }
2494 
bpf_fill_jmp32_jge_imm(struct bpf_test * self)2495 static int bpf_fill_jmp32_jge_imm(struct bpf_test *self)
2496 {
2497 	return __bpf_fill_jmp32_imm(self, BPF_JGE);
2498 }
2499 
bpf_fill_jmp32_jlt_imm(struct bpf_test * self)2500 static int bpf_fill_jmp32_jlt_imm(struct bpf_test *self)
2501 {
2502 	return __bpf_fill_jmp32_imm(self, BPF_JLT);
2503 }
2504 
bpf_fill_jmp32_jle_imm(struct bpf_test * self)2505 static int bpf_fill_jmp32_jle_imm(struct bpf_test *self)
2506 {
2507 	return __bpf_fill_jmp32_imm(self, BPF_JLE);
2508 }
2509 
bpf_fill_jmp32_jsgt_imm(struct bpf_test * self)2510 static int bpf_fill_jmp32_jsgt_imm(struct bpf_test *self)
2511 {
2512 	return __bpf_fill_jmp32_imm(self, BPF_JSGT);
2513 }
2514 
bpf_fill_jmp32_jsge_imm(struct bpf_test * self)2515 static int bpf_fill_jmp32_jsge_imm(struct bpf_test *self)
2516 {
2517 	return __bpf_fill_jmp32_imm(self, BPF_JSGE);
2518 }
2519 
bpf_fill_jmp32_jslt_imm(struct bpf_test * self)2520 static int bpf_fill_jmp32_jslt_imm(struct bpf_test *self)
2521 {
2522 	return __bpf_fill_jmp32_imm(self, BPF_JSLT);
2523 }
2524 
bpf_fill_jmp32_jsle_imm(struct bpf_test * self)2525 static int bpf_fill_jmp32_jsle_imm(struct bpf_test *self)
2526 {
2527 	return __bpf_fill_jmp32_imm(self, BPF_JSLE);
2528 }
2529 
2530 /* JMP register tests */
bpf_fill_jmp_jset_reg(struct bpf_test * self)2531 static int bpf_fill_jmp_jset_reg(struct bpf_test *self)
2532 {
2533 	return __bpf_fill_jmp_reg(self, BPF_JSET);
2534 }
2535 
bpf_fill_jmp_jeq_reg(struct bpf_test * self)2536 static int bpf_fill_jmp_jeq_reg(struct bpf_test *self)
2537 {
2538 	return __bpf_fill_jmp_reg(self, BPF_JEQ);
2539 }
2540 
bpf_fill_jmp_jne_reg(struct bpf_test * self)2541 static int bpf_fill_jmp_jne_reg(struct bpf_test *self)
2542 {
2543 	return __bpf_fill_jmp_reg(self, BPF_JNE);
2544 }
2545 
bpf_fill_jmp_jgt_reg(struct bpf_test * self)2546 static int bpf_fill_jmp_jgt_reg(struct bpf_test *self)
2547 {
2548 	return __bpf_fill_jmp_reg(self, BPF_JGT);
2549 }
2550 
bpf_fill_jmp_jge_reg(struct bpf_test * self)2551 static int bpf_fill_jmp_jge_reg(struct bpf_test *self)
2552 {
2553 	return __bpf_fill_jmp_reg(self, BPF_JGE);
2554 }
2555 
bpf_fill_jmp_jlt_reg(struct bpf_test * self)2556 static int bpf_fill_jmp_jlt_reg(struct bpf_test *self)
2557 {
2558 	return __bpf_fill_jmp_reg(self, BPF_JLT);
2559 }
2560 
bpf_fill_jmp_jle_reg(struct bpf_test * self)2561 static int bpf_fill_jmp_jle_reg(struct bpf_test *self)
2562 {
2563 	return __bpf_fill_jmp_reg(self, BPF_JLE);
2564 }
2565 
bpf_fill_jmp_jsgt_reg(struct bpf_test * self)2566 static int bpf_fill_jmp_jsgt_reg(struct bpf_test *self)
2567 {
2568 	return __bpf_fill_jmp_reg(self, BPF_JSGT);
2569 }
2570 
bpf_fill_jmp_jsge_reg(struct bpf_test * self)2571 static int bpf_fill_jmp_jsge_reg(struct bpf_test *self)
2572 {
2573 	return __bpf_fill_jmp_reg(self, BPF_JSGE);
2574 }
2575 
bpf_fill_jmp_jslt_reg(struct bpf_test * self)2576 static int bpf_fill_jmp_jslt_reg(struct bpf_test *self)
2577 {
2578 	return __bpf_fill_jmp_reg(self, BPF_JSLT);
2579 }
2580 
bpf_fill_jmp_jsle_reg(struct bpf_test * self)2581 static int bpf_fill_jmp_jsle_reg(struct bpf_test *self)
2582 {
2583 	return __bpf_fill_jmp_reg(self, BPF_JSLE);
2584 }
2585 
2586 /* JMP32 register tests */
bpf_fill_jmp32_jset_reg(struct bpf_test * self)2587 static int bpf_fill_jmp32_jset_reg(struct bpf_test *self)
2588 {
2589 	return __bpf_fill_jmp32_reg(self, BPF_JSET);
2590 }
2591 
bpf_fill_jmp32_jeq_reg(struct bpf_test * self)2592 static int bpf_fill_jmp32_jeq_reg(struct bpf_test *self)
2593 {
2594 	return __bpf_fill_jmp32_reg(self, BPF_JEQ);
2595 }
2596 
bpf_fill_jmp32_jne_reg(struct bpf_test * self)2597 static int bpf_fill_jmp32_jne_reg(struct bpf_test *self)
2598 {
2599 	return __bpf_fill_jmp32_reg(self, BPF_JNE);
2600 }
2601 
bpf_fill_jmp32_jgt_reg(struct bpf_test * self)2602 static int bpf_fill_jmp32_jgt_reg(struct bpf_test *self)
2603 {
2604 	return __bpf_fill_jmp32_reg(self, BPF_JGT);
2605 }
2606 
bpf_fill_jmp32_jge_reg(struct bpf_test * self)2607 static int bpf_fill_jmp32_jge_reg(struct bpf_test *self)
2608 {
2609 	return __bpf_fill_jmp32_reg(self, BPF_JGE);
2610 }
2611 
bpf_fill_jmp32_jlt_reg(struct bpf_test * self)2612 static int bpf_fill_jmp32_jlt_reg(struct bpf_test *self)
2613 {
2614 	return __bpf_fill_jmp32_reg(self, BPF_JLT);
2615 }
2616 
bpf_fill_jmp32_jle_reg(struct bpf_test * self)2617 static int bpf_fill_jmp32_jle_reg(struct bpf_test *self)
2618 {
2619 	return __bpf_fill_jmp32_reg(self, BPF_JLE);
2620 }
2621 
bpf_fill_jmp32_jsgt_reg(struct bpf_test * self)2622 static int bpf_fill_jmp32_jsgt_reg(struct bpf_test *self)
2623 {
2624 	return __bpf_fill_jmp32_reg(self, BPF_JSGT);
2625 }
2626 
bpf_fill_jmp32_jsge_reg(struct bpf_test * self)2627 static int bpf_fill_jmp32_jsge_reg(struct bpf_test *self)
2628 {
2629 	return __bpf_fill_jmp32_reg(self, BPF_JSGE);
2630 }
2631 
bpf_fill_jmp32_jslt_reg(struct bpf_test * self)2632 static int bpf_fill_jmp32_jslt_reg(struct bpf_test *self)
2633 {
2634 	return __bpf_fill_jmp32_reg(self, BPF_JSLT);
2635 }
2636 
bpf_fill_jmp32_jsle_reg(struct bpf_test * self)2637 static int bpf_fill_jmp32_jsle_reg(struct bpf_test *self)
2638 {
2639 	return __bpf_fill_jmp32_reg(self, BPF_JSLE);
2640 }
2641 
2642 /*
2643  * Set up a sequence of staggered jumps, forwards and backwards with
2644  * increasing offset. This tests the conversion of relative jumps to
2645  * JITed native jumps. On some architectures, for example MIPS, a large
2646  * PC-relative jump offset may overflow the immediate field of the native
2647  * conditional branch instruction, triggering a conversion to use an
2648  * absolute jump instead. Since this changes the jump offsets, another
2649  * offset computation pass is necessary, and that may in turn trigger
2650  * another branch conversion. This jump sequence is particularly nasty
2651  * in that regard.
2652  *
2653  * The sequence generation is parameterized by size and jump type.
2654  * The size must be even, and the expected result is always size + 1.
2655  * Below is an example with size=8 and result=9.
2656  *
2657  *                     ________________________Start
2658  *                     R0 = 0
2659  *                     R1 = r1
2660  *                     R2 = r2
2661  *            ,------- JMP +4 * 3______________Preamble: 4 insns
2662  * ,----------|-ind 0- if R0 != 7 JMP 8 * 3 + 1 <--------------------.
2663  * |          |        R0 = 8                                        |
2664  * |          |        JMP +7 * 3               ------------------------.
2665  * | ,--------|-----1- if R0 != 5 JMP 7 * 3 + 1 <--------------.     |  |
2666  * | |        |        R0 = 6                                  |     |  |
2667  * | |        |        JMP +5 * 3               ------------------.  |  |
2668  * | | ,------|-----2- if R0 != 3 JMP 6 * 3 + 1 <--------.     |  |  |  |
2669  * | | |      |        R0 = 4                            |     |  |  |  |
2670  * | | |      |        JMP +3 * 3               ------------.  |  |  |  |
2671  * | | | ,----|-----3- if R0 != 1 JMP 5 * 3 + 1 <--.     |  |  |  |  |  |
2672  * | | | |    |        R0 = 2                      |     |  |  |  |  |  |
2673  * | | | |    |        JMP +1 * 3               ------.  |  |  |  |  |  |
2674  * | | | | ,--t=====4> if R0 != 0 JMP 4 * 3 + 1    1  2  3  4  5  6  7  8 loc
2675  * | | | | |           R0 = 1                     -1 +2 -3 +4 -5 +6 -7 +8 off
2676  * | | | | |           JMP -2 * 3               ---'  |  |  |  |  |  |  |
2677  * | | | | | ,------5- if R0 != 2 JMP 3 * 3 + 1 <-----'  |  |  |  |  |  |
2678  * | | | | | |         R0 = 3                            |  |  |  |  |  |
2679  * | | | | | |         JMP -4 * 3               ---------'  |  |  |  |  |
2680  * | | | | | | ,----6- if R0 != 4 JMP 2 * 3 + 1 <-----------'  |  |  |  |
2681  * | | | | | | |       R0 = 5                                  |  |  |  |
2682  * | | | | | | |       JMP -6 * 3               ---------------'  |  |  |
2683  * | | | | | | | ,--7- if R0 != 6 JMP 1 * 3 + 1 <-----------------'  |  |
2684  * | | | | | | | |     R0 = 7                                        |  |
2685  * | | Error | | |     JMP -8 * 3               ---------------------'  |
2686  * | | paths | | | ,8- if R0 != 8 JMP 0 * 3 + 1 <-----------------------'
2687  * | | | | | | | | |   R0 = 9__________________Sequence: 3 * size - 1 insns
2688  * `-+-+-+-+-+-+-+-+-> EXIT____________________Return: 1 insn
2689  *
2690  */
2691 
2692 /* The maximum size parameter */
2693 #define MAX_STAGGERED_JMP_SIZE ((0x7fff / 3) & ~1)
2694 
2695 /* We use a reduced number of iterations to get a reasonable execution time */
2696 #define NR_STAGGERED_JMP_RUNS 10
2697 
__bpf_fill_staggered_jumps(struct bpf_test * self,const struct bpf_insn * jmp,u64 r1,u64 r2)2698 static int __bpf_fill_staggered_jumps(struct bpf_test *self,
2699 				      const struct bpf_insn *jmp,
2700 				      u64 r1, u64 r2)
2701 {
2702 	int size = self->test[0].result - 1;
2703 	int len = 4 + 3 * (size + 1);
2704 	struct bpf_insn *insns;
2705 	int off, ind;
2706 
2707 	insns = kmalloc_array(len, sizeof(*insns), GFP_KERNEL);
2708 	if (!insns)
2709 		return -ENOMEM;
2710 
2711 	/* Preamble */
2712 	insns[0] = BPF_ALU64_IMM(BPF_MOV, R0, 0);
2713 	insns[1] = BPF_ALU64_IMM(BPF_MOV, R1, r1);
2714 	insns[2] = BPF_ALU64_IMM(BPF_MOV, R2, r2);
2715 	insns[3] = BPF_JMP_IMM(BPF_JA, 0, 0, 3 * size / 2);
2716 
2717 	/* Sequence */
2718 	for (ind = 0, off = size; ind <= size; ind++, off -= 2) {
2719 		struct bpf_insn *ins = &insns[4 + 3 * ind];
2720 		int loc;
2721 
2722 		if (off == 0)
2723 			off--;
2724 
2725 		loc = abs(off);
2726 		ins[0] = BPF_JMP_IMM(BPF_JNE, R0, loc - 1,
2727 				     3 * (size - ind) + 1);
2728 		ins[1] = BPF_ALU64_IMM(BPF_MOV, R0, loc);
2729 		ins[2] = *jmp;
2730 		ins[2].off = 3 * (off - 1);
2731 	}
2732 
2733 	/* Return */
2734 	insns[len - 1] = BPF_EXIT_INSN();
2735 
2736 	self->u.ptr.insns = insns;
2737 	self->u.ptr.len = len;
2738 
2739 	return 0;
2740 }
2741 
2742 /* 64-bit unconditional jump */
bpf_fill_staggered_ja(struct bpf_test * self)2743 static int bpf_fill_staggered_ja(struct bpf_test *self)
2744 {
2745 	struct bpf_insn jmp = BPF_JMP_IMM(BPF_JA, 0, 0, 0);
2746 
2747 	return __bpf_fill_staggered_jumps(self, &jmp, 0, 0);
2748 }
2749 
2750 /* 64-bit immediate jumps */
bpf_fill_staggered_jeq_imm(struct bpf_test * self)2751 static int bpf_fill_staggered_jeq_imm(struct bpf_test *self)
2752 {
2753 	struct bpf_insn jmp = BPF_JMP_IMM(BPF_JEQ, R1, 1234, 0);
2754 
2755 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 0);
2756 }
2757 
bpf_fill_staggered_jne_imm(struct bpf_test * self)2758 static int bpf_fill_staggered_jne_imm(struct bpf_test *self)
2759 {
2760 	struct bpf_insn jmp = BPF_JMP_IMM(BPF_JNE, R1, 1234, 0);
2761 
2762 	return __bpf_fill_staggered_jumps(self, &jmp, 4321, 0);
2763 }
2764 
bpf_fill_staggered_jset_imm(struct bpf_test * self)2765 static int bpf_fill_staggered_jset_imm(struct bpf_test *self)
2766 {
2767 	struct bpf_insn jmp = BPF_JMP_IMM(BPF_JSET, R1, 0x82, 0);
2768 
2769 	return __bpf_fill_staggered_jumps(self, &jmp, 0x86, 0);
2770 }
2771 
bpf_fill_staggered_jgt_imm(struct bpf_test * self)2772 static int bpf_fill_staggered_jgt_imm(struct bpf_test *self)
2773 {
2774 	struct bpf_insn jmp = BPF_JMP_IMM(BPF_JGT, R1, 1234, 0);
2775 
2776 	return __bpf_fill_staggered_jumps(self, &jmp, 0x80000000, 0);
2777 }
2778 
bpf_fill_staggered_jge_imm(struct bpf_test * self)2779 static int bpf_fill_staggered_jge_imm(struct bpf_test *self)
2780 {
2781 	struct bpf_insn jmp = BPF_JMP_IMM(BPF_JGE, R1, 1234, 0);
2782 
2783 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 0);
2784 }
2785 
bpf_fill_staggered_jlt_imm(struct bpf_test * self)2786 static int bpf_fill_staggered_jlt_imm(struct bpf_test *self)
2787 {
2788 	struct bpf_insn jmp = BPF_JMP_IMM(BPF_JLT, R1, 0x80000000, 0);
2789 
2790 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 0);
2791 }
2792 
bpf_fill_staggered_jle_imm(struct bpf_test * self)2793 static int bpf_fill_staggered_jle_imm(struct bpf_test *self)
2794 {
2795 	struct bpf_insn jmp = BPF_JMP_IMM(BPF_JLE, R1, 1234, 0);
2796 
2797 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 0);
2798 }
2799 
bpf_fill_staggered_jsgt_imm(struct bpf_test * self)2800 static int bpf_fill_staggered_jsgt_imm(struct bpf_test *self)
2801 {
2802 	struct bpf_insn jmp = BPF_JMP_IMM(BPF_JSGT, R1, -2, 0);
2803 
2804 	return __bpf_fill_staggered_jumps(self, &jmp, -1, 0);
2805 }
2806 
bpf_fill_staggered_jsge_imm(struct bpf_test * self)2807 static int bpf_fill_staggered_jsge_imm(struct bpf_test *self)
2808 {
2809 	struct bpf_insn jmp = BPF_JMP_IMM(BPF_JSGE, R1, -2, 0);
2810 
2811 	return __bpf_fill_staggered_jumps(self, &jmp, -2, 0);
2812 }
2813 
bpf_fill_staggered_jslt_imm(struct bpf_test * self)2814 static int bpf_fill_staggered_jslt_imm(struct bpf_test *self)
2815 {
2816 	struct bpf_insn jmp = BPF_JMP_IMM(BPF_JSLT, R1, -1, 0);
2817 
2818 	return __bpf_fill_staggered_jumps(self, &jmp, -2, 0);
2819 }
2820 
bpf_fill_staggered_jsle_imm(struct bpf_test * self)2821 static int bpf_fill_staggered_jsle_imm(struct bpf_test *self)
2822 {
2823 	struct bpf_insn jmp = BPF_JMP_IMM(BPF_JSLE, R1, -1, 0);
2824 
2825 	return __bpf_fill_staggered_jumps(self, &jmp, -1, 0);
2826 }
2827 
2828 /* 64-bit register jumps */
bpf_fill_staggered_jeq_reg(struct bpf_test * self)2829 static int bpf_fill_staggered_jeq_reg(struct bpf_test *self)
2830 {
2831 	struct bpf_insn jmp = BPF_JMP_REG(BPF_JEQ, R1, R2, 0);
2832 
2833 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 1234);
2834 }
2835 
bpf_fill_staggered_jne_reg(struct bpf_test * self)2836 static int bpf_fill_staggered_jne_reg(struct bpf_test *self)
2837 {
2838 	struct bpf_insn jmp = BPF_JMP_REG(BPF_JNE, R1, R2, 0);
2839 
2840 	return __bpf_fill_staggered_jumps(self, &jmp, 4321, 1234);
2841 }
2842 
bpf_fill_staggered_jset_reg(struct bpf_test * self)2843 static int bpf_fill_staggered_jset_reg(struct bpf_test *self)
2844 {
2845 	struct bpf_insn jmp = BPF_JMP_REG(BPF_JSET, R1, R2, 0);
2846 
2847 	return __bpf_fill_staggered_jumps(self, &jmp, 0x86, 0x82);
2848 }
2849 
bpf_fill_staggered_jgt_reg(struct bpf_test * self)2850 static int bpf_fill_staggered_jgt_reg(struct bpf_test *self)
2851 {
2852 	struct bpf_insn jmp = BPF_JMP_REG(BPF_JGT, R1, R2, 0);
2853 
2854 	return __bpf_fill_staggered_jumps(self, &jmp, 0x80000000, 1234);
2855 }
2856 
bpf_fill_staggered_jge_reg(struct bpf_test * self)2857 static int bpf_fill_staggered_jge_reg(struct bpf_test *self)
2858 {
2859 	struct bpf_insn jmp = BPF_JMP_REG(BPF_JGE, R1, R2, 0);
2860 
2861 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 1234);
2862 }
2863 
bpf_fill_staggered_jlt_reg(struct bpf_test * self)2864 static int bpf_fill_staggered_jlt_reg(struct bpf_test *self)
2865 {
2866 	struct bpf_insn jmp = BPF_JMP_REG(BPF_JLT, R1, R2, 0);
2867 
2868 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 0x80000000);
2869 }
2870 
bpf_fill_staggered_jle_reg(struct bpf_test * self)2871 static int bpf_fill_staggered_jle_reg(struct bpf_test *self)
2872 {
2873 	struct bpf_insn jmp = BPF_JMP_REG(BPF_JLE, R1, R2, 0);
2874 
2875 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 1234);
2876 }
2877 
bpf_fill_staggered_jsgt_reg(struct bpf_test * self)2878 static int bpf_fill_staggered_jsgt_reg(struct bpf_test *self)
2879 {
2880 	struct bpf_insn jmp = BPF_JMP_REG(BPF_JSGT, R1, R2, 0);
2881 
2882 	return __bpf_fill_staggered_jumps(self, &jmp, -1, -2);
2883 }
2884 
bpf_fill_staggered_jsge_reg(struct bpf_test * self)2885 static int bpf_fill_staggered_jsge_reg(struct bpf_test *self)
2886 {
2887 	struct bpf_insn jmp = BPF_JMP_REG(BPF_JSGE, R1, R2, 0);
2888 
2889 	return __bpf_fill_staggered_jumps(self, &jmp, -2, -2);
2890 }
2891 
bpf_fill_staggered_jslt_reg(struct bpf_test * self)2892 static int bpf_fill_staggered_jslt_reg(struct bpf_test *self)
2893 {
2894 	struct bpf_insn jmp = BPF_JMP_REG(BPF_JSLT, R1, R2, 0);
2895 
2896 	return __bpf_fill_staggered_jumps(self, &jmp, -2, -1);
2897 }
2898 
bpf_fill_staggered_jsle_reg(struct bpf_test * self)2899 static int bpf_fill_staggered_jsle_reg(struct bpf_test *self)
2900 {
2901 	struct bpf_insn jmp = BPF_JMP_REG(BPF_JSLE, R1, R2, 0);
2902 
2903 	return __bpf_fill_staggered_jumps(self, &jmp, -1, -1);
2904 }
2905 
2906 /* 32-bit immediate jumps */
bpf_fill_staggered_jeq32_imm(struct bpf_test * self)2907 static int bpf_fill_staggered_jeq32_imm(struct bpf_test *self)
2908 {
2909 	struct bpf_insn jmp = BPF_JMP32_IMM(BPF_JEQ, R1, 1234, 0);
2910 
2911 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 0);
2912 }
2913 
bpf_fill_staggered_jne32_imm(struct bpf_test * self)2914 static int bpf_fill_staggered_jne32_imm(struct bpf_test *self)
2915 {
2916 	struct bpf_insn jmp = BPF_JMP32_IMM(BPF_JNE, R1, 1234, 0);
2917 
2918 	return __bpf_fill_staggered_jumps(self, &jmp, 4321, 0);
2919 }
2920 
bpf_fill_staggered_jset32_imm(struct bpf_test * self)2921 static int bpf_fill_staggered_jset32_imm(struct bpf_test *self)
2922 {
2923 	struct bpf_insn jmp = BPF_JMP32_IMM(BPF_JSET, R1, 0x82, 0);
2924 
2925 	return __bpf_fill_staggered_jumps(self, &jmp, 0x86, 0);
2926 }
2927 
bpf_fill_staggered_jgt32_imm(struct bpf_test * self)2928 static int bpf_fill_staggered_jgt32_imm(struct bpf_test *self)
2929 {
2930 	struct bpf_insn jmp = BPF_JMP32_IMM(BPF_JGT, R1, 1234, 0);
2931 
2932 	return __bpf_fill_staggered_jumps(self, &jmp, 0x80000000, 0);
2933 }
2934 
bpf_fill_staggered_jge32_imm(struct bpf_test * self)2935 static int bpf_fill_staggered_jge32_imm(struct bpf_test *self)
2936 {
2937 	struct bpf_insn jmp = BPF_JMP32_IMM(BPF_JGE, R1, 1234, 0);
2938 
2939 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 0);
2940 }
2941 
bpf_fill_staggered_jlt32_imm(struct bpf_test * self)2942 static int bpf_fill_staggered_jlt32_imm(struct bpf_test *self)
2943 {
2944 	struct bpf_insn jmp = BPF_JMP32_IMM(BPF_JLT, R1, 0x80000000, 0);
2945 
2946 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 0);
2947 }
2948 
bpf_fill_staggered_jle32_imm(struct bpf_test * self)2949 static int bpf_fill_staggered_jle32_imm(struct bpf_test *self)
2950 {
2951 	struct bpf_insn jmp = BPF_JMP32_IMM(BPF_JLE, R1, 1234, 0);
2952 
2953 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 0);
2954 }
2955 
bpf_fill_staggered_jsgt32_imm(struct bpf_test * self)2956 static int bpf_fill_staggered_jsgt32_imm(struct bpf_test *self)
2957 {
2958 	struct bpf_insn jmp = BPF_JMP32_IMM(BPF_JSGT, R1, -2, 0);
2959 
2960 	return __bpf_fill_staggered_jumps(self, &jmp, -1, 0);
2961 }
2962 
bpf_fill_staggered_jsge32_imm(struct bpf_test * self)2963 static int bpf_fill_staggered_jsge32_imm(struct bpf_test *self)
2964 {
2965 	struct bpf_insn jmp = BPF_JMP32_IMM(BPF_JSGE, R1, -2, 0);
2966 
2967 	return __bpf_fill_staggered_jumps(self, &jmp, -2, 0);
2968 }
2969 
bpf_fill_staggered_jslt32_imm(struct bpf_test * self)2970 static int bpf_fill_staggered_jslt32_imm(struct bpf_test *self)
2971 {
2972 	struct bpf_insn jmp = BPF_JMP32_IMM(BPF_JSLT, R1, -1, 0);
2973 
2974 	return __bpf_fill_staggered_jumps(self, &jmp, -2, 0);
2975 }
2976 
bpf_fill_staggered_jsle32_imm(struct bpf_test * self)2977 static int bpf_fill_staggered_jsle32_imm(struct bpf_test *self)
2978 {
2979 	struct bpf_insn jmp = BPF_JMP32_IMM(BPF_JSLE, R1, -1, 0);
2980 
2981 	return __bpf_fill_staggered_jumps(self, &jmp, -1, 0);
2982 }
2983 
2984 /* 32-bit register jumps */
bpf_fill_staggered_jeq32_reg(struct bpf_test * self)2985 static int bpf_fill_staggered_jeq32_reg(struct bpf_test *self)
2986 {
2987 	struct bpf_insn jmp = BPF_JMP32_REG(BPF_JEQ, R1, R2, 0);
2988 
2989 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 1234);
2990 }
2991 
bpf_fill_staggered_jne32_reg(struct bpf_test * self)2992 static int bpf_fill_staggered_jne32_reg(struct bpf_test *self)
2993 {
2994 	struct bpf_insn jmp = BPF_JMP32_REG(BPF_JNE, R1, R2, 0);
2995 
2996 	return __bpf_fill_staggered_jumps(self, &jmp, 4321, 1234);
2997 }
2998 
bpf_fill_staggered_jset32_reg(struct bpf_test * self)2999 static int bpf_fill_staggered_jset32_reg(struct bpf_test *self)
3000 {
3001 	struct bpf_insn jmp = BPF_JMP32_REG(BPF_JSET, R1, R2, 0);
3002 
3003 	return __bpf_fill_staggered_jumps(self, &jmp, 0x86, 0x82);
3004 }
3005 
bpf_fill_staggered_jgt32_reg(struct bpf_test * self)3006 static int bpf_fill_staggered_jgt32_reg(struct bpf_test *self)
3007 {
3008 	struct bpf_insn jmp = BPF_JMP32_REG(BPF_JGT, R1, R2, 0);
3009 
3010 	return __bpf_fill_staggered_jumps(self, &jmp, 0x80000000, 1234);
3011 }
3012 
bpf_fill_staggered_jge32_reg(struct bpf_test * self)3013 static int bpf_fill_staggered_jge32_reg(struct bpf_test *self)
3014 {
3015 	struct bpf_insn jmp = BPF_JMP32_REG(BPF_JGE, R1, R2, 0);
3016 
3017 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 1234);
3018 }
3019 
bpf_fill_staggered_jlt32_reg(struct bpf_test * self)3020 static int bpf_fill_staggered_jlt32_reg(struct bpf_test *self)
3021 {
3022 	struct bpf_insn jmp = BPF_JMP32_REG(BPF_JLT, R1, R2, 0);
3023 
3024 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 0x80000000);
3025 }
3026 
bpf_fill_staggered_jle32_reg(struct bpf_test * self)3027 static int bpf_fill_staggered_jle32_reg(struct bpf_test *self)
3028 {
3029 	struct bpf_insn jmp = BPF_JMP32_REG(BPF_JLE, R1, R2, 0);
3030 
3031 	return __bpf_fill_staggered_jumps(self, &jmp, 1234, 1234);
3032 }
3033 
bpf_fill_staggered_jsgt32_reg(struct bpf_test * self)3034 static int bpf_fill_staggered_jsgt32_reg(struct bpf_test *self)
3035 {
3036 	struct bpf_insn jmp = BPF_JMP32_REG(BPF_JSGT, R1, R2, 0);
3037 
3038 	return __bpf_fill_staggered_jumps(self, &jmp, -1, -2);
3039 }
3040 
bpf_fill_staggered_jsge32_reg(struct bpf_test * self)3041 static int bpf_fill_staggered_jsge32_reg(struct bpf_test *self)
3042 {
3043 	struct bpf_insn jmp = BPF_JMP32_REG(BPF_JSGE, R1, R2, 0);
3044 
3045 	return __bpf_fill_staggered_jumps(self, &jmp, -2, -2);
3046 }
3047 
bpf_fill_staggered_jslt32_reg(struct bpf_test * self)3048 static int bpf_fill_staggered_jslt32_reg(struct bpf_test *self)
3049 {
3050 	struct bpf_insn jmp = BPF_JMP32_REG(BPF_JSLT, R1, R2, 0);
3051 
3052 	return __bpf_fill_staggered_jumps(self, &jmp, -2, -1);
3053 }
3054 
bpf_fill_staggered_jsle32_reg(struct bpf_test * self)3055 static int bpf_fill_staggered_jsle32_reg(struct bpf_test *self)
3056 {
3057 	struct bpf_insn jmp = BPF_JMP32_REG(BPF_JSLE, R1, R2, 0);
3058 
3059 	return __bpf_fill_staggered_jumps(self, &jmp, -1, -1);
3060 }
3061 
3062 
3063 static struct bpf_test tests[] = {
3064 	{
3065 		"TAX",
3066 		.u.insns = {
3067 			BPF_STMT(BPF_LD | BPF_IMM, 1),
3068 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
3069 			BPF_STMT(BPF_LD | BPF_IMM, 2),
3070 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
3071 			BPF_STMT(BPF_ALU | BPF_NEG, 0), /* A == -3 */
3072 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
3073 			BPF_STMT(BPF_LD | BPF_LEN, 0),
3074 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
3075 			BPF_STMT(BPF_MISC | BPF_TAX, 0), /* X == len - 3 */
3076 			BPF_STMT(BPF_LD | BPF_B | BPF_IND, 1),
3077 			BPF_STMT(BPF_RET | BPF_A, 0)
3078 		},
3079 		CLASSIC,
3080 		{ 10, 20, 30, 40, 50 },
3081 		{ { 2, 10 }, { 3, 20 }, { 4, 30 } },
3082 	},
3083 	{
3084 		"TXA",
3085 		.u.insns = {
3086 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
3087 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
3088 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
3089 			BPF_STMT(BPF_RET | BPF_A, 0) /* A == len * 2 */
3090 		},
3091 		CLASSIC,
3092 		{ 10, 20, 30, 40, 50 },
3093 		{ { 1, 2 }, { 3, 6 }, { 4, 8 } },
3094 	},
3095 	{
3096 		"ADD_SUB_MUL_K",
3097 		.u.insns = {
3098 			BPF_STMT(BPF_LD | BPF_IMM, 1),
3099 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 2),
3100 			BPF_STMT(BPF_LDX | BPF_IMM, 3),
3101 			BPF_STMT(BPF_ALU | BPF_SUB | BPF_X, 0),
3102 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 0xffffffff),
3103 			BPF_STMT(BPF_ALU | BPF_MUL | BPF_K, 3),
3104 			BPF_STMT(BPF_RET | BPF_A, 0)
3105 		},
3106 		CLASSIC | FLAG_NO_DATA,
3107 		{ },
3108 		{ { 0, 0xfffffffd } }
3109 	},
3110 	{
3111 		"DIV_MOD_KX",
3112 		.u.insns = {
3113 			BPF_STMT(BPF_LD | BPF_IMM, 8),
3114 			BPF_STMT(BPF_ALU | BPF_DIV | BPF_K, 2),
3115 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
3116 			BPF_STMT(BPF_LD | BPF_IMM, 0xffffffff),
3117 			BPF_STMT(BPF_ALU | BPF_DIV | BPF_X, 0),
3118 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
3119 			BPF_STMT(BPF_LD | BPF_IMM, 0xffffffff),
3120 			BPF_STMT(BPF_ALU | BPF_DIV | BPF_K, 0x70000000),
3121 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
3122 			BPF_STMT(BPF_LD | BPF_IMM, 0xffffffff),
3123 			BPF_STMT(BPF_ALU | BPF_MOD | BPF_X, 0),
3124 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
3125 			BPF_STMT(BPF_LD | BPF_IMM, 0xffffffff),
3126 			BPF_STMT(BPF_ALU | BPF_MOD | BPF_K, 0x70000000),
3127 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
3128 			BPF_STMT(BPF_RET | BPF_A, 0)
3129 		},
3130 		CLASSIC | FLAG_NO_DATA,
3131 		{ },
3132 		{ { 0, 0x20000000 } }
3133 	},
3134 	{
3135 		"AND_OR_LSH_K",
3136 		.u.insns = {
3137 			BPF_STMT(BPF_LD | BPF_IMM, 0xff),
3138 			BPF_STMT(BPF_ALU | BPF_AND | BPF_K, 0xf0),
3139 			BPF_STMT(BPF_ALU | BPF_LSH | BPF_K, 27),
3140 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
3141 			BPF_STMT(BPF_LD | BPF_IMM, 0xf),
3142 			BPF_STMT(BPF_ALU | BPF_OR | BPF_K, 0xf0),
3143 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
3144 			BPF_STMT(BPF_RET | BPF_A, 0)
3145 		},
3146 		CLASSIC | FLAG_NO_DATA,
3147 		{ },
3148 		{ { 0, 0x800000ff }, { 1, 0x800000ff } },
3149 	},
3150 	{
3151 		"LD_IMM_0",
3152 		.u.insns = {
3153 			BPF_STMT(BPF_LD | BPF_IMM, 0), /* ld #0 */
3154 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0, 1, 0),
3155 			BPF_STMT(BPF_RET | BPF_K, 0),
3156 			BPF_STMT(BPF_RET | BPF_K, 1),
3157 		},
3158 		CLASSIC,
3159 		{ },
3160 		{ { 1, 1 } },
3161 	},
3162 	{
3163 		"LD_IND",
3164 		.u.insns = {
3165 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
3166 			BPF_STMT(BPF_LD | BPF_H | BPF_IND, MAX_K),
3167 			BPF_STMT(BPF_RET | BPF_K, 1)
3168 		},
3169 		CLASSIC,
3170 		{ },
3171 		{ { 1, 0 }, { 10, 0 }, { 60, 0 } },
3172 	},
3173 	{
3174 		"LD_ABS",
3175 		.u.insns = {
3176 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS, 1000),
3177 			BPF_STMT(BPF_RET | BPF_K, 1)
3178 		},
3179 		CLASSIC,
3180 		{ },
3181 		{ { 1, 0 }, { 10, 0 }, { 60, 0 } },
3182 	},
3183 	{
3184 		"LD_ABS_LL",
3185 		.u.insns = {
3186 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, SKF_LL_OFF),
3187 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
3188 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, SKF_LL_OFF + 1),
3189 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
3190 			BPF_STMT(BPF_RET | BPF_A, 0)
3191 		},
3192 		CLASSIC,
3193 		{ 1, 2, 3 },
3194 		{ { 1, 0 }, { 2, 3 } },
3195 	},
3196 	{
3197 		"LD_IND_LL",
3198 		.u.insns = {
3199 			BPF_STMT(BPF_LD | BPF_IMM, SKF_LL_OFF - 1),
3200 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
3201 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
3202 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
3203 			BPF_STMT(BPF_LD | BPF_B | BPF_IND, 0),
3204 			BPF_STMT(BPF_RET | BPF_A, 0)
3205 		},
3206 		CLASSIC,
3207 		{ 1, 2, 3, 0xff },
3208 		{ { 1, 1 }, { 3, 3 }, { 4, 0xff } },
3209 	},
3210 	{
3211 		"LD_ABS_NET",
3212 		.u.insns = {
3213 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, SKF_NET_OFF),
3214 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
3215 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, SKF_NET_OFF + 1),
3216 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
3217 			BPF_STMT(BPF_RET | BPF_A, 0)
3218 		},
3219 		CLASSIC,
3220 		{ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3 },
3221 		{ { 15, 0 }, { 16, 3 } },
3222 	},
3223 	{
3224 		"LD_IND_NET",
3225 		.u.insns = {
3226 			BPF_STMT(BPF_LD | BPF_IMM, SKF_NET_OFF - 15),
3227 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
3228 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
3229 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
3230 			BPF_STMT(BPF_LD | BPF_B | BPF_IND, 0),
3231 			BPF_STMT(BPF_RET | BPF_A, 0)
3232 		},
3233 		CLASSIC,
3234 		{ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3 },
3235 		{ { 14, 0 }, { 15, 1 }, { 17, 3 } },
3236 	},
3237 	{
3238 		"LD_PKTTYPE",
3239 		.u.insns = {
3240 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3241 				 SKF_AD_OFF + SKF_AD_PKTTYPE),
3242 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, SKB_TYPE, 1, 0),
3243 			BPF_STMT(BPF_RET | BPF_K, 1),
3244 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3245 				 SKF_AD_OFF + SKF_AD_PKTTYPE),
3246 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, SKB_TYPE, 1, 0),
3247 			BPF_STMT(BPF_RET | BPF_K, 1),
3248 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3249 				 SKF_AD_OFF + SKF_AD_PKTTYPE),
3250 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, SKB_TYPE, 1, 0),
3251 			BPF_STMT(BPF_RET | BPF_K, 1),
3252 			BPF_STMT(BPF_RET | BPF_A, 0)
3253 		},
3254 		CLASSIC,
3255 		{ },
3256 		{ { 1, 3 }, { 10, 3 } },
3257 	},
3258 	{
3259 		"LD_MARK",
3260 		.u.insns = {
3261 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3262 				 SKF_AD_OFF + SKF_AD_MARK),
3263 			BPF_STMT(BPF_RET | BPF_A, 0)
3264 		},
3265 		CLASSIC,
3266 		{ },
3267 		{ { 1, SKB_MARK}, { 10, SKB_MARK} },
3268 	},
3269 	{
3270 		"LD_RXHASH",
3271 		.u.insns = {
3272 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3273 				 SKF_AD_OFF + SKF_AD_RXHASH),
3274 			BPF_STMT(BPF_RET | BPF_A, 0)
3275 		},
3276 		CLASSIC,
3277 		{ },
3278 		{ { 1, SKB_HASH}, { 10, SKB_HASH} },
3279 	},
3280 	{
3281 		"LD_QUEUE",
3282 		.u.insns = {
3283 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3284 				 SKF_AD_OFF + SKF_AD_QUEUE),
3285 			BPF_STMT(BPF_RET | BPF_A, 0)
3286 		},
3287 		CLASSIC,
3288 		{ },
3289 		{ { 1, SKB_QUEUE_MAP }, { 10, SKB_QUEUE_MAP } },
3290 	},
3291 	{
3292 		"LD_PROTOCOL",
3293 		.u.insns = {
3294 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 1),
3295 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 20, 1, 0),
3296 			BPF_STMT(BPF_RET | BPF_K, 0),
3297 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3298 				 SKF_AD_OFF + SKF_AD_PROTOCOL),
3299 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
3300 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 2),
3301 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 30, 1, 0),
3302 			BPF_STMT(BPF_RET | BPF_K, 0),
3303 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
3304 			BPF_STMT(BPF_RET | BPF_A, 0)
3305 		},
3306 		CLASSIC,
3307 		{ 10, 20, 30 },
3308 		{ { 10, ETH_P_IP }, { 100, ETH_P_IP } },
3309 	},
3310 	{
3311 		"LD_VLAN_TAG",
3312 		.u.insns = {
3313 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3314 				 SKF_AD_OFF + SKF_AD_VLAN_TAG),
3315 			BPF_STMT(BPF_RET | BPF_A, 0)
3316 		},
3317 		CLASSIC,
3318 		{ },
3319 		{
3320 			{ 1, SKB_VLAN_TCI },
3321 			{ 10, SKB_VLAN_TCI }
3322 		},
3323 	},
3324 	{
3325 		"LD_VLAN_TAG_PRESENT",
3326 		.u.insns = {
3327 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3328 				 SKF_AD_OFF + SKF_AD_VLAN_TAG_PRESENT),
3329 			BPF_STMT(BPF_RET | BPF_A, 0)
3330 		},
3331 		CLASSIC,
3332 		{ },
3333 		{
3334 			{ 1, SKB_VLAN_PRESENT },
3335 			{ 10, SKB_VLAN_PRESENT }
3336 		},
3337 	},
3338 	{
3339 		"LD_IFINDEX",
3340 		.u.insns = {
3341 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3342 				 SKF_AD_OFF + SKF_AD_IFINDEX),
3343 			BPF_STMT(BPF_RET | BPF_A, 0)
3344 		},
3345 		CLASSIC,
3346 		{ },
3347 		{ { 1, SKB_DEV_IFINDEX }, { 10, SKB_DEV_IFINDEX } },
3348 	},
3349 	{
3350 		"LD_HATYPE",
3351 		.u.insns = {
3352 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3353 				 SKF_AD_OFF + SKF_AD_HATYPE),
3354 			BPF_STMT(BPF_RET | BPF_A, 0)
3355 		},
3356 		CLASSIC,
3357 		{ },
3358 		{ { 1, SKB_DEV_TYPE }, { 10, SKB_DEV_TYPE } },
3359 	},
3360 	{
3361 		"LD_CPU",
3362 		.u.insns = {
3363 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3364 				 SKF_AD_OFF + SKF_AD_CPU),
3365 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
3366 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3367 				 SKF_AD_OFF + SKF_AD_CPU),
3368 			BPF_STMT(BPF_ALU | BPF_SUB | BPF_X, 0),
3369 			BPF_STMT(BPF_RET | BPF_A, 0)
3370 		},
3371 		CLASSIC,
3372 		{ },
3373 		{ { 1, 0 }, { 10, 0 } },
3374 	},
3375 	{
3376 		"LD_NLATTR",
3377 		.u.insns = {
3378 			BPF_STMT(BPF_LDX | BPF_IMM, 2),
3379 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
3380 			BPF_STMT(BPF_LDX | BPF_IMM, 3),
3381 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3382 				 SKF_AD_OFF + SKF_AD_NLATTR),
3383 			BPF_STMT(BPF_RET | BPF_A, 0)
3384 		},
3385 		CLASSIC,
3386 #ifdef __BIG_ENDIAN
3387 		{ 0xff, 0xff, 0, 4, 0, 2, 0, 4, 0, 3 },
3388 #else
3389 		{ 0xff, 0xff, 4, 0, 2, 0, 4, 0, 3, 0 },
3390 #endif
3391 		{ { 4, 0 }, { 20, 6 } },
3392 	},
3393 	{
3394 		"LD_NLATTR_NEST",
3395 		.u.insns = {
3396 			BPF_STMT(BPF_LD | BPF_IMM, 2),
3397 			BPF_STMT(BPF_LDX | BPF_IMM, 3),
3398 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3399 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
3400 			BPF_STMT(BPF_LD | BPF_IMM, 2),
3401 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3402 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
3403 			BPF_STMT(BPF_LD | BPF_IMM, 2),
3404 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3405 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
3406 			BPF_STMT(BPF_LD | BPF_IMM, 2),
3407 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3408 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
3409 			BPF_STMT(BPF_LD | BPF_IMM, 2),
3410 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3411 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
3412 			BPF_STMT(BPF_LD | BPF_IMM, 2),
3413 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3414 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
3415 			BPF_STMT(BPF_LD | BPF_IMM, 2),
3416 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3417 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
3418 			BPF_STMT(BPF_LD | BPF_IMM, 2),
3419 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3420 				 SKF_AD_OFF + SKF_AD_NLATTR_NEST),
3421 			BPF_STMT(BPF_RET | BPF_A, 0)
3422 		},
3423 		CLASSIC,
3424 #ifdef __BIG_ENDIAN
3425 		{ 0xff, 0xff, 0, 12, 0, 1, 0, 4, 0, 2, 0, 4, 0, 3 },
3426 #else
3427 		{ 0xff, 0xff, 12, 0, 1, 0, 4, 0, 2, 0, 4, 0, 3, 0 },
3428 #endif
3429 		{ { 4, 0 }, { 20, 10 } },
3430 	},
3431 	{
3432 		"LD_PAYLOAD_OFF",
3433 		.u.insns = {
3434 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3435 				 SKF_AD_OFF + SKF_AD_PAY_OFFSET),
3436 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3437 				 SKF_AD_OFF + SKF_AD_PAY_OFFSET),
3438 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3439 				 SKF_AD_OFF + SKF_AD_PAY_OFFSET),
3440 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3441 				 SKF_AD_OFF + SKF_AD_PAY_OFFSET),
3442 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3443 				 SKF_AD_OFF + SKF_AD_PAY_OFFSET),
3444 			BPF_STMT(BPF_RET | BPF_A, 0)
3445 		},
3446 		CLASSIC,
3447 		/* 00:00:00:00:00:00 > 00:00:00:00:00:00, ethtype IPv4 (0x0800),
3448 		 * length 98: 127.0.0.1 > 127.0.0.1: ICMP echo request,
3449 		 * id 9737, seq 1, length 64
3450 		 */
3451 		{ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
3452 		  0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
3453 		  0x08, 0x00,
3454 		  0x45, 0x00, 0x00, 0x54, 0xac, 0x8b, 0x40, 0x00, 0x40,
3455 		  0x01, 0x90, 0x1b, 0x7f, 0x00, 0x00, 0x01 },
3456 		{ { 30, 0 }, { 100, 42 } },
3457 	},
3458 	{
3459 		"LD_ANC_XOR",
3460 		.u.insns = {
3461 			BPF_STMT(BPF_LD | BPF_IMM, 10),
3462 			BPF_STMT(BPF_LDX | BPF_IMM, 300),
3463 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
3464 				 SKF_AD_OFF + SKF_AD_ALU_XOR_X),
3465 			BPF_STMT(BPF_RET | BPF_A, 0)
3466 		},
3467 		CLASSIC,
3468 		{ },
3469 		{ { 4, 0xA ^ 300 }, { 20, 0xA ^ 300 } },
3470 	},
3471 	{
3472 		"SPILL_FILL",
3473 		.u.insns = {
3474 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
3475 			BPF_STMT(BPF_LD | BPF_IMM, 2),
3476 			BPF_STMT(BPF_ALU | BPF_RSH, 1),
3477 			BPF_STMT(BPF_ALU | BPF_XOR | BPF_X, 0),
3478 			BPF_STMT(BPF_ST, 1), /* M1 = 1 ^ len */
3479 			BPF_STMT(BPF_ALU | BPF_XOR | BPF_K, 0x80000000),
3480 			BPF_STMT(BPF_ST, 2), /* M2 = 1 ^ len ^ 0x80000000 */
3481 			BPF_STMT(BPF_STX, 15), /* M3 = len */
3482 			BPF_STMT(BPF_LDX | BPF_MEM, 1),
3483 			BPF_STMT(BPF_LD | BPF_MEM, 2),
3484 			BPF_STMT(BPF_ALU | BPF_XOR | BPF_X, 0),
3485 			BPF_STMT(BPF_LDX | BPF_MEM, 15),
3486 			BPF_STMT(BPF_ALU | BPF_XOR | BPF_X, 0),
3487 			BPF_STMT(BPF_RET | BPF_A, 0)
3488 		},
3489 		CLASSIC,
3490 		{ },
3491 		{ { 1, 0x80000001 }, { 2, 0x80000002 }, { 60, 0x80000000 ^ 60 } }
3492 	},
3493 	{
3494 		"JEQ",
3495 		.u.insns = {
3496 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
3497 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 2),
3498 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_X, 0, 0, 1),
3499 			BPF_STMT(BPF_RET | BPF_K, 1),
3500 			BPF_STMT(BPF_RET | BPF_K, MAX_K)
3501 		},
3502 		CLASSIC,
3503 		{ 3, 3, 3, 3, 3 },
3504 		{ { 1, 0 }, { 3, 1 }, { 4, MAX_K } },
3505 	},
3506 	{
3507 		"JGT",
3508 		.u.insns = {
3509 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
3510 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 2),
3511 			BPF_JUMP(BPF_JMP | BPF_JGT | BPF_X, 0, 0, 1),
3512 			BPF_STMT(BPF_RET | BPF_K, 1),
3513 			BPF_STMT(BPF_RET | BPF_K, MAX_K)
3514 		},
3515 		CLASSIC,
3516 		{ 4, 4, 4, 3, 3 },
3517 		{ { 2, 0 }, { 3, 1 }, { 4, MAX_K } },
3518 	},
3519 	{
3520 		"JGE (jt 0), test 1",
3521 		.u.insns = {
3522 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
3523 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 2),
3524 			BPF_JUMP(BPF_JMP | BPF_JGE | BPF_X, 0, 0, 1),
3525 			BPF_STMT(BPF_RET | BPF_K, 1),
3526 			BPF_STMT(BPF_RET | BPF_K, MAX_K)
3527 		},
3528 		CLASSIC,
3529 		{ 4, 4, 4, 3, 3 },
3530 		{ { 2, 0 }, { 3, 1 }, { 4, 1 } },
3531 	},
3532 	{
3533 		"JGE (jt 0), test 2",
3534 		.u.insns = {
3535 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
3536 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 2),
3537 			BPF_JUMP(BPF_JMP | BPF_JGE | BPF_X, 0, 0, 1),
3538 			BPF_STMT(BPF_RET | BPF_K, 1),
3539 			BPF_STMT(BPF_RET | BPF_K, MAX_K)
3540 		},
3541 		CLASSIC,
3542 		{ 4, 4, 5, 3, 3 },
3543 		{ { 4, 1 }, { 5, 1 }, { 6, MAX_K } },
3544 	},
3545 	{
3546 		"JGE",
3547 		.u.insns = {
3548 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
3549 			BPF_STMT(BPF_LD | BPF_B | BPF_IND, MAX_K),
3550 			BPF_JUMP(BPF_JMP | BPF_JGE | BPF_K, 1, 1, 0),
3551 			BPF_STMT(BPF_RET | BPF_K, 10),
3552 			BPF_JUMP(BPF_JMP | BPF_JGE | BPF_K, 2, 1, 0),
3553 			BPF_STMT(BPF_RET | BPF_K, 20),
3554 			BPF_JUMP(BPF_JMP | BPF_JGE | BPF_K, 3, 1, 0),
3555 			BPF_STMT(BPF_RET | BPF_K, 30),
3556 			BPF_JUMP(BPF_JMP | BPF_JGE | BPF_K, 4, 1, 0),
3557 			BPF_STMT(BPF_RET | BPF_K, 40),
3558 			BPF_STMT(BPF_RET | BPF_K, MAX_K)
3559 		},
3560 		CLASSIC,
3561 		{ 1, 2, 3, 4, 5 },
3562 		{ { 1, 20 }, { 3, 40 }, { 5, MAX_K } },
3563 	},
3564 	{
3565 		"JSET",
3566 		.u.insns = {
3567 			BPF_JUMP(BPF_JMP | BPF_JA, 0, 0, 0),
3568 			BPF_JUMP(BPF_JMP | BPF_JA, 1, 1, 1),
3569 			BPF_JUMP(BPF_JMP | BPF_JA, 0, 0, 0),
3570 			BPF_JUMP(BPF_JMP | BPF_JA, 0, 0, 0),
3571 			BPF_STMT(BPF_LDX | BPF_LEN, 0),
3572 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
3573 			BPF_STMT(BPF_ALU | BPF_SUB | BPF_K, 4),
3574 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
3575 			BPF_STMT(BPF_LD | BPF_W | BPF_IND, 0),
3576 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 1, 0, 1),
3577 			BPF_STMT(BPF_RET | BPF_K, 10),
3578 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0x80000000, 0, 1),
3579 			BPF_STMT(BPF_RET | BPF_K, 20),
3580 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0xffffff, 1, 0),
3581 			BPF_STMT(BPF_RET | BPF_K, 30),
3582 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0xffffff, 1, 0),
3583 			BPF_STMT(BPF_RET | BPF_K, 30),
3584 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0xffffff, 1, 0),
3585 			BPF_STMT(BPF_RET | BPF_K, 30),
3586 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0xffffff, 1, 0),
3587 			BPF_STMT(BPF_RET | BPF_K, 30),
3588 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0xffffff, 1, 0),
3589 			BPF_STMT(BPF_RET | BPF_K, 30),
3590 			BPF_STMT(BPF_RET | BPF_K, MAX_K)
3591 		},
3592 		CLASSIC,
3593 		{ 0, 0xAA, 0x55, 1 },
3594 		{ { 4, 10 }, { 5, 20 }, { 6, MAX_K } },
3595 	},
3596 	{
3597 		"tcpdump port 22",
3598 		.u.insns = {
3599 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 12),
3600 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x86dd, 0, 8), /* IPv6 */
3601 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 20),
3602 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x84, 2, 0),
3603 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x6, 1, 0),
3604 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x11, 0, 17),
3605 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 54),
3606 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 22, 14, 0),
3607 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 56),
3608 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 22, 12, 13),
3609 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x0800, 0, 12), /* IPv4 */
3610 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 23),
3611 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x84, 2, 0),
3612 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x6, 1, 0),
3613 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x11, 0, 8),
3614 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 20),
3615 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0x1fff, 6, 0),
3616 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 14),
3617 			BPF_STMT(BPF_LD | BPF_H | BPF_IND, 14),
3618 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 22, 2, 0),
3619 			BPF_STMT(BPF_LD | BPF_H | BPF_IND, 16),
3620 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 22, 0, 1),
3621 			BPF_STMT(BPF_RET | BPF_K, 0xffff),
3622 			BPF_STMT(BPF_RET | BPF_K, 0),
3623 		},
3624 		CLASSIC,
3625 		/* 3c:07:54:43:e5:76 > 10:bf:48:d6:43:d6, ethertype IPv4(0x0800)
3626 		 * length 114: 10.1.1.149.49700 > 10.1.2.10.22: Flags [P.],
3627 		 * seq 1305692979:1305693027, ack 3650467037, win 65535,
3628 		 * options [nop,nop,TS val 2502645400 ecr 3971138], length 48
3629 		 */
3630 		{ 0x10, 0xbf, 0x48, 0xd6, 0x43, 0xd6,
3631 		  0x3c, 0x07, 0x54, 0x43, 0xe5, 0x76,
3632 		  0x08, 0x00,
3633 		  0x45, 0x10, 0x00, 0x64, 0x75, 0xb5,
3634 		  0x40, 0x00, 0x40, 0x06, 0xad, 0x2e, /* IP header */
3635 		  0x0a, 0x01, 0x01, 0x95, /* ip src */
3636 		  0x0a, 0x01, 0x02, 0x0a, /* ip dst */
3637 		  0xc2, 0x24,
3638 		  0x00, 0x16 /* dst port */ },
3639 		{ { 10, 0 }, { 30, 0 }, { 100, 65535 } },
3640 	},
3641 	{
3642 		"tcpdump complex",
3643 		.u.insns = {
3644 			/* tcpdump -nei eth0 'tcp port 22 and (((ip[2:2] -
3645 			 * ((ip[0]&0xf)<<2)) - ((tcp[12]&0xf0)>>2)) != 0) and
3646 			 * (len > 115 or len < 30000000000)' -d
3647 			 */
3648 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 12),
3649 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x86dd, 30, 0),
3650 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x800, 0, 29),
3651 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 23),
3652 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x6, 0, 27),
3653 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 20),
3654 			BPF_JUMP(BPF_JMP | BPF_JSET | BPF_K, 0x1fff, 25, 0),
3655 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 14),
3656 			BPF_STMT(BPF_LD | BPF_H | BPF_IND, 14),
3657 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 22, 2, 0),
3658 			BPF_STMT(BPF_LD | BPF_H | BPF_IND, 16),
3659 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 22, 0, 20),
3660 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 16),
3661 			BPF_STMT(BPF_ST, 1),
3662 			BPF_STMT(BPF_LD | BPF_B | BPF_ABS, 14),
3663 			BPF_STMT(BPF_ALU | BPF_AND | BPF_K, 0xf),
3664 			BPF_STMT(BPF_ALU | BPF_LSH | BPF_K, 2),
3665 			BPF_STMT(BPF_MISC | BPF_TAX, 0x5), /* libpcap emits K on TAX */
3666 			BPF_STMT(BPF_LD | BPF_MEM, 1),
3667 			BPF_STMT(BPF_ALU | BPF_SUB | BPF_X, 0),
3668 			BPF_STMT(BPF_ST, 5),
3669 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 14),
3670 			BPF_STMT(BPF_LD | BPF_B | BPF_IND, 26),
3671 			BPF_STMT(BPF_ALU | BPF_AND | BPF_K, 0xf0),
3672 			BPF_STMT(BPF_ALU | BPF_RSH | BPF_K, 2),
3673 			BPF_STMT(BPF_MISC | BPF_TAX, 0x9), /* libpcap emits K on TAX */
3674 			BPF_STMT(BPF_LD | BPF_MEM, 5),
3675 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_X, 0, 4, 0),
3676 			BPF_STMT(BPF_LD | BPF_LEN, 0),
3677 			BPF_JUMP(BPF_JMP | BPF_JGT | BPF_K, 0x73, 1, 0),
3678 			BPF_JUMP(BPF_JMP | BPF_JGE | BPF_K, 0xfc23ac00, 1, 0),
3679 			BPF_STMT(BPF_RET | BPF_K, 0xffff),
3680 			BPF_STMT(BPF_RET | BPF_K, 0),
3681 		},
3682 		CLASSIC,
3683 		{ 0x10, 0xbf, 0x48, 0xd6, 0x43, 0xd6,
3684 		  0x3c, 0x07, 0x54, 0x43, 0xe5, 0x76,
3685 		  0x08, 0x00,
3686 		  0x45, 0x10, 0x00, 0x64, 0x75, 0xb5,
3687 		  0x40, 0x00, 0x40, 0x06, 0xad, 0x2e, /* IP header */
3688 		  0x0a, 0x01, 0x01, 0x95, /* ip src */
3689 		  0x0a, 0x01, 0x02, 0x0a, /* ip dst */
3690 		  0xc2, 0x24,
3691 		  0x00, 0x16 /* dst port */ },
3692 		{ { 10, 0 }, { 30, 0 }, { 100, 65535 } },
3693 	},
3694 	{
3695 		"RET_A",
3696 		.u.insns = {
3697 			/* check that uninitialized X and A contain zeros */
3698 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
3699 			BPF_STMT(BPF_RET | BPF_A, 0)
3700 		},
3701 		CLASSIC,
3702 		{ },
3703 		{ {1, 0}, {2, 0} },
3704 	},
3705 	{
3706 		"INT: ADD trivial",
3707 		.u.insns_int = {
3708 			BPF_ALU64_IMM(BPF_MOV, R1, 1),
3709 			BPF_ALU64_IMM(BPF_ADD, R1, 2),
3710 			BPF_ALU64_IMM(BPF_MOV, R2, 3),
3711 			BPF_ALU64_REG(BPF_SUB, R1, R2),
3712 			BPF_ALU64_IMM(BPF_ADD, R1, -1),
3713 			BPF_ALU64_IMM(BPF_MUL, R1, 3),
3714 			BPF_ALU64_REG(BPF_MOV, R0, R1),
3715 			BPF_EXIT_INSN(),
3716 		},
3717 		INTERNAL,
3718 		{ },
3719 		{ { 0, 0xfffffffd } }
3720 	},
3721 	{
3722 		"INT: MUL_X",
3723 		.u.insns_int = {
3724 			BPF_ALU64_IMM(BPF_MOV, R0, -1),
3725 			BPF_ALU64_IMM(BPF_MOV, R1, -1),
3726 			BPF_ALU64_IMM(BPF_MOV, R2, 3),
3727 			BPF_ALU64_REG(BPF_MUL, R1, R2),
3728 			BPF_JMP_IMM(BPF_JEQ, R1, 0xfffffffd, 1),
3729 			BPF_EXIT_INSN(),
3730 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
3731 			BPF_EXIT_INSN(),
3732 		},
3733 		INTERNAL,
3734 		{ },
3735 		{ { 0, 1 } }
3736 	},
3737 	{
3738 		"INT: MUL_X2",
3739 		.u.insns_int = {
3740 			BPF_ALU32_IMM(BPF_MOV, R0, -1),
3741 			BPF_ALU32_IMM(BPF_MOV, R1, -1),
3742 			BPF_ALU32_IMM(BPF_MOV, R2, 3),
3743 			BPF_ALU64_REG(BPF_MUL, R1, R2),
3744 			BPF_ALU64_IMM(BPF_RSH, R1, 8),
3745 			BPF_JMP_IMM(BPF_JEQ, R1, 0x2ffffff, 1),
3746 			BPF_EXIT_INSN(),
3747 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
3748 			BPF_EXIT_INSN(),
3749 		},
3750 		INTERNAL,
3751 		{ },
3752 		{ { 0, 1 } }
3753 	},
3754 	{
3755 		"INT: MUL32_X",
3756 		.u.insns_int = {
3757 			BPF_ALU32_IMM(BPF_MOV, R0, -1),
3758 			BPF_ALU64_IMM(BPF_MOV, R1, -1),
3759 			BPF_ALU32_IMM(BPF_MOV, R2, 3),
3760 			BPF_ALU32_REG(BPF_MUL, R1, R2),
3761 			BPF_ALU64_IMM(BPF_RSH, R1, 8),
3762 			BPF_JMP_IMM(BPF_JEQ, R1, 0xffffff, 1),
3763 			BPF_EXIT_INSN(),
3764 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
3765 			BPF_EXIT_INSN(),
3766 		},
3767 		INTERNAL,
3768 		{ },
3769 		{ { 0, 1 } }
3770 	},
3771 	{
3772 		/* Have to test all register combinations, since
3773 		 * JITing of different registers will produce
3774 		 * different asm code.
3775 		 */
3776 		"INT: ADD 64-bit",
3777 		.u.insns_int = {
3778 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
3779 			BPF_ALU64_IMM(BPF_MOV, R1, 1),
3780 			BPF_ALU64_IMM(BPF_MOV, R2, 2),
3781 			BPF_ALU64_IMM(BPF_MOV, R3, 3),
3782 			BPF_ALU64_IMM(BPF_MOV, R4, 4),
3783 			BPF_ALU64_IMM(BPF_MOV, R5, 5),
3784 			BPF_ALU64_IMM(BPF_MOV, R6, 6),
3785 			BPF_ALU64_IMM(BPF_MOV, R7, 7),
3786 			BPF_ALU64_IMM(BPF_MOV, R8, 8),
3787 			BPF_ALU64_IMM(BPF_MOV, R9, 9),
3788 			BPF_ALU64_IMM(BPF_ADD, R0, 20),
3789 			BPF_ALU64_IMM(BPF_ADD, R1, 20),
3790 			BPF_ALU64_IMM(BPF_ADD, R2, 20),
3791 			BPF_ALU64_IMM(BPF_ADD, R3, 20),
3792 			BPF_ALU64_IMM(BPF_ADD, R4, 20),
3793 			BPF_ALU64_IMM(BPF_ADD, R5, 20),
3794 			BPF_ALU64_IMM(BPF_ADD, R6, 20),
3795 			BPF_ALU64_IMM(BPF_ADD, R7, 20),
3796 			BPF_ALU64_IMM(BPF_ADD, R8, 20),
3797 			BPF_ALU64_IMM(BPF_ADD, R9, 20),
3798 			BPF_ALU64_IMM(BPF_SUB, R0, 10),
3799 			BPF_ALU64_IMM(BPF_SUB, R1, 10),
3800 			BPF_ALU64_IMM(BPF_SUB, R2, 10),
3801 			BPF_ALU64_IMM(BPF_SUB, R3, 10),
3802 			BPF_ALU64_IMM(BPF_SUB, R4, 10),
3803 			BPF_ALU64_IMM(BPF_SUB, R5, 10),
3804 			BPF_ALU64_IMM(BPF_SUB, R6, 10),
3805 			BPF_ALU64_IMM(BPF_SUB, R7, 10),
3806 			BPF_ALU64_IMM(BPF_SUB, R8, 10),
3807 			BPF_ALU64_IMM(BPF_SUB, R9, 10),
3808 			BPF_ALU64_REG(BPF_ADD, R0, R0),
3809 			BPF_ALU64_REG(BPF_ADD, R0, R1),
3810 			BPF_ALU64_REG(BPF_ADD, R0, R2),
3811 			BPF_ALU64_REG(BPF_ADD, R0, R3),
3812 			BPF_ALU64_REG(BPF_ADD, R0, R4),
3813 			BPF_ALU64_REG(BPF_ADD, R0, R5),
3814 			BPF_ALU64_REG(BPF_ADD, R0, R6),
3815 			BPF_ALU64_REG(BPF_ADD, R0, R7),
3816 			BPF_ALU64_REG(BPF_ADD, R0, R8),
3817 			BPF_ALU64_REG(BPF_ADD, R0, R9), /* R0 == 155 */
3818 			BPF_JMP_IMM(BPF_JEQ, R0, 155, 1),
3819 			BPF_EXIT_INSN(),
3820 			BPF_ALU64_REG(BPF_ADD, R1, R0),
3821 			BPF_ALU64_REG(BPF_ADD, R1, R1),
3822 			BPF_ALU64_REG(BPF_ADD, R1, R2),
3823 			BPF_ALU64_REG(BPF_ADD, R1, R3),
3824 			BPF_ALU64_REG(BPF_ADD, R1, R4),
3825 			BPF_ALU64_REG(BPF_ADD, R1, R5),
3826 			BPF_ALU64_REG(BPF_ADD, R1, R6),
3827 			BPF_ALU64_REG(BPF_ADD, R1, R7),
3828 			BPF_ALU64_REG(BPF_ADD, R1, R8),
3829 			BPF_ALU64_REG(BPF_ADD, R1, R9), /* R1 == 456 */
3830 			BPF_JMP_IMM(BPF_JEQ, R1, 456, 1),
3831 			BPF_EXIT_INSN(),
3832 			BPF_ALU64_REG(BPF_ADD, R2, R0),
3833 			BPF_ALU64_REG(BPF_ADD, R2, R1),
3834 			BPF_ALU64_REG(BPF_ADD, R2, R2),
3835 			BPF_ALU64_REG(BPF_ADD, R2, R3),
3836 			BPF_ALU64_REG(BPF_ADD, R2, R4),
3837 			BPF_ALU64_REG(BPF_ADD, R2, R5),
3838 			BPF_ALU64_REG(BPF_ADD, R2, R6),
3839 			BPF_ALU64_REG(BPF_ADD, R2, R7),
3840 			BPF_ALU64_REG(BPF_ADD, R2, R8),
3841 			BPF_ALU64_REG(BPF_ADD, R2, R9), /* R2 == 1358 */
3842 			BPF_JMP_IMM(BPF_JEQ, R2, 1358, 1),
3843 			BPF_EXIT_INSN(),
3844 			BPF_ALU64_REG(BPF_ADD, R3, R0),
3845 			BPF_ALU64_REG(BPF_ADD, R3, R1),
3846 			BPF_ALU64_REG(BPF_ADD, R3, R2),
3847 			BPF_ALU64_REG(BPF_ADD, R3, R3),
3848 			BPF_ALU64_REG(BPF_ADD, R3, R4),
3849 			BPF_ALU64_REG(BPF_ADD, R3, R5),
3850 			BPF_ALU64_REG(BPF_ADD, R3, R6),
3851 			BPF_ALU64_REG(BPF_ADD, R3, R7),
3852 			BPF_ALU64_REG(BPF_ADD, R3, R8),
3853 			BPF_ALU64_REG(BPF_ADD, R3, R9), /* R3 == 4063 */
3854 			BPF_JMP_IMM(BPF_JEQ, R3, 4063, 1),
3855 			BPF_EXIT_INSN(),
3856 			BPF_ALU64_REG(BPF_ADD, R4, R0),
3857 			BPF_ALU64_REG(BPF_ADD, R4, R1),
3858 			BPF_ALU64_REG(BPF_ADD, R4, R2),
3859 			BPF_ALU64_REG(BPF_ADD, R4, R3),
3860 			BPF_ALU64_REG(BPF_ADD, R4, R4),
3861 			BPF_ALU64_REG(BPF_ADD, R4, R5),
3862 			BPF_ALU64_REG(BPF_ADD, R4, R6),
3863 			BPF_ALU64_REG(BPF_ADD, R4, R7),
3864 			BPF_ALU64_REG(BPF_ADD, R4, R8),
3865 			BPF_ALU64_REG(BPF_ADD, R4, R9), /* R4 == 12177 */
3866 			BPF_JMP_IMM(BPF_JEQ, R4, 12177, 1),
3867 			BPF_EXIT_INSN(),
3868 			BPF_ALU64_REG(BPF_ADD, R5, R0),
3869 			BPF_ALU64_REG(BPF_ADD, R5, R1),
3870 			BPF_ALU64_REG(BPF_ADD, R5, R2),
3871 			BPF_ALU64_REG(BPF_ADD, R5, R3),
3872 			BPF_ALU64_REG(BPF_ADD, R5, R4),
3873 			BPF_ALU64_REG(BPF_ADD, R5, R5),
3874 			BPF_ALU64_REG(BPF_ADD, R5, R6),
3875 			BPF_ALU64_REG(BPF_ADD, R5, R7),
3876 			BPF_ALU64_REG(BPF_ADD, R5, R8),
3877 			BPF_ALU64_REG(BPF_ADD, R5, R9), /* R5 == 36518 */
3878 			BPF_JMP_IMM(BPF_JEQ, R5, 36518, 1),
3879 			BPF_EXIT_INSN(),
3880 			BPF_ALU64_REG(BPF_ADD, R6, R0),
3881 			BPF_ALU64_REG(BPF_ADD, R6, R1),
3882 			BPF_ALU64_REG(BPF_ADD, R6, R2),
3883 			BPF_ALU64_REG(BPF_ADD, R6, R3),
3884 			BPF_ALU64_REG(BPF_ADD, R6, R4),
3885 			BPF_ALU64_REG(BPF_ADD, R6, R5),
3886 			BPF_ALU64_REG(BPF_ADD, R6, R6),
3887 			BPF_ALU64_REG(BPF_ADD, R6, R7),
3888 			BPF_ALU64_REG(BPF_ADD, R6, R8),
3889 			BPF_ALU64_REG(BPF_ADD, R6, R9), /* R6 == 109540 */
3890 			BPF_JMP_IMM(BPF_JEQ, R6, 109540, 1),
3891 			BPF_EXIT_INSN(),
3892 			BPF_ALU64_REG(BPF_ADD, R7, R0),
3893 			BPF_ALU64_REG(BPF_ADD, R7, R1),
3894 			BPF_ALU64_REG(BPF_ADD, R7, R2),
3895 			BPF_ALU64_REG(BPF_ADD, R7, R3),
3896 			BPF_ALU64_REG(BPF_ADD, R7, R4),
3897 			BPF_ALU64_REG(BPF_ADD, R7, R5),
3898 			BPF_ALU64_REG(BPF_ADD, R7, R6),
3899 			BPF_ALU64_REG(BPF_ADD, R7, R7),
3900 			BPF_ALU64_REG(BPF_ADD, R7, R8),
3901 			BPF_ALU64_REG(BPF_ADD, R7, R9), /* R7 == 328605 */
3902 			BPF_JMP_IMM(BPF_JEQ, R7, 328605, 1),
3903 			BPF_EXIT_INSN(),
3904 			BPF_ALU64_REG(BPF_ADD, R8, R0),
3905 			BPF_ALU64_REG(BPF_ADD, R8, R1),
3906 			BPF_ALU64_REG(BPF_ADD, R8, R2),
3907 			BPF_ALU64_REG(BPF_ADD, R8, R3),
3908 			BPF_ALU64_REG(BPF_ADD, R8, R4),
3909 			BPF_ALU64_REG(BPF_ADD, R8, R5),
3910 			BPF_ALU64_REG(BPF_ADD, R8, R6),
3911 			BPF_ALU64_REG(BPF_ADD, R8, R7),
3912 			BPF_ALU64_REG(BPF_ADD, R8, R8),
3913 			BPF_ALU64_REG(BPF_ADD, R8, R9), /* R8 == 985799 */
3914 			BPF_JMP_IMM(BPF_JEQ, R8, 985799, 1),
3915 			BPF_EXIT_INSN(),
3916 			BPF_ALU64_REG(BPF_ADD, R9, R0),
3917 			BPF_ALU64_REG(BPF_ADD, R9, R1),
3918 			BPF_ALU64_REG(BPF_ADD, R9, R2),
3919 			BPF_ALU64_REG(BPF_ADD, R9, R3),
3920 			BPF_ALU64_REG(BPF_ADD, R9, R4),
3921 			BPF_ALU64_REG(BPF_ADD, R9, R5),
3922 			BPF_ALU64_REG(BPF_ADD, R9, R6),
3923 			BPF_ALU64_REG(BPF_ADD, R9, R7),
3924 			BPF_ALU64_REG(BPF_ADD, R9, R8),
3925 			BPF_ALU64_REG(BPF_ADD, R9, R9), /* R9 == 2957380 */
3926 			BPF_ALU64_REG(BPF_MOV, R0, R9),
3927 			BPF_EXIT_INSN(),
3928 		},
3929 		INTERNAL,
3930 		{ },
3931 		{ { 0, 2957380 } }
3932 	},
3933 	{
3934 		"INT: ADD 32-bit",
3935 		.u.insns_int = {
3936 			BPF_ALU32_IMM(BPF_MOV, R0, 20),
3937 			BPF_ALU32_IMM(BPF_MOV, R1, 1),
3938 			BPF_ALU32_IMM(BPF_MOV, R2, 2),
3939 			BPF_ALU32_IMM(BPF_MOV, R3, 3),
3940 			BPF_ALU32_IMM(BPF_MOV, R4, 4),
3941 			BPF_ALU32_IMM(BPF_MOV, R5, 5),
3942 			BPF_ALU32_IMM(BPF_MOV, R6, 6),
3943 			BPF_ALU32_IMM(BPF_MOV, R7, 7),
3944 			BPF_ALU32_IMM(BPF_MOV, R8, 8),
3945 			BPF_ALU32_IMM(BPF_MOV, R9, 9),
3946 			BPF_ALU64_IMM(BPF_ADD, R1, 10),
3947 			BPF_ALU64_IMM(BPF_ADD, R2, 10),
3948 			BPF_ALU64_IMM(BPF_ADD, R3, 10),
3949 			BPF_ALU64_IMM(BPF_ADD, R4, 10),
3950 			BPF_ALU64_IMM(BPF_ADD, R5, 10),
3951 			BPF_ALU64_IMM(BPF_ADD, R6, 10),
3952 			BPF_ALU64_IMM(BPF_ADD, R7, 10),
3953 			BPF_ALU64_IMM(BPF_ADD, R8, 10),
3954 			BPF_ALU64_IMM(BPF_ADD, R9, 10),
3955 			BPF_ALU32_REG(BPF_ADD, R0, R1),
3956 			BPF_ALU32_REG(BPF_ADD, R0, R2),
3957 			BPF_ALU32_REG(BPF_ADD, R0, R3),
3958 			BPF_ALU32_REG(BPF_ADD, R0, R4),
3959 			BPF_ALU32_REG(BPF_ADD, R0, R5),
3960 			BPF_ALU32_REG(BPF_ADD, R0, R6),
3961 			BPF_ALU32_REG(BPF_ADD, R0, R7),
3962 			BPF_ALU32_REG(BPF_ADD, R0, R8),
3963 			BPF_ALU32_REG(BPF_ADD, R0, R9), /* R0 == 155 */
3964 			BPF_JMP_IMM(BPF_JEQ, R0, 155, 1),
3965 			BPF_EXIT_INSN(),
3966 			BPF_ALU32_REG(BPF_ADD, R1, R0),
3967 			BPF_ALU32_REG(BPF_ADD, R1, R1),
3968 			BPF_ALU32_REG(BPF_ADD, R1, R2),
3969 			BPF_ALU32_REG(BPF_ADD, R1, R3),
3970 			BPF_ALU32_REG(BPF_ADD, R1, R4),
3971 			BPF_ALU32_REG(BPF_ADD, R1, R5),
3972 			BPF_ALU32_REG(BPF_ADD, R1, R6),
3973 			BPF_ALU32_REG(BPF_ADD, R1, R7),
3974 			BPF_ALU32_REG(BPF_ADD, R1, R8),
3975 			BPF_ALU32_REG(BPF_ADD, R1, R9), /* R1 == 456 */
3976 			BPF_JMP_IMM(BPF_JEQ, R1, 456, 1),
3977 			BPF_EXIT_INSN(),
3978 			BPF_ALU32_REG(BPF_ADD, R2, R0),
3979 			BPF_ALU32_REG(BPF_ADD, R2, R1),
3980 			BPF_ALU32_REG(BPF_ADD, R2, R2),
3981 			BPF_ALU32_REG(BPF_ADD, R2, R3),
3982 			BPF_ALU32_REG(BPF_ADD, R2, R4),
3983 			BPF_ALU32_REG(BPF_ADD, R2, R5),
3984 			BPF_ALU32_REG(BPF_ADD, R2, R6),
3985 			BPF_ALU32_REG(BPF_ADD, R2, R7),
3986 			BPF_ALU32_REG(BPF_ADD, R2, R8),
3987 			BPF_ALU32_REG(BPF_ADD, R2, R9), /* R2 == 1358 */
3988 			BPF_JMP_IMM(BPF_JEQ, R2, 1358, 1),
3989 			BPF_EXIT_INSN(),
3990 			BPF_ALU32_REG(BPF_ADD, R3, R0),
3991 			BPF_ALU32_REG(BPF_ADD, R3, R1),
3992 			BPF_ALU32_REG(BPF_ADD, R3, R2),
3993 			BPF_ALU32_REG(BPF_ADD, R3, R3),
3994 			BPF_ALU32_REG(BPF_ADD, R3, R4),
3995 			BPF_ALU32_REG(BPF_ADD, R3, R5),
3996 			BPF_ALU32_REG(BPF_ADD, R3, R6),
3997 			BPF_ALU32_REG(BPF_ADD, R3, R7),
3998 			BPF_ALU32_REG(BPF_ADD, R3, R8),
3999 			BPF_ALU32_REG(BPF_ADD, R3, R9), /* R3 == 4063 */
4000 			BPF_JMP_IMM(BPF_JEQ, R3, 4063, 1),
4001 			BPF_EXIT_INSN(),
4002 			BPF_ALU32_REG(BPF_ADD, R4, R0),
4003 			BPF_ALU32_REG(BPF_ADD, R4, R1),
4004 			BPF_ALU32_REG(BPF_ADD, R4, R2),
4005 			BPF_ALU32_REG(BPF_ADD, R4, R3),
4006 			BPF_ALU32_REG(BPF_ADD, R4, R4),
4007 			BPF_ALU32_REG(BPF_ADD, R4, R5),
4008 			BPF_ALU32_REG(BPF_ADD, R4, R6),
4009 			BPF_ALU32_REG(BPF_ADD, R4, R7),
4010 			BPF_ALU32_REG(BPF_ADD, R4, R8),
4011 			BPF_ALU32_REG(BPF_ADD, R4, R9), /* R4 == 12177 */
4012 			BPF_JMP_IMM(BPF_JEQ, R4, 12177, 1),
4013 			BPF_EXIT_INSN(),
4014 			BPF_ALU32_REG(BPF_ADD, R5, R0),
4015 			BPF_ALU32_REG(BPF_ADD, R5, R1),
4016 			BPF_ALU32_REG(BPF_ADD, R5, R2),
4017 			BPF_ALU32_REG(BPF_ADD, R5, R3),
4018 			BPF_ALU32_REG(BPF_ADD, R5, R4),
4019 			BPF_ALU32_REG(BPF_ADD, R5, R5),
4020 			BPF_ALU32_REG(BPF_ADD, R5, R6),
4021 			BPF_ALU32_REG(BPF_ADD, R5, R7),
4022 			BPF_ALU32_REG(BPF_ADD, R5, R8),
4023 			BPF_ALU32_REG(BPF_ADD, R5, R9), /* R5 == 36518 */
4024 			BPF_JMP_IMM(BPF_JEQ, R5, 36518, 1),
4025 			BPF_EXIT_INSN(),
4026 			BPF_ALU32_REG(BPF_ADD, R6, R0),
4027 			BPF_ALU32_REG(BPF_ADD, R6, R1),
4028 			BPF_ALU32_REG(BPF_ADD, R6, R2),
4029 			BPF_ALU32_REG(BPF_ADD, R6, R3),
4030 			BPF_ALU32_REG(BPF_ADD, R6, R4),
4031 			BPF_ALU32_REG(BPF_ADD, R6, R5),
4032 			BPF_ALU32_REG(BPF_ADD, R6, R6),
4033 			BPF_ALU32_REG(BPF_ADD, R6, R7),
4034 			BPF_ALU32_REG(BPF_ADD, R6, R8),
4035 			BPF_ALU32_REG(BPF_ADD, R6, R9), /* R6 == 109540 */
4036 			BPF_JMP_IMM(BPF_JEQ, R6, 109540, 1),
4037 			BPF_EXIT_INSN(),
4038 			BPF_ALU32_REG(BPF_ADD, R7, R0),
4039 			BPF_ALU32_REG(BPF_ADD, R7, R1),
4040 			BPF_ALU32_REG(BPF_ADD, R7, R2),
4041 			BPF_ALU32_REG(BPF_ADD, R7, R3),
4042 			BPF_ALU32_REG(BPF_ADD, R7, R4),
4043 			BPF_ALU32_REG(BPF_ADD, R7, R5),
4044 			BPF_ALU32_REG(BPF_ADD, R7, R6),
4045 			BPF_ALU32_REG(BPF_ADD, R7, R7),
4046 			BPF_ALU32_REG(BPF_ADD, R7, R8),
4047 			BPF_ALU32_REG(BPF_ADD, R7, R9), /* R7 == 328605 */
4048 			BPF_JMP_IMM(BPF_JEQ, R7, 328605, 1),
4049 			BPF_EXIT_INSN(),
4050 			BPF_ALU32_REG(BPF_ADD, R8, R0),
4051 			BPF_ALU32_REG(BPF_ADD, R8, R1),
4052 			BPF_ALU32_REG(BPF_ADD, R8, R2),
4053 			BPF_ALU32_REG(BPF_ADD, R8, R3),
4054 			BPF_ALU32_REG(BPF_ADD, R8, R4),
4055 			BPF_ALU32_REG(BPF_ADD, R8, R5),
4056 			BPF_ALU32_REG(BPF_ADD, R8, R6),
4057 			BPF_ALU32_REG(BPF_ADD, R8, R7),
4058 			BPF_ALU32_REG(BPF_ADD, R8, R8),
4059 			BPF_ALU32_REG(BPF_ADD, R8, R9), /* R8 == 985799 */
4060 			BPF_JMP_IMM(BPF_JEQ, R8, 985799, 1),
4061 			BPF_EXIT_INSN(),
4062 			BPF_ALU32_REG(BPF_ADD, R9, R0),
4063 			BPF_ALU32_REG(BPF_ADD, R9, R1),
4064 			BPF_ALU32_REG(BPF_ADD, R9, R2),
4065 			BPF_ALU32_REG(BPF_ADD, R9, R3),
4066 			BPF_ALU32_REG(BPF_ADD, R9, R4),
4067 			BPF_ALU32_REG(BPF_ADD, R9, R5),
4068 			BPF_ALU32_REG(BPF_ADD, R9, R6),
4069 			BPF_ALU32_REG(BPF_ADD, R9, R7),
4070 			BPF_ALU32_REG(BPF_ADD, R9, R8),
4071 			BPF_ALU32_REG(BPF_ADD, R9, R9), /* R9 == 2957380 */
4072 			BPF_ALU32_REG(BPF_MOV, R0, R9),
4073 			BPF_EXIT_INSN(),
4074 		},
4075 		INTERNAL,
4076 		{ },
4077 		{ { 0, 2957380 } }
4078 	},
4079 	{	/* Mainly checking JIT here. */
4080 		"INT: SUB",
4081 		.u.insns_int = {
4082 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
4083 			BPF_ALU64_IMM(BPF_MOV, R1, 1),
4084 			BPF_ALU64_IMM(BPF_MOV, R2, 2),
4085 			BPF_ALU64_IMM(BPF_MOV, R3, 3),
4086 			BPF_ALU64_IMM(BPF_MOV, R4, 4),
4087 			BPF_ALU64_IMM(BPF_MOV, R5, 5),
4088 			BPF_ALU64_IMM(BPF_MOV, R6, 6),
4089 			BPF_ALU64_IMM(BPF_MOV, R7, 7),
4090 			BPF_ALU64_IMM(BPF_MOV, R8, 8),
4091 			BPF_ALU64_IMM(BPF_MOV, R9, 9),
4092 			BPF_ALU64_REG(BPF_SUB, R0, R0),
4093 			BPF_ALU64_REG(BPF_SUB, R0, R1),
4094 			BPF_ALU64_REG(BPF_SUB, R0, R2),
4095 			BPF_ALU64_REG(BPF_SUB, R0, R3),
4096 			BPF_ALU64_REG(BPF_SUB, R0, R4),
4097 			BPF_ALU64_REG(BPF_SUB, R0, R5),
4098 			BPF_ALU64_REG(BPF_SUB, R0, R6),
4099 			BPF_ALU64_REG(BPF_SUB, R0, R7),
4100 			BPF_ALU64_REG(BPF_SUB, R0, R8),
4101 			BPF_ALU64_REG(BPF_SUB, R0, R9),
4102 			BPF_ALU64_IMM(BPF_SUB, R0, 10),
4103 			BPF_JMP_IMM(BPF_JEQ, R0, -55, 1),
4104 			BPF_EXIT_INSN(),
4105 			BPF_ALU64_REG(BPF_SUB, R1, R0),
4106 			BPF_ALU64_REG(BPF_SUB, R1, R2),
4107 			BPF_ALU64_REG(BPF_SUB, R1, R3),
4108 			BPF_ALU64_REG(BPF_SUB, R1, R4),
4109 			BPF_ALU64_REG(BPF_SUB, R1, R5),
4110 			BPF_ALU64_REG(BPF_SUB, R1, R6),
4111 			BPF_ALU64_REG(BPF_SUB, R1, R7),
4112 			BPF_ALU64_REG(BPF_SUB, R1, R8),
4113 			BPF_ALU64_REG(BPF_SUB, R1, R9),
4114 			BPF_ALU64_IMM(BPF_SUB, R1, 10),
4115 			BPF_ALU64_REG(BPF_SUB, R2, R0),
4116 			BPF_ALU64_REG(BPF_SUB, R2, R1),
4117 			BPF_ALU64_REG(BPF_SUB, R2, R3),
4118 			BPF_ALU64_REG(BPF_SUB, R2, R4),
4119 			BPF_ALU64_REG(BPF_SUB, R2, R5),
4120 			BPF_ALU64_REG(BPF_SUB, R2, R6),
4121 			BPF_ALU64_REG(BPF_SUB, R2, R7),
4122 			BPF_ALU64_REG(BPF_SUB, R2, R8),
4123 			BPF_ALU64_REG(BPF_SUB, R2, R9),
4124 			BPF_ALU64_IMM(BPF_SUB, R2, 10),
4125 			BPF_ALU64_REG(BPF_SUB, R3, R0),
4126 			BPF_ALU64_REG(BPF_SUB, R3, R1),
4127 			BPF_ALU64_REG(BPF_SUB, R3, R2),
4128 			BPF_ALU64_REG(BPF_SUB, R3, R4),
4129 			BPF_ALU64_REG(BPF_SUB, R3, R5),
4130 			BPF_ALU64_REG(BPF_SUB, R3, R6),
4131 			BPF_ALU64_REG(BPF_SUB, R3, R7),
4132 			BPF_ALU64_REG(BPF_SUB, R3, R8),
4133 			BPF_ALU64_REG(BPF_SUB, R3, R9),
4134 			BPF_ALU64_IMM(BPF_SUB, R3, 10),
4135 			BPF_ALU64_REG(BPF_SUB, R4, R0),
4136 			BPF_ALU64_REG(BPF_SUB, R4, R1),
4137 			BPF_ALU64_REG(BPF_SUB, R4, R2),
4138 			BPF_ALU64_REG(BPF_SUB, R4, R3),
4139 			BPF_ALU64_REG(BPF_SUB, R4, R5),
4140 			BPF_ALU64_REG(BPF_SUB, R4, R6),
4141 			BPF_ALU64_REG(BPF_SUB, R4, R7),
4142 			BPF_ALU64_REG(BPF_SUB, R4, R8),
4143 			BPF_ALU64_REG(BPF_SUB, R4, R9),
4144 			BPF_ALU64_IMM(BPF_SUB, R4, 10),
4145 			BPF_ALU64_REG(BPF_SUB, R5, R0),
4146 			BPF_ALU64_REG(BPF_SUB, R5, R1),
4147 			BPF_ALU64_REG(BPF_SUB, R5, R2),
4148 			BPF_ALU64_REG(BPF_SUB, R5, R3),
4149 			BPF_ALU64_REG(BPF_SUB, R5, R4),
4150 			BPF_ALU64_REG(BPF_SUB, R5, R6),
4151 			BPF_ALU64_REG(BPF_SUB, R5, R7),
4152 			BPF_ALU64_REG(BPF_SUB, R5, R8),
4153 			BPF_ALU64_REG(BPF_SUB, R5, R9),
4154 			BPF_ALU64_IMM(BPF_SUB, R5, 10),
4155 			BPF_ALU64_REG(BPF_SUB, R6, R0),
4156 			BPF_ALU64_REG(BPF_SUB, R6, R1),
4157 			BPF_ALU64_REG(BPF_SUB, R6, R2),
4158 			BPF_ALU64_REG(BPF_SUB, R6, R3),
4159 			BPF_ALU64_REG(BPF_SUB, R6, R4),
4160 			BPF_ALU64_REG(BPF_SUB, R6, R5),
4161 			BPF_ALU64_REG(BPF_SUB, R6, R7),
4162 			BPF_ALU64_REG(BPF_SUB, R6, R8),
4163 			BPF_ALU64_REG(BPF_SUB, R6, R9),
4164 			BPF_ALU64_IMM(BPF_SUB, R6, 10),
4165 			BPF_ALU64_REG(BPF_SUB, R7, R0),
4166 			BPF_ALU64_REG(BPF_SUB, R7, R1),
4167 			BPF_ALU64_REG(BPF_SUB, R7, R2),
4168 			BPF_ALU64_REG(BPF_SUB, R7, R3),
4169 			BPF_ALU64_REG(BPF_SUB, R7, R4),
4170 			BPF_ALU64_REG(BPF_SUB, R7, R5),
4171 			BPF_ALU64_REG(BPF_SUB, R7, R6),
4172 			BPF_ALU64_REG(BPF_SUB, R7, R8),
4173 			BPF_ALU64_REG(BPF_SUB, R7, R9),
4174 			BPF_ALU64_IMM(BPF_SUB, R7, 10),
4175 			BPF_ALU64_REG(BPF_SUB, R8, R0),
4176 			BPF_ALU64_REG(BPF_SUB, R8, R1),
4177 			BPF_ALU64_REG(BPF_SUB, R8, R2),
4178 			BPF_ALU64_REG(BPF_SUB, R8, R3),
4179 			BPF_ALU64_REG(BPF_SUB, R8, R4),
4180 			BPF_ALU64_REG(BPF_SUB, R8, R5),
4181 			BPF_ALU64_REG(BPF_SUB, R8, R6),
4182 			BPF_ALU64_REG(BPF_SUB, R8, R7),
4183 			BPF_ALU64_REG(BPF_SUB, R8, R9),
4184 			BPF_ALU64_IMM(BPF_SUB, R8, 10),
4185 			BPF_ALU64_REG(BPF_SUB, R9, R0),
4186 			BPF_ALU64_REG(BPF_SUB, R9, R1),
4187 			BPF_ALU64_REG(BPF_SUB, R9, R2),
4188 			BPF_ALU64_REG(BPF_SUB, R9, R3),
4189 			BPF_ALU64_REG(BPF_SUB, R9, R4),
4190 			BPF_ALU64_REG(BPF_SUB, R9, R5),
4191 			BPF_ALU64_REG(BPF_SUB, R9, R6),
4192 			BPF_ALU64_REG(BPF_SUB, R9, R7),
4193 			BPF_ALU64_REG(BPF_SUB, R9, R8),
4194 			BPF_ALU64_IMM(BPF_SUB, R9, 10),
4195 			BPF_ALU64_IMM(BPF_SUB, R0, 10),
4196 			BPF_ALU64_IMM(BPF_NEG, R0, 0),
4197 			BPF_ALU64_REG(BPF_SUB, R0, R1),
4198 			BPF_ALU64_REG(BPF_SUB, R0, R2),
4199 			BPF_ALU64_REG(BPF_SUB, R0, R3),
4200 			BPF_ALU64_REG(BPF_SUB, R0, R4),
4201 			BPF_ALU64_REG(BPF_SUB, R0, R5),
4202 			BPF_ALU64_REG(BPF_SUB, R0, R6),
4203 			BPF_ALU64_REG(BPF_SUB, R0, R7),
4204 			BPF_ALU64_REG(BPF_SUB, R0, R8),
4205 			BPF_ALU64_REG(BPF_SUB, R0, R9),
4206 			BPF_EXIT_INSN(),
4207 		},
4208 		INTERNAL,
4209 		{ },
4210 		{ { 0, 11 } }
4211 	},
4212 	{	/* Mainly checking JIT here. */
4213 		"INT: XOR",
4214 		.u.insns_int = {
4215 			BPF_ALU64_REG(BPF_SUB, R0, R0),
4216 			BPF_ALU64_REG(BPF_XOR, R1, R1),
4217 			BPF_JMP_REG(BPF_JEQ, R0, R1, 1),
4218 			BPF_EXIT_INSN(),
4219 			BPF_ALU64_IMM(BPF_MOV, R0, 10),
4220 			BPF_ALU64_IMM(BPF_MOV, R1, -1),
4221 			BPF_ALU64_REG(BPF_SUB, R1, R1),
4222 			BPF_ALU64_REG(BPF_XOR, R2, R2),
4223 			BPF_JMP_REG(BPF_JEQ, R1, R2, 1),
4224 			BPF_EXIT_INSN(),
4225 			BPF_ALU64_REG(BPF_SUB, R2, R2),
4226 			BPF_ALU64_REG(BPF_XOR, R3, R3),
4227 			BPF_ALU64_IMM(BPF_MOV, R0, 10),
4228 			BPF_ALU64_IMM(BPF_MOV, R1, -1),
4229 			BPF_JMP_REG(BPF_JEQ, R2, R3, 1),
4230 			BPF_EXIT_INSN(),
4231 			BPF_ALU64_REG(BPF_SUB, R3, R3),
4232 			BPF_ALU64_REG(BPF_XOR, R4, R4),
4233 			BPF_ALU64_IMM(BPF_MOV, R2, 1),
4234 			BPF_ALU64_IMM(BPF_MOV, R5, -1),
4235 			BPF_JMP_REG(BPF_JEQ, R3, R4, 1),
4236 			BPF_EXIT_INSN(),
4237 			BPF_ALU64_REG(BPF_SUB, R4, R4),
4238 			BPF_ALU64_REG(BPF_XOR, R5, R5),
4239 			BPF_ALU64_IMM(BPF_MOV, R3, 1),
4240 			BPF_ALU64_IMM(BPF_MOV, R7, -1),
4241 			BPF_JMP_REG(BPF_JEQ, R5, R4, 1),
4242 			BPF_EXIT_INSN(),
4243 			BPF_ALU64_IMM(BPF_MOV, R5, 1),
4244 			BPF_ALU64_REG(BPF_SUB, R5, R5),
4245 			BPF_ALU64_REG(BPF_XOR, R6, R6),
4246 			BPF_ALU64_IMM(BPF_MOV, R1, 1),
4247 			BPF_ALU64_IMM(BPF_MOV, R8, -1),
4248 			BPF_JMP_REG(BPF_JEQ, R5, R6, 1),
4249 			BPF_EXIT_INSN(),
4250 			BPF_ALU64_REG(BPF_SUB, R6, R6),
4251 			BPF_ALU64_REG(BPF_XOR, R7, R7),
4252 			BPF_JMP_REG(BPF_JEQ, R7, R6, 1),
4253 			BPF_EXIT_INSN(),
4254 			BPF_ALU64_REG(BPF_SUB, R7, R7),
4255 			BPF_ALU64_REG(BPF_XOR, R8, R8),
4256 			BPF_JMP_REG(BPF_JEQ, R7, R8, 1),
4257 			BPF_EXIT_INSN(),
4258 			BPF_ALU64_REG(BPF_SUB, R8, R8),
4259 			BPF_ALU64_REG(BPF_XOR, R9, R9),
4260 			BPF_JMP_REG(BPF_JEQ, R9, R8, 1),
4261 			BPF_EXIT_INSN(),
4262 			BPF_ALU64_REG(BPF_SUB, R9, R9),
4263 			BPF_ALU64_REG(BPF_XOR, R0, R0),
4264 			BPF_JMP_REG(BPF_JEQ, R9, R0, 1),
4265 			BPF_EXIT_INSN(),
4266 			BPF_ALU64_REG(BPF_SUB, R1, R1),
4267 			BPF_ALU64_REG(BPF_XOR, R0, R0),
4268 			BPF_JMP_REG(BPF_JEQ, R9, R0, 2),
4269 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
4270 			BPF_EXIT_INSN(),
4271 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
4272 			BPF_EXIT_INSN(),
4273 		},
4274 		INTERNAL,
4275 		{ },
4276 		{ { 0, 1 } }
4277 	},
4278 	{	/* Mainly checking JIT here. */
4279 		"INT: MUL",
4280 		.u.insns_int = {
4281 			BPF_ALU64_IMM(BPF_MOV, R0, 11),
4282 			BPF_ALU64_IMM(BPF_MOV, R1, 1),
4283 			BPF_ALU64_IMM(BPF_MOV, R2, 2),
4284 			BPF_ALU64_IMM(BPF_MOV, R3, 3),
4285 			BPF_ALU64_IMM(BPF_MOV, R4, 4),
4286 			BPF_ALU64_IMM(BPF_MOV, R5, 5),
4287 			BPF_ALU64_IMM(BPF_MOV, R6, 6),
4288 			BPF_ALU64_IMM(BPF_MOV, R7, 7),
4289 			BPF_ALU64_IMM(BPF_MOV, R8, 8),
4290 			BPF_ALU64_IMM(BPF_MOV, R9, 9),
4291 			BPF_ALU64_REG(BPF_MUL, R0, R0),
4292 			BPF_ALU64_REG(BPF_MUL, R0, R1),
4293 			BPF_ALU64_REG(BPF_MUL, R0, R2),
4294 			BPF_ALU64_REG(BPF_MUL, R0, R3),
4295 			BPF_ALU64_REG(BPF_MUL, R0, R4),
4296 			BPF_ALU64_REG(BPF_MUL, R0, R5),
4297 			BPF_ALU64_REG(BPF_MUL, R0, R6),
4298 			BPF_ALU64_REG(BPF_MUL, R0, R7),
4299 			BPF_ALU64_REG(BPF_MUL, R0, R8),
4300 			BPF_ALU64_REG(BPF_MUL, R0, R9),
4301 			BPF_ALU64_IMM(BPF_MUL, R0, 10),
4302 			BPF_JMP_IMM(BPF_JEQ, R0, 439084800, 1),
4303 			BPF_EXIT_INSN(),
4304 			BPF_ALU64_REG(BPF_MUL, R1, R0),
4305 			BPF_ALU64_REG(BPF_MUL, R1, R2),
4306 			BPF_ALU64_REG(BPF_MUL, R1, R3),
4307 			BPF_ALU64_REG(BPF_MUL, R1, R4),
4308 			BPF_ALU64_REG(BPF_MUL, R1, R5),
4309 			BPF_ALU64_REG(BPF_MUL, R1, R6),
4310 			BPF_ALU64_REG(BPF_MUL, R1, R7),
4311 			BPF_ALU64_REG(BPF_MUL, R1, R8),
4312 			BPF_ALU64_REG(BPF_MUL, R1, R9),
4313 			BPF_ALU64_IMM(BPF_MUL, R1, 10),
4314 			BPF_ALU64_REG(BPF_MOV, R2, R1),
4315 			BPF_ALU64_IMM(BPF_RSH, R2, 32),
4316 			BPF_JMP_IMM(BPF_JEQ, R2, 0x5a924, 1),
4317 			BPF_EXIT_INSN(),
4318 			BPF_ALU64_IMM(BPF_LSH, R1, 32),
4319 			BPF_ALU64_IMM(BPF_ARSH, R1, 32),
4320 			BPF_JMP_IMM(BPF_JEQ, R1, 0xebb90000, 1),
4321 			BPF_EXIT_INSN(),
4322 			BPF_ALU64_REG(BPF_MUL, R2, R0),
4323 			BPF_ALU64_REG(BPF_MUL, R2, R1),
4324 			BPF_ALU64_REG(BPF_MUL, R2, R3),
4325 			BPF_ALU64_REG(BPF_MUL, R2, R4),
4326 			BPF_ALU64_REG(BPF_MUL, R2, R5),
4327 			BPF_ALU64_REG(BPF_MUL, R2, R6),
4328 			BPF_ALU64_REG(BPF_MUL, R2, R7),
4329 			BPF_ALU64_REG(BPF_MUL, R2, R8),
4330 			BPF_ALU64_REG(BPF_MUL, R2, R9),
4331 			BPF_ALU64_IMM(BPF_MUL, R2, 10),
4332 			BPF_ALU64_IMM(BPF_RSH, R2, 32),
4333 			BPF_ALU64_REG(BPF_MOV, R0, R2),
4334 			BPF_EXIT_INSN(),
4335 		},
4336 		INTERNAL,
4337 		{ },
4338 		{ { 0, 0x35d97ef2 } }
4339 	},
4340 	{	/* Mainly checking JIT here. */
4341 		"MOV REG64",
4342 		.u.insns_int = {
4343 			BPF_LD_IMM64(R0, 0xffffffffffffffffLL),
4344 			BPF_MOV64_REG(R1, R0),
4345 			BPF_MOV64_REG(R2, R1),
4346 			BPF_MOV64_REG(R3, R2),
4347 			BPF_MOV64_REG(R4, R3),
4348 			BPF_MOV64_REG(R5, R4),
4349 			BPF_MOV64_REG(R6, R5),
4350 			BPF_MOV64_REG(R7, R6),
4351 			BPF_MOV64_REG(R8, R7),
4352 			BPF_MOV64_REG(R9, R8),
4353 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
4354 			BPF_ALU64_IMM(BPF_MOV, R1, 0),
4355 			BPF_ALU64_IMM(BPF_MOV, R2, 0),
4356 			BPF_ALU64_IMM(BPF_MOV, R3, 0),
4357 			BPF_ALU64_IMM(BPF_MOV, R4, 0),
4358 			BPF_ALU64_IMM(BPF_MOV, R5, 0),
4359 			BPF_ALU64_IMM(BPF_MOV, R6, 0),
4360 			BPF_ALU64_IMM(BPF_MOV, R7, 0),
4361 			BPF_ALU64_IMM(BPF_MOV, R8, 0),
4362 			BPF_ALU64_IMM(BPF_MOV, R9, 0),
4363 			BPF_ALU64_REG(BPF_ADD, R0, R0),
4364 			BPF_ALU64_REG(BPF_ADD, R0, R1),
4365 			BPF_ALU64_REG(BPF_ADD, R0, R2),
4366 			BPF_ALU64_REG(BPF_ADD, R0, R3),
4367 			BPF_ALU64_REG(BPF_ADD, R0, R4),
4368 			BPF_ALU64_REG(BPF_ADD, R0, R5),
4369 			BPF_ALU64_REG(BPF_ADD, R0, R6),
4370 			BPF_ALU64_REG(BPF_ADD, R0, R7),
4371 			BPF_ALU64_REG(BPF_ADD, R0, R8),
4372 			BPF_ALU64_REG(BPF_ADD, R0, R9),
4373 			BPF_ALU64_IMM(BPF_ADD, R0, 0xfefe),
4374 			BPF_EXIT_INSN(),
4375 		},
4376 		INTERNAL,
4377 		{ },
4378 		{ { 0, 0xfefe } }
4379 	},
4380 	{	/* Mainly checking JIT here. */
4381 		"MOV REG32",
4382 		.u.insns_int = {
4383 			BPF_LD_IMM64(R0, 0xffffffffffffffffLL),
4384 			BPF_MOV64_REG(R1, R0),
4385 			BPF_MOV64_REG(R2, R1),
4386 			BPF_MOV64_REG(R3, R2),
4387 			BPF_MOV64_REG(R4, R3),
4388 			BPF_MOV64_REG(R5, R4),
4389 			BPF_MOV64_REG(R6, R5),
4390 			BPF_MOV64_REG(R7, R6),
4391 			BPF_MOV64_REG(R8, R7),
4392 			BPF_MOV64_REG(R9, R8),
4393 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4394 			BPF_ALU32_IMM(BPF_MOV, R1, 0),
4395 			BPF_ALU32_IMM(BPF_MOV, R2, 0),
4396 			BPF_ALU32_IMM(BPF_MOV, R3, 0),
4397 			BPF_ALU32_IMM(BPF_MOV, R4, 0),
4398 			BPF_ALU32_IMM(BPF_MOV, R5, 0),
4399 			BPF_ALU32_IMM(BPF_MOV, R6, 0),
4400 			BPF_ALU32_IMM(BPF_MOV, R7, 0),
4401 			BPF_ALU32_IMM(BPF_MOV, R8, 0),
4402 			BPF_ALU32_IMM(BPF_MOV, R9, 0),
4403 			BPF_ALU64_REG(BPF_ADD, R0, R0),
4404 			BPF_ALU64_REG(BPF_ADD, R0, R1),
4405 			BPF_ALU64_REG(BPF_ADD, R0, R2),
4406 			BPF_ALU64_REG(BPF_ADD, R0, R3),
4407 			BPF_ALU64_REG(BPF_ADD, R0, R4),
4408 			BPF_ALU64_REG(BPF_ADD, R0, R5),
4409 			BPF_ALU64_REG(BPF_ADD, R0, R6),
4410 			BPF_ALU64_REG(BPF_ADD, R0, R7),
4411 			BPF_ALU64_REG(BPF_ADD, R0, R8),
4412 			BPF_ALU64_REG(BPF_ADD, R0, R9),
4413 			BPF_ALU64_IMM(BPF_ADD, R0, 0xfefe),
4414 			BPF_EXIT_INSN(),
4415 		},
4416 		INTERNAL,
4417 		{ },
4418 		{ { 0, 0xfefe } }
4419 	},
4420 	{	/* Mainly checking JIT here. */
4421 		"LD IMM64",
4422 		.u.insns_int = {
4423 			BPF_LD_IMM64(R0, 0xffffffffffffffffLL),
4424 			BPF_MOV64_REG(R1, R0),
4425 			BPF_MOV64_REG(R2, R1),
4426 			BPF_MOV64_REG(R3, R2),
4427 			BPF_MOV64_REG(R4, R3),
4428 			BPF_MOV64_REG(R5, R4),
4429 			BPF_MOV64_REG(R6, R5),
4430 			BPF_MOV64_REG(R7, R6),
4431 			BPF_MOV64_REG(R8, R7),
4432 			BPF_MOV64_REG(R9, R8),
4433 			BPF_LD_IMM64(R0, 0x0LL),
4434 			BPF_LD_IMM64(R1, 0x0LL),
4435 			BPF_LD_IMM64(R2, 0x0LL),
4436 			BPF_LD_IMM64(R3, 0x0LL),
4437 			BPF_LD_IMM64(R4, 0x0LL),
4438 			BPF_LD_IMM64(R5, 0x0LL),
4439 			BPF_LD_IMM64(R6, 0x0LL),
4440 			BPF_LD_IMM64(R7, 0x0LL),
4441 			BPF_LD_IMM64(R8, 0x0LL),
4442 			BPF_LD_IMM64(R9, 0x0LL),
4443 			BPF_ALU64_REG(BPF_ADD, R0, R0),
4444 			BPF_ALU64_REG(BPF_ADD, R0, R1),
4445 			BPF_ALU64_REG(BPF_ADD, R0, R2),
4446 			BPF_ALU64_REG(BPF_ADD, R0, R3),
4447 			BPF_ALU64_REG(BPF_ADD, R0, R4),
4448 			BPF_ALU64_REG(BPF_ADD, R0, R5),
4449 			BPF_ALU64_REG(BPF_ADD, R0, R6),
4450 			BPF_ALU64_REG(BPF_ADD, R0, R7),
4451 			BPF_ALU64_REG(BPF_ADD, R0, R8),
4452 			BPF_ALU64_REG(BPF_ADD, R0, R9),
4453 			BPF_ALU64_IMM(BPF_ADD, R0, 0xfefe),
4454 			BPF_EXIT_INSN(),
4455 		},
4456 		INTERNAL,
4457 		{ },
4458 		{ { 0, 0xfefe } }
4459 	},
4460 	{
4461 		"INT: ALU MIX",
4462 		.u.insns_int = {
4463 			BPF_ALU64_IMM(BPF_MOV, R0, 11),
4464 			BPF_ALU64_IMM(BPF_ADD, R0, -1),
4465 			BPF_ALU64_IMM(BPF_MOV, R2, 2),
4466 			BPF_ALU64_IMM(BPF_XOR, R2, 3),
4467 			BPF_ALU64_REG(BPF_DIV, R0, R2),
4468 			BPF_JMP_IMM(BPF_JEQ, R0, 10, 1),
4469 			BPF_EXIT_INSN(),
4470 			BPF_ALU64_IMM(BPF_MOD, R0, 3),
4471 			BPF_JMP_IMM(BPF_JEQ, R0, 1, 1),
4472 			BPF_EXIT_INSN(),
4473 			BPF_ALU64_IMM(BPF_MOV, R0, -1),
4474 			BPF_EXIT_INSN(),
4475 		},
4476 		INTERNAL,
4477 		{ },
4478 		{ { 0, -1 } }
4479 	},
4480 	{
4481 		"INT: shifts by register",
4482 		.u.insns_int = {
4483 			BPF_MOV64_IMM(R0, -1234),
4484 			BPF_MOV64_IMM(R1, 1),
4485 			BPF_ALU32_REG(BPF_RSH, R0, R1),
4486 			BPF_JMP_IMM(BPF_JEQ, R0, 0x7ffffd97, 1),
4487 			BPF_EXIT_INSN(),
4488 			BPF_MOV64_IMM(R2, 1),
4489 			BPF_ALU64_REG(BPF_LSH, R0, R2),
4490 			BPF_MOV32_IMM(R4, -1234),
4491 			BPF_JMP_REG(BPF_JEQ, R0, R4, 1),
4492 			BPF_EXIT_INSN(),
4493 			BPF_ALU64_IMM(BPF_AND, R4, 63),
4494 			BPF_ALU64_REG(BPF_LSH, R0, R4), /* R0 <= 46 */
4495 			BPF_MOV64_IMM(R3, 47),
4496 			BPF_ALU64_REG(BPF_ARSH, R0, R3),
4497 			BPF_JMP_IMM(BPF_JEQ, R0, -617, 1),
4498 			BPF_EXIT_INSN(),
4499 			BPF_MOV64_IMM(R2, 1),
4500 			BPF_ALU64_REG(BPF_LSH, R4, R2), /* R4 = 46 << 1 */
4501 			BPF_JMP_IMM(BPF_JEQ, R4, 92, 1),
4502 			BPF_EXIT_INSN(),
4503 			BPF_MOV64_IMM(R4, 4),
4504 			BPF_ALU64_REG(BPF_LSH, R4, R4), /* R4 = 4 << 4 */
4505 			BPF_JMP_IMM(BPF_JEQ, R4, 64, 1),
4506 			BPF_EXIT_INSN(),
4507 			BPF_MOV64_IMM(R4, 5),
4508 			BPF_ALU32_REG(BPF_LSH, R4, R4), /* R4 = 5 << 5 */
4509 			BPF_JMP_IMM(BPF_JEQ, R4, 160, 1),
4510 			BPF_EXIT_INSN(),
4511 			BPF_MOV64_IMM(R0, -1),
4512 			BPF_EXIT_INSN(),
4513 		},
4514 		INTERNAL,
4515 		{ },
4516 		{ { 0, -1 } }
4517 	},
4518 #ifdef CONFIG_32BIT
4519 	{
4520 		"INT: 32-bit context pointer word order and zero-extension",
4521 		.u.insns_int = {
4522 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
4523 			BPF_JMP32_IMM(BPF_JEQ, R1, 0, 3),
4524 			BPF_ALU64_IMM(BPF_RSH, R1, 32),
4525 			BPF_JMP32_IMM(BPF_JNE, R1, 0, 1),
4526 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
4527 			BPF_EXIT_INSN(),
4528 		},
4529 		INTERNAL,
4530 		{ },
4531 		{ { 0, 1 } }
4532 	},
4533 #endif
4534 	{
4535 		"check: missing ret",
4536 		.u.insns = {
4537 			BPF_STMT(BPF_LD | BPF_IMM, 1),
4538 		},
4539 		CLASSIC | FLAG_NO_DATA | FLAG_EXPECTED_FAIL,
4540 		{ },
4541 		{ },
4542 		.fill_helper = NULL,
4543 		.expected_errcode = -EINVAL,
4544 	},
4545 	{
4546 		"check: div_k_0",
4547 		.u.insns = {
4548 			BPF_STMT(BPF_ALU | BPF_DIV | BPF_K, 0),
4549 			BPF_STMT(BPF_RET | BPF_K, 0)
4550 		},
4551 		CLASSIC | FLAG_NO_DATA | FLAG_EXPECTED_FAIL,
4552 		{ },
4553 		{ },
4554 		.fill_helper = NULL,
4555 		.expected_errcode = -EINVAL,
4556 	},
4557 	{
4558 		"check: unknown insn",
4559 		.u.insns = {
4560 			/* seccomp insn, rejected in socket filter */
4561 			BPF_STMT(BPF_LDX | BPF_W | BPF_ABS, 0),
4562 			BPF_STMT(BPF_RET | BPF_K, 0)
4563 		},
4564 		CLASSIC | FLAG_EXPECTED_FAIL,
4565 		{ },
4566 		{ },
4567 		.fill_helper = NULL,
4568 		.expected_errcode = -EINVAL,
4569 	},
4570 	{
4571 		"check: out of range spill/fill",
4572 		.u.insns = {
4573 			BPF_STMT(BPF_STX, 16),
4574 			BPF_STMT(BPF_RET | BPF_K, 0)
4575 		},
4576 		CLASSIC | FLAG_NO_DATA | FLAG_EXPECTED_FAIL,
4577 		{ },
4578 		{ },
4579 		.fill_helper = NULL,
4580 		.expected_errcode = -EINVAL,
4581 	},
4582 	{
4583 		"JUMPS + HOLES",
4584 		.u.insns = {
4585 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4586 			BPF_JUMP(BPF_JMP | BPF_JGE, 0, 13, 15),
4587 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4588 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4589 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4590 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4591 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4592 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4593 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4594 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4595 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4596 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4597 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4598 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4599 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4600 			BPF_JUMP(BPF_JMP | BPF_JEQ, 0x90c2894d, 3, 4),
4601 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4602 			BPF_JUMP(BPF_JMP | BPF_JEQ, 0x90c2894d, 1, 2),
4603 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4604 			BPF_JUMP(BPF_JMP | BPF_JGE, 0, 14, 15),
4605 			BPF_JUMP(BPF_JMP | BPF_JGE, 0, 13, 14),
4606 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4607 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4608 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4609 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4610 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4611 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4612 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4613 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4614 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4615 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4616 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4617 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4618 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4619 			BPF_JUMP(BPF_JMP | BPF_JEQ, 0x2ac28349, 2, 3),
4620 			BPF_JUMP(BPF_JMP | BPF_JEQ, 0x2ac28349, 1, 2),
4621 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4622 			BPF_JUMP(BPF_JMP | BPF_JGE, 0, 14, 15),
4623 			BPF_JUMP(BPF_JMP | BPF_JGE, 0, 13, 14),
4624 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4625 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4626 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4627 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4628 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4629 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4630 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4631 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4632 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4633 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4634 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4635 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4636 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4637 			BPF_JUMP(BPF_JMP | BPF_JEQ, 0x90d2ff41, 2, 3),
4638 			BPF_JUMP(BPF_JMP | BPF_JEQ, 0x90d2ff41, 1, 2),
4639 			BPF_STMT(BPF_LD | BPF_H | BPF_ABS, 0),
4640 			BPF_STMT(BPF_RET | BPF_A, 0),
4641 			BPF_STMT(BPF_RET | BPF_A, 0),
4642 		},
4643 		CLASSIC,
4644 		{ 0x00, 0x1b, 0x21, 0x3c, 0x9d, 0xf8,
4645 		  0x90, 0xe2, 0xba, 0x0a, 0x56, 0xb4,
4646 		  0x08, 0x00,
4647 		  0x45, 0x00, 0x00, 0x28, 0x00, 0x00,
4648 		  0x20, 0x00, 0x40, 0x11, 0x00, 0x00, /* IP header */
4649 		  0xc0, 0xa8, 0x33, 0x01,
4650 		  0xc0, 0xa8, 0x33, 0x02,
4651 		  0xbb, 0xb6,
4652 		  0xa9, 0xfa,
4653 		  0x00, 0x14, 0x00, 0x00,
4654 		  0xcc, 0xcc, 0xcc, 0xcc, 0xcc, 0xcc,
4655 		  0xcc, 0xcc, 0xcc, 0xcc, 0xcc, 0xcc,
4656 		  0xcc, 0xcc, 0xcc, 0xcc, 0xcc, 0xcc,
4657 		  0xcc, 0xcc, 0xcc, 0xcc, 0xcc, 0xcc,
4658 		  0xcc, 0xcc, 0xcc, 0xcc, 0xcc, 0xcc,
4659 		  0xcc, 0xcc, 0xcc, 0xcc, 0xcc, 0xcc,
4660 		  0xcc, 0xcc, 0xcc, 0xcc, 0xcc, 0xcc,
4661 		  0xcc, 0xcc, 0xcc, 0xcc },
4662 		{ { 88, 0x001b } }
4663 	},
4664 	{
4665 		"check: RET X",
4666 		.u.insns = {
4667 			BPF_STMT(BPF_RET | BPF_X, 0),
4668 		},
4669 		CLASSIC | FLAG_NO_DATA | FLAG_EXPECTED_FAIL,
4670 		{ },
4671 		{ },
4672 		.fill_helper = NULL,
4673 		.expected_errcode = -EINVAL,
4674 	},
4675 	{
4676 		"check: LDX + RET X",
4677 		.u.insns = {
4678 			BPF_STMT(BPF_LDX | BPF_IMM, 42),
4679 			BPF_STMT(BPF_RET | BPF_X, 0),
4680 		},
4681 		CLASSIC | FLAG_NO_DATA | FLAG_EXPECTED_FAIL,
4682 		{ },
4683 		{ },
4684 		.fill_helper = NULL,
4685 		.expected_errcode = -EINVAL,
4686 	},
4687 	{	/* Mainly checking JIT here. */
4688 		"M[]: alt STX + LDX",
4689 		.u.insns = {
4690 			BPF_STMT(BPF_LDX | BPF_IMM, 100),
4691 			BPF_STMT(BPF_STX, 0),
4692 			BPF_STMT(BPF_LDX | BPF_MEM, 0),
4693 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4694 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4695 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4696 			BPF_STMT(BPF_STX, 1),
4697 			BPF_STMT(BPF_LDX | BPF_MEM, 1),
4698 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4699 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4700 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4701 			BPF_STMT(BPF_STX, 2),
4702 			BPF_STMT(BPF_LDX | BPF_MEM, 2),
4703 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4704 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4705 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4706 			BPF_STMT(BPF_STX, 3),
4707 			BPF_STMT(BPF_LDX | BPF_MEM, 3),
4708 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4709 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4710 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4711 			BPF_STMT(BPF_STX, 4),
4712 			BPF_STMT(BPF_LDX | BPF_MEM, 4),
4713 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4714 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4715 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4716 			BPF_STMT(BPF_STX, 5),
4717 			BPF_STMT(BPF_LDX | BPF_MEM, 5),
4718 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4719 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4720 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4721 			BPF_STMT(BPF_STX, 6),
4722 			BPF_STMT(BPF_LDX | BPF_MEM, 6),
4723 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4724 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4725 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4726 			BPF_STMT(BPF_STX, 7),
4727 			BPF_STMT(BPF_LDX | BPF_MEM, 7),
4728 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4729 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4730 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4731 			BPF_STMT(BPF_STX, 8),
4732 			BPF_STMT(BPF_LDX | BPF_MEM, 8),
4733 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4734 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4735 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4736 			BPF_STMT(BPF_STX, 9),
4737 			BPF_STMT(BPF_LDX | BPF_MEM, 9),
4738 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4739 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4740 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4741 			BPF_STMT(BPF_STX, 10),
4742 			BPF_STMT(BPF_LDX | BPF_MEM, 10),
4743 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4744 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4745 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4746 			BPF_STMT(BPF_STX, 11),
4747 			BPF_STMT(BPF_LDX | BPF_MEM, 11),
4748 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4749 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4750 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4751 			BPF_STMT(BPF_STX, 12),
4752 			BPF_STMT(BPF_LDX | BPF_MEM, 12),
4753 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4754 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4755 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4756 			BPF_STMT(BPF_STX, 13),
4757 			BPF_STMT(BPF_LDX | BPF_MEM, 13),
4758 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4759 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4760 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4761 			BPF_STMT(BPF_STX, 14),
4762 			BPF_STMT(BPF_LDX | BPF_MEM, 14),
4763 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4764 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4765 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4766 			BPF_STMT(BPF_STX, 15),
4767 			BPF_STMT(BPF_LDX | BPF_MEM, 15),
4768 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4769 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 1),
4770 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
4771 			BPF_STMT(BPF_RET | BPF_A, 0),
4772 		},
4773 		CLASSIC | FLAG_NO_DATA,
4774 		{ },
4775 		{ { 0, 116 } },
4776 	},
4777 	{	/* Mainly checking JIT here. */
4778 		"M[]: full STX + full LDX",
4779 		.u.insns = {
4780 			BPF_STMT(BPF_LDX | BPF_IMM, 0xbadfeedb),
4781 			BPF_STMT(BPF_STX, 0),
4782 			BPF_STMT(BPF_LDX | BPF_IMM, 0xecabedae),
4783 			BPF_STMT(BPF_STX, 1),
4784 			BPF_STMT(BPF_LDX | BPF_IMM, 0xafccfeaf),
4785 			BPF_STMT(BPF_STX, 2),
4786 			BPF_STMT(BPF_LDX | BPF_IMM, 0xbffdcedc),
4787 			BPF_STMT(BPF_STX, 3),
4788 			BPF_STMT(BPF_LDX | BPF_IMM, 0xfbbbdccb),
4789 			BPF_STMT(BPF_STX, 4),
4790 			BPF_STMT(BPF_LDX | BPF_IMM, 0xfbabcbda),
4791 			BPF_STMT(BPF_STX, 5),
4792 			BPF_STMT(BPF_LDX | BPF_IMM, 0xaedecbdb),
4793 			BPF_STMT(BPF_STX, 6),
4794 			BPF_STMT(BPF_LDX | BPF_IMM, 0xadebbade),
4795 			BPF_STMT(BPF_STX, 7),
4796 			BPF_STMT(BPF_LDX | BPF_IMM, 0xfcfcfaec),
4797 			BPF_STMT(BPF_STX, 8),
4798 			BPF_STMT(BPF_LDX | BPF_IMM, 0xbcdddbdc),
4799 			BPF_STMT(BPF_STX, 9),
4800 			BPF_STMT(BPF_LDX | BPF_IMM, 0xfeefdfac),
4801 			BPF_STMT(BPF_STX, 10),
4802 			BPF_STMT(BPF_LDX | BPF_IMM, 0xcddcdeea),
4803 			BPF_STMT(BPF_STX, 11),
4804 			BPF_STMT(BPF_LDX | BPF_IMM, 0xaccfaebb),
4805 			BPF_STMT(BPF_STX, 12),
4806 			BPF_STMT(BPF_LDX | BPF_IMM, 0xbdcccdcf),
4807 			BPF_STMT(BPF_STX, 13),
4808 			BPF_STMT(BPF_LDX | BPF_IMM, 0xaaedecde),
4809 			BPF_STMT(BPF_STX, 14),
4810 			BPF_STMT(BPF_LDX | BPF_IMM, 0xfaeacdad),
4811 			BPF_STMT(BPF_STX, 15),
4812 			BPF_STMT(BPF_LDX | BPF_MEM, 0),
4813 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
4814 			BPF_STMT(BPF_LDX | BPF_MEM, 1),
4815 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
4816 			BPF_STMT(BPF_LDX | BPF_MEM, 2),
4817 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
4818 			BPF_STMT(BPF_LDX | BPF_MEM, 3),
4819 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
4820 			BPF_STMT(BPF_LDX | BPF_MEM, 4),
4821 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
4822 			BPF_STMT(BPF_LDX | BPF_MEM, 5),
4823 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
4824 			BPF_STMT(BPF_LDX | BPF_MEM, 6),
4825 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
4826 			BPF_STMT(BPF_LDX | BPF_MEM, 7),
4827 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
4828 			BPF_STMT(BPF_LDX | BPF_MEM, 8),
4829 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
4830 			BPF_STMT(BPF_LDX | BPF_MEM, 9),
4831 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
4832 			BPF_STMT(BPF_LDX | BPF_MEM, 10),
4833 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
4834 			BPF_STMT(BPF_LDX | BPF_MEM, 11),
4835 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
4836 			BPF_STMT(BPF_LDX | BPF_MEM, 12),
4837 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
4838 			BPF_STMT(BPF_LDX | BPF_MEM, 13),
4839 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
4840 			BPF_STMT(BPF_LDX | BPF_MEM, 14),
4841 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
4842 			BPF_STMT(BPF_LDX | BPF_MEM, 15),
4843 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
4844 			BPF_STMT(BPF_RET | BPF_A, 0),
4845 		},
4846 		CLASSIC | FLAG_NO_DATA,
4847 		{ },
4848 		{ { 0, 0x2a5a5e5 } },
4849 	},
4850 	{
4851 		"check: SKF_AD_MAX",
4852 		.u.insns = {
4853 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
4854 				 SKF_AD_OFF + SKF_AD_MAX),
4855 			BPF_STMT(BPF_RET | BPF_A, 0),
4856 		},
4857 		CLASSIC | FLAG_NO_DATA | FLAG_EXPECTED_FAIL,
4858 		{ },
4859 		{ },
4860 		.fill_helper = NULL,
4861 		.expected_errcode = -EINVAL,
4862 	},
4863 	{	/* Passes checker but fails during runtime. */
4864 		"LD [SKF_AD_OFF-1]",
4865 		.u.insns = {
4866 			BPF_STMT(BPF_LD | BPF_W | BPF_ABS,
4867 				 SKF_AD_OFF - 1),
4868 			BPF_STMT(BPF_RET | BPF_K, 1),
4869 		},
4870 		CLASSIC,
4871 		{ },
4872 		{ { 1, 0 } },
4873 	},
4874 	{
4875 		"load 64-bit immediate",
4876 		.u.insns_int = {
4877 			BPF_LD_IMM64(R1, 0x567800001234LL),
4878 			BPF_MOV64_REG(R2, R1),
4879 			BPF_MOV64_REG(R3, R2),
4880 			BPF_ALU64_IMM(BPF_RSH, R2, 32),
4881 			BPF_ALU64_IMM(BPF_LSH, R3, 32),
4882 			BPF_ALU64_IMM(BPF_RSH, R3, 32),
4883 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
4884 			BPF_JMP_IMM(BPF_JEQ, R2, 0x5678, 1),
4885 			BPF_EXIT_INSN(),
4886 			BPF_JMP_IMM(BPF_JEQ, R3, 0x1234, 1),
4887 			BPF_EXIT_INSN(),
4888 			BPF_LD_IMM64(R0, 0x1ffffffffLL),
4889 			BPF_ALU64_IMM(BPF_RSH, R0, 32), /* R0 = 1 */
4890 			BPF_EXIT_INSN(),
4891 		},
4892 		INTERNAL,
4893 		{ },
4894 		{ { 0, 1 } }
4895 	},
4896 	/* BPF_ALU | BPF_MOV | BPF_X */
4897 	{
4898 		"ALU_MOV_X: dst = 2",
4899 		.u.insns_int = {
4900 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
4901 			BPF_ALU32_REG(BPF_MOV, R0, R1),
4902 			BPF_EXIT_INSN(),
4903 		},
4904 		INTERNAL,
4905 		{ },
4906 		{ { 0, 2 } },
4907 	},
4908 	{
4909 		"ALU_MOV_X: dst = 4294967295",
4910 		.u.insns_int = {
4911 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967295U),
4912 			BPF_ALU32_REG(BPF_MOV, R0, R1),
4913 			BPF_EXIT_INSN(),
4914 		},
4915 		INTERNAL,
4916 		{ },
4917 		{ { 0, 4294967295U } },
4918 	},
4919 	{
4920 		"ALU64_MOV_X: dst = 2",
4921 		.u.insns_int = {
4922 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
4923 			BPF_ALU64_REG(BPF_MOV, R0, R1),
4924 			BPF_EXIT_INSN(),
4925 		},
4926 		INTERNAL,
4927 		{ },
4928 		{ { 0, 2 } },
4929 	},
4930 	{
4931 		"ALU64_MOV_X: dst = 4294967295",
4932 		.u.insns_int = {
4933 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967295U),
4934 			BPF_ALU64_REG(BPF_MOV, R0, R1),
4935 			BPF_EXIT_INSN(),
4936 		},
4937 		INTERNAL,
4938 		{ },
4939 		{ { 0, 4294967295U } },
4940 	},
4941 	/* BPF_ALU | BPF_MOV | BPF_K */
4942 	{
4943 		"ALU_MOV_K: dst = 2",
4944 		.u.insns_int = {
4945 			BPF_ALU32_IMM(BPF_MOV, R0, 2),
4946 			BPF_EXIT_INSN(),
4947 		},
4948 		INTERNAL,
4949 		{ },
4950 		{ { 0, 2 } },
4951 	},
4952 	{
4953 		"ALU_MOV_K: dst = 4294967295",
4954 		.u.insns_int = {
4955 			BPF_ALU32_IMM(BPF_MOV, R0, 4294967295U),
4956 			BPF_EXIT_INSN(),
4957 		},
4958 		INTERNAL,
4959 		{ },
4960 		{ { 0, 4294967295U } },
4961 	},
4962 	{
4963 		"ALU_MOV_K: 0x0000ffffffff0000 = 0x00000000ffffffff",
4964 		.u.insns_int = {
4965 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
4966 			BPF_LD_IMM64(R3, 0x00000000ffffffffLL),
4967 			BPF_ALU32_IMM(BPF_MOV, R2, 0xffffffff),
4968 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
4969 			BPF_MOV32_IMM(R0, 2),
4970 			BPF_EXIT_INSN(),
4971 			BPF_MOV32_IMM(R0, 1),
4972 			BPF_EXIT_INSN(),
4973 		},
4974 		INTERNAL,
4975 		{ },
4976 		{ { 0, 0x1 } },
4977 	},
4978 	{
4979 		"ALU_MOV_K: small negative",
4980 		.u.insns_int = {
4981 			BPF_ALU32_IMM(BPF_MOV, R0, -123),
4982 			BPF_EXIT_INSN(),
4983 		},
4984 		INTERNAL,
4985 		{ },
4986 		{ { 0, -123 } }
4987 	},
4988 	{
4989 		"ALU_MOV_K: small negative zero extension",
4990 		.u.insns_int = {
4991 			BPF_ALU32_IMM(BPF_MOV, R0, -123),
4992 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
4993 			BPF_EXIT_INSN(),
4994 		},
4995 		INTERNAL,
4996 		{ },
4997 		{ { 0, 0 } }
4998 	},
4999 	{
5000 		"ALU_MOV_K: large negative",
5001 		.u.insns_int = {
5002 			BPF_ALU32_IMM(BPF_MOV, R0, -123456789),
5003 			BPF_EXIT_INSN(),
5004 		},
5005 		INTERNAL,
5006 		{ },
5007 		{ { 0, -123456789 } }
5008 	},
5009 	{
5010 		"ALU_MOV_K: large negative zero extension",
5011 		.u.insns_int = {
5012 			BPF_ALU32_IMM(BPF_MOV, R0, -123456789),
5013 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
5014 			BPF_EXIT_INSN(),
5015 		},
5016 		INTERNAL,
5017 		{ },
5018 		{ { 0, 0 } }
5019 	},
5020 	{
5021 		"ALU64_MOV_K: dst = 2",
5022 		.u.insns_int = {
5023 			BPF_ALU64_IMM(BPF_MOV, R0, 2),
5024 			BPF_EXIT_INSN(),
5025 		},
5026 		INTERNAL,
5027 		{ },
5028 		{ { 0, 2 } },
5029 	},
5030 	{
5031 		"ALU64_MOV_K: dst = 2147483647",
5032 		.u.insns_int = {
5033 			BPF_ALU64_IMM(BPF_MOV, R0, 2147483647),
5034 			BPF_EXIT_INSN(),
5035 		},
5036 		INTERNAL,
5037 		{ },
5038 		{ { 0, 2147483647 } },
5039 	},
5040 	{
5041 		"ALU64_OR_K: dst = 0x0",
5042 		.u.insns_int = {
5043 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
5044 			BPF_LD_IMM64(R3, 0x0),
5045 			BPF_ALU64_IMM(BPF_MOV, R2, 0x0),
5046 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5047 			BPF_MOV32_IMM(R0, 2),
5048 			BPF_EXIT_INSN(),
5049 			BPF_MOV32_IMM(R0, 1),
5050 			BPF_EXIT_INSN(),
5051 		},
5052 		INTERNAL,
5053 		{ },
5054 		{ { 0, 0x1 } },
5055 	},
5056 	{
5057 		"ALU64_MOV_K: dst = -1",
5058 		.u.insns_int = {
5059 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
5060 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
5061 			BPF_ALU64_IMM(BPF_MOV, R2, 0xffffffff),
5062 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5063 			BPF_MOV32_IMM(R0, 2),
5064 			BPF_EXIT_INSN(),
5065 			BPF_MOV32_IMM(R0, 1),
5066 			BPF_EXIT_INSN(),
5067 		},
5068 		INTERNAL,
5069 		{ },
5070 		{ { 0, 0x1 } },
5071 	},
5072 	{
5073 		"ALU64_MOV_K: small negative",
5074 		.u.insns_int = {
5075 			BPF_ALU64_IMM(BPF_MOV, R0, -123),
5076 			BPF_EXIT_INSN(),
5077 		},
5078 		INTERNAL,
5079 		{ },
5080 		{ { 0, -123 } }
5081 	},
5082 	{
5083 		"ALU64_MOV_K: small negative sign extension",
5084 		.u.insns_int = {
5085 			BPF_ALU64_IMM(BPF_MOV, R0, -123),
5086 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
5087 			BPF_EXIT_INSN(),
5088 		},
5089 		INTERNAL,
5090 		{ },
5091 		{ { 0, 0xffffffff } }
5092 	},
5093 	{
5094 		"ALU64_MOV_K: large negative",
5095 		.u.insns_int = {
5096 			BPF_ALU64_IMM(BPF_MOV, R0, -123456789),
5097 			BPF_EXIT_INSN(),
5098 		},
5099 		INTERNAL,
5100 		{ },
5101 		{ { 0, -123456789 } }
5102 	},
5103 	{
5104 		"ALU64_MOV_K: large negative sign extension",
5105 		.u.insns_int = {
5106 			BPF_ALU64_IMM(BPF_MOV, R0, -123456789),
5107 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
5108 			BPF_EXIT_INSN(),
5109 		},
5110 		INTERNAL,
5111 		{ },
5112 		{ { 0, 0xffffffff } }
5113 	},
5114 	/* BPF_ALU | BPF_ADD | BPF_X */
5115 	{
5116 		"ALU_ADD_X: 1 + 2 = 3",
5117 		.u.insns_int = {
5118 			BPF_LD_IMM64(R0, 1),
5119 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
5120 			BPF_ALU32_REG(BPF_ADD, R0, R1),
5121 			BPF_EXIT_INSN(),
5122 		},
5123 		INTERNAL,
5124 		{ },
5125 		{ { 0, 3 } },
5126 	},
5127 	{
5128 		"ALU_ADD_X: 1 + 4294967294 = 4294967295",
5129 		.u.insns_int = {
5130 			BPF_LD_IMM64(R0, 1),
5131 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967294U),
5132 			BPF_ALU32_REG(BPF_ADD, R0, R1),
5133 			BPF_EXIT_INSN(),
5134 		},
5135 		INTERNAL,
5136 		{ },
5137 		{ { 0, 4294967295U } },
5138 	},
5139 	{
5140 		"ALU_ADD_X: 2 + 4294967294 = 0",
5141 		.u.insns_int = {
5142 			BPF_LD_IMM64(R0, 2),
5143 			BPF_LD_IMM64(R1, 4294967294U),
5144 			BPF_ALU32_REG(BPF_ADD, R0, R1),
5145 			BPF_JMP_IMM(BPF_JEQ, R0, 0, 2),
5146 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5147 			BPF_EXIT_INSN(),
5148 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5149 			BPF_EXIT_INSN(),
5150 		},
5151 		INTERNAL,
5152 		{ },
5153 		{ { 0, 1 } },
5154 	},
5155 	{
5156 		"ALU64_ADD_X: 1 + 2 = 3",
5157 		.u.insns_int = {
5158 			BPF_LD_IMM64(R0, 1),
5159 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
5160 			BPF_ALU64_REG(BPF_ADD, R0, R1),
5161 			BPF_EXIT_INSN(),
5162 		},
5163 		INTERNAL,
5164 		{ },
5165 		{ { 0, 3 } },
5166 	},
5167 	{
5168 		"ALU64_ADD_X: 1 + 4294967294 = 4294967295",
5169 		.u.insns_int = {
5170 			BPF_LD_IMM64(R0, 1),
5171 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967294U),
5172 			BPF_ALU64_REG(BPF_ADD, R0, R1),
5173 			BPF_EXIT_INSN(),
5174 		},
5175 		INTERNAL,
5176 		{ },
5177 		{ { 0, 4294967295U } },
5178 	},
5179 	{
5180 		"ALU64_ADD_X: 2 + 4294967294 = 4294967296",
5181 		.u.insns_int = {
5182 			BPF_LD_IMM64(R0, 2),
5183 			BPF_LD_IMM64(R1, 4294967294U),
5184 			BPF_LD_IMM64(R2, 4294967296ULL),
5185 			BPF_ALU64_REG(BPF_ADD, R0, R1),
5186 			BPF_JMP_REG(BPF_JEQ, R0, R2, 2),
5187 			BPF_MOV32_IMM(R0, 0),
5188 			BPF_EXIT_INSN(),
5189 			BPF_MOV32_IMM(R0, 1),
5190 			BPF_EXIT_INSN(),
5191 		},
5192 		INTERNAL,
5193 		{ },
5194 		{ { 0, 1 } },
5195 	},
5196 	/* BPF_ALU | BPF_ADD | BPF_K */
5197 	{
5198 		"ALU_ADD_K: 1 + 2 = 3",
5199 		.u.insns_int = {
5200 			BPF_LD_IMM64(R0, 1),
5201 			BPF_ALU32_IMM(BPF_ADD, R0, 2),
5202 			BPF_EXIT_INSN(),
5203 		},
5204 		INTERNAL,
5205 		{ },
5206 		{ { 0, 3 } },
5207 	},
5208 	{
5209 		"ALU_ADD_K: 3 + 0 = 3",
5210 		.u.insns_int = {
5211 			BPF_LD_IMM64(R0, 3),
5212 			BPF_ALU32_IMM(BPF_ADD, R0, 0),
5213 			BPF_EXIT_INSN(),
5214 		},
5215 		INTERNAL,
5216 		{ },
5217 		{ { 0, 3 } },
5218 	},
5219 	{
5220 		"ALU_ADD_K: 1 + 4294967294 = 4294967295",
5221 		.u.insns_int = {
5222 			BPF_LD_IMM64(R0, 1),
5223 			BPF_ALU32_IMM(BPF_ADD, R0, 4294967294U),
5224 			BPF_EXIT_INSN(),
5225 		},
5226 		INTERNAL,
5227 		{ },
5228 		{ { 0, 4294967295U } },
5229 	},
5230 	{
5231 		"ALU_ADD_K: 4294967294 + 2 = 0",
5232 		.u.insns_int = {
5233 			BPF_LD_IMM64(R0, 4294967294U),
5234 			BPF_ALU32_IMM(BPF_ADD, R0, 2),
5235 			BPF_JMP_IMM(BPF_JEQ, R0, 0, 2),
5236 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5237 			BPF_EXIT_INSN(),
5238 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5239 			BPF_EXIT_INSN(),
5240 		},
5241 		INTERNAL,
5242 		{ },
5243 		{ { 0, 1 } },
5244 	},
5245 	{
5246 		"ALU_ADD_K: 0 + (-1) = 0x00000000ffffffff",
5247 		.u.insns_int = {
5248 			BPF_LD_IMM64(R2, 0x0),
5249 			BPF_LD_IMM64(R3, 0x00000000ffffffff),
5250 			BPF_ALU32_IMM(BPF_ADD, R2, 0xffffffff),
5251 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5252 			BPF_MOV32_IMM(R0, 2),
5253 			BPF_EXIT_INSN(),
5254 			BPF_MOV32_IMM(R0, 1),
5255 			BPF_EXIT_INSN(),
5256 		},
5257 		INTERNAL,
5258 		{ },
5259 		{ { 0, 0x1 } },
5260 	},
5261 	{
5262 		"ALU_ADD_K: 0 + 0xffff = 0xffff",
5263 		.u.insns_int = {
5264 			BPF_LD_IMM64(R2, 0x0),
5265 			BPF_LD_IMM64(R3, 0xffff),
5266 			BPF_ALU32_IMM(BPF_ADD, R2, 0xffff),
5267 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5268 			BPF_MOV32_IMM(R0, 2),
5269 			BPF_EXIT_INSN(),
5270 			BPF_MOV32_IMM(R0, 1),
5271 			BPF_EXIT_INSN(),
5272 		},
5273 		INTERNAL,
5274 		{ },
5275 		{ { 0, 0x1 } },
5276 	},
5277 	{
5278 		"ALU_ADD_K: 0 + 0x7fffffff = 0x7fffffff",
5279 		.u.insns_int = {
5280 			BPF_LD_IMM64(R2, 0x0),
5281 			BPF_LD_IMM64(R3, 0x7fffffff),
5282 			BPF_ALU32_IMM(BPF_ADD, R2, 0x7fffffff),
5283 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5284 			BPF_MOV32_IMM(R0, 2),
5285 			BPF_EXIT_INSN(),
5286 			BPF_MOV32_IMM(R0, 1),
5287 			BPF_EXIT_INSN(),
5288 		},
5289 		INTERNAL,
5290 		{ },
5291 		{ { 0, 0x1 } },
5292 	},
5293 	{
5294 		"ALU_ADD_K: 0 + 0x80000000 = 0x80000000",
5295 		.u.insns_int = {
5296 			BPF_LD_IMM64(R2, 0x0),
5297 			BPF_LD_IMM64(R3, 0x80000000),
5298 			BPF_ALU32_IMM(BPF_ADD, R2, 0x80000000),
5299 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5300 			BPF_MOV32_IMM(R0, 2),
5301 			BPF_EXIT_INSN(),
5302 			BPF_MOV32_IMM(R0, 1),
5303 			BPF_EXIT_INSN(),
5304 		},
5305 		INTERNAL,
5306 		{ },
5307 		{ { 0, 0x1 } },
5308 	},
5309 	{
5310 		"ALU_ADD_K: 0 + 0x80008000 = 0x80008000",
5311 		.u.insns_int = {
5312 			BPF_LD_IMM64(R2, 0x0),
5313 			BPF_LD_IMM64(R3, 0x80008000),
5314 			BPF_ALU32_IMM(BPF_ADD, R2, 0x80008000),
5315 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5316 			BPF_MOV32_IMM(R0, 2),
5317 			BPF_EXIT_INSN(),
5318 			BPF_MOV32_IMM(R0, 1),
5319 			BPF_EXIT_INSN(),
5320 		},
5321 		INTERNAL,
5322 		{ },
5323 		{ { 0, 0x1 } },
5324 	},
5325 	{
5326 		"ALU64_ADD_K: 1 + 2 = 3",
5327 		.u.insns_int = {
5328 			BPF_LD_IMM64(R0, 1),
5329 			BPF_ALU64_IMM(BPF_ADD, R0, 2),
5330 			BPF_EXIT_INSN(),
5331 		},
5332 		INTERNAL,
5333 		{ },
5334 		{ { 0, 3 } },
5335 	},
5336 	{
5337 		"ALU64_ADD_K: 3 + 0 = 3",
5338 		.u.insns_int = {
5339 			BPF_LD_IMM64(R0, 3),
5340 			BPF_ALU64_IMM(BPF_ADD, R0, 0),
5341 			BPF_EXIT_INSN(),
5342 		},
5343 		INTERNAL,
5344 		{ },
5345 		{ { 0, 3 } },
5346 	},
5347 	{
5348 		"ALU64_ADD_K: 1 + 2147483646 = 2147483647",
5349 		.u.insns_int = {
5350 			BPF_LD_IMM64(R0, 1),
5351 			BPF_ALU64_IMM(BPF_ADD, R0, 2147483646),
5352 			BPF_EXIT_INSN(),
5353 		},
5354 		INTERNAL,
5355 		{ },
5356 		{ { 0, 2147483647 } },
5357 	},
5358 	{
5359 		"ALU64_ADD_K: 4294967294 + 2 = 4294967296",
5360 		.u.insns_int = {
5361 			BPF_LD_IMM64(R0, 4294967294U),
5362 			BPF_LD_IMM64(R1, 4294967296ULL),
5363 			BPF_ALU64_IMM(BPF_ADD, R0, 2),
5364 			BPF_JMP_REG(BPF_JEQ, R0, R1, 2),
5365 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
5366 			BPF_EXIT_INSN(),
5367 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
5368 			BPF_EXIT_INSN(),
5369 		},
5370 		INTERNAL,
5371 		{ },
5372 		{ { 0, 1 } },
5373 	},
5374 	{
5375 		"ALU64_ADD_K: 2147483646 + -2147483647 = -1",
5376 		.u.insns_int = {
5377 			BPF_LD_IMM64(R0, 2147483646),
5378 			BPF_ALU64_IMM(BPF_ADD, R0, -2147483647),
5379 			BPF_EXIT_INSN(),
5380 		},
5381 		INTERNAL,
5382 		{ },
5383 		{ { 0, -1 } },
5384 	},
5385 	{
5386 		"ALU64_ADD_K: 1 + 0 = 1",
5387 		.u.insns_int = {
5388 			BPF_LD_IMM64(R2, 0x1),
5389 			BPF_LD_IMM64(R3, 0x1),
5390 			BPF_ALU64_IMM(BPF_ADD, R2, 0x0),
5391 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5392 			BPF_MOV32_IMM(R0, 2),
5393 			BPF_EXIT_INSN(),
5394 			BPF_MOV32_IMM(R0, 1),
5395 			BPF_EXIT_INSN(),
5396 		},
5397 		INTERNAL,
5398 		{ },
5399 		{ { 0, 0x1 } },
5400 	},
5401 	{
5402 		"ALU64_ADD_K: 0 + (-1) = 0xffffffffffffffff",
5403 		.u.insns_int = {
5404 			BPF_LD_IMM64(R2, 0x0),
5405 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
5406 			BPF_ALU64_IMM(BPF_ADD, R2, 0xffffffff),
5407 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5408 			BPF_MOV32_IMM(R0, 2),
5409 			BPF_EXIT_INSN(),
5410 			BPF_MOV32_IMM(R0, 1),
5411 			BPF_EXIT_INSN(),
5412 		},
5413 		INTERNAL,
5414 		{ },
5415 		{ { 0, 0x1 } },
5416 	},
5417 	{
5418 		"ALU64_ADD_K: 0 + 0xffff = 0xffff",
5419 		.u.insns_int = {
5420 			BPF_LD_IMM64(R2, 0x0),
5421 			BPF_LD_IMM64(R3, 0xffff),
5422 			BPF_ALU64_IMM(BPF_ADD, R2, 0xffff),
5423 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5424 			BPF_MOV32_IMM(R0, 2),
5425 			BPF_EXIT_INSN(),
5426 			BPF_MOV32_IMM(R0, 1),
5427 			BPF_EXIT_INSN(),
5428 		},
5429 		INTERNAL,
5430 		{ },
5431 		{ { 0, 0x1 } },
5432 	},
5433 	{
5434 		"ALU64_ADD_K: 0 + 0x7fffffff = 0x7fffffff",
5435 		.u.insns_int = {
5436 			BPF_LD_IMM64(R2, 0x0),
5437 			BPF_LD_IMM64(R3, 0x7fffffff),
5438 			BPF_ALU64_IMM(BPF_ADD, R2, 0x7fffffff),
5439 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5440 			BPF_MOV32_IMM(R0, 2),
5441 			BPF_EXIT_INSN(),
5442 			BPF_MOV32_IMM(R0, 1),
5443 			BPF_EXIT_INSN(),
5444 		},
5445 		INTERNAL,
5446 		{ },
5447 		{ { 0, 0x1 } },
5448 	},
5449 	{
5450 		"ALU64_ADD_K: 0 + 0x80000000 = 0xffffffff80000000",
5451 		.u.insns_int = {
5452 			BPF_LD_IMM64(R2, 0x0),
5453 			BPF_LD_IMM64(R3, 0xffffffff80000000LL),
5454 			BPF_ALU64_IMM(BPF_ADD, R2, 0x80000000),
5455 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5456 			BPF_MOV32_IMM(R0, 2),
5457 			BPF_EXIT_INSN(),
5458 			BPF_MOV32_IMM(R0, 1),
5459 			BPF_EXIT_INSN(),
5460 		},
5461 		INTERNAL,
5462 		{ },
5463 		{ { 0, 0x1 } },
5464 	},
5465 	{
5466 		"ALU_ADD_K: 0 + 0x80008000 = 0xffffffff80008000",
5467 		.u.insns_int = {
5468 			BPF_LD_IMM64(R2, 0x0),
5469 			BPF_LD_IMM64(R3, 0xffffffff80008000LL),
5470 			BPF_ALU64_IMM(BPF_ADD, R2, 0x80008000),
5471 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5472 			BPF_MOV32_IMM(R0, 2),
5473 			BPF_EXIT_INSN(),
5474 			BPF_MOV32_IMM(R0, 1),
5475 			BPF_EXIT_INSN(),
5476 		},
5477 		INTERNAL,
5478 		{ },
5479 		{ { 0, 0x1 } },
5480 	},
5481 	/* BPF_ALU | BPF_SUB | BPF_X */
5482 	{
5483 		"ALU_SUB_X: 3 - 1 = 2",
5484 		.u.insns_int = {
5485 			BPF_LD_IMM64(R0, 3),
5486 			BPF_ALU32_IMM(BPF_MOV, R1, 1),
5487 			BPF_ALU32_REG(BPF_SUB, R0, R1),
5488 			BPF_EXIT_INSN(),
5489 		},
5490 		INTERNAL,
5491 		{ },
5492 		{ { 0, 2 } },
5493 	},
5494 	{
5495 		"ALU_SUB_X: 4294967295 - 4294967294 = 1",
5496 		.u.insns_int = {
5497 			BPF_LD_IMM64(R0, 4294967295U),
5498 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967294U),
5499 			BPF_ALU32_REG(BPF_SUB, R0, R1),
5500 			BPF_EXIT_INSN(),
5501 		},
5502 		INTERNAL,
5503 		{ },
5504 		{ { 0, 1 } },
5505 	},
5506 	{
5507 		"ALU64_SUB_X: 3 - 1 = 2",
5508 		.u.insns_int = {
5509 			BPF_LD_IMM64(R0, 3),
5510 			BPF_ALU32_IMM(BPF_MOV, R1, 1),
5511 			BPF_ALU64_REG(BPF_SUB, R0, R1),
5512 			BPF_EXIT_INSN(),
5513 		},
5514 		INTERNAL,
5515 		{ },
5516 		{ { 0, 2 } },
5517 	},
5518 	{
5519 		"ALU64_SUB_X: 4294967295 - 4294967294 = 1",
5520 		.u.insns_int = {
5521 			BPF_LD_IMM64(R0, 4294967295U),
5522 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967294U),
5523 			BPF_ALU64_REG(BPF_SUB, R0, R1),
5524 			BPF_EXIT_INSN(),
5525 		},
5526 		INTERNAL,
5527 		{ },
5528 		{ { 0, 1 } },
5529 	},
5530 	/* BPF_ALU | BPF_SUB | BPF_K */
5531 	{
5532 		"ALU_SUB_K: 3 - 1 = 2",
5533 		.u.insns_int = {
5534 			BPF_LD_IMM64(R0, 3),
5535 			BPF_ALU32_IMM(BPF_SUB, R0, 1),
5536 			BPF_EXIT_INSN(),
5537 		},
5538 		INTERNAL,
5539 		{ },
5540 		{ { 0, 2 } },
5541 	},
5542 	{
5543 		"ALU_SUB_K: 3 - 0 = 3",
5544 		.u.insns_int = {
5545 			BPF_LD_IMM64(R0, 3),
5546 			BPF_ALU32_IMM(BPF_SUB, R0, 0),
5547 			BPF_EXIT_INSN(),
5548 		},
5549 		INTERNAL,
5550 		{ },
5551 		{ { 0, 3 } },
5552 	},
5553 	{
5554 		"ALU_SUB_K: 4294967295 - 4294967294 = 1",
5555 		.u.insns_int = {
5556 			BPF_LD_IMM64(R0, 4294967295U),
5557 			BPF_ALU32_IMM(BPF_SUB, R0, 4294967294U),
5558 			BPF_EXIT_INSN(),
5559 		},
5560 		INTERNAL,
5561 		{ },
5562 		{ { 0, 1 } },
5563 	},
5564 	{
5565 		"ALU64_SUB_K: 3 - 1 = 2",
5566 		.u.insns_int = {
5567 			BPF_LD_IMM64(R0, 3),
5568 			BPF_ALU64_IMM(BPF_SUB, R0, 1),
5569 			BPF_EXIT_INSN(),
5570 		},
5571 		INTERNAL,
5572 		{ },
5573 		{ { 0, 2 } },
5574 	},
5575 	{
5576 		"ALU64_SUB_K: 3 - 0 = 3",
5577 		.u.insns_int = {
5578 			BPF_LD_IMM64(R0, 3),
5579 			BPF_ALU64_IMM(BPF_SUB, R0, 0),
5580 			BPF_EXIT_INSN(),
5581 		},
5582 		INTERNAL,
5583 		{ },
5584 		{ { 0, 3 } },
5585 	},
5586 	{
5587 		"ALU64_SUB_K: 4294967294 - 4294967295 = -1",
5588 		.u.insns_int = {
5589 			BPF_LD_IMM64(R0, 4294967294U),
5590 			BPF_ALU64_IMM(BPF_SUB, R0, 4294967295U),
5591 			BPF_EXIT_INSN(),
5592 		},
5593 		INTERNAL,
5594 		{ },
5595 		{ { 0, -1 } },
5596 	},
5597 	{
5598 		"ALU64_ADD_K: 2147483646 - 2147483647 = -1",
5599 		.u.insns_int = {
5600 			BPF_LD_IMM64(R0, 2147483646),
5601 			BPF_ALU64_IMM(BPF_SUB, R0, 2147483647),
5602 			BPF_EXIT_INSN(),
5603 		},
5604 		INTERNAL,
5605 		{ },
5606 		{ { 0, -1 } },
5607 	},
5608 	/* BPF_ALU | BPF_MUL | BPF_X */
5609 	{
5610 		"ALU_MUL_X: 2 * 3 = 6",
5611 		.u.insns_int = {
5612 			BPF_LD_IMM64(R0, 2),
5613 			BPF_ALU32_IMM(BPF_MOV, R1, 3),
5614 			BPF_ALU32_REG(BPF_MUL, R0, R1),
5615 			BPF_EXIT_INSN(),
5616 		},
5617 		INTERNAL,
5618 		{ },
5619 		{ { 0, 6 } },
5620 	},
5621 	{
5622 		"ALU_MUL_X: 2 * 0x7FFFFFF8 = 0xFFFFFFF0",
5623 		.u.insns_int = {
5624 			BPF_LD_IMM64(R0, 2),
5625 			BPF_ALU32_IMM(BPF_MOV, R1, 0x7FFFFFF8),
5626 			BPF_ALU32_REG(BPF_MUL, R0, R1),
5627 			BPF_EXIT_INSN(),
5628 		},
5629 		INTERNAL,
5630 		{ },
5631 		{ { 0, 0xFFFFFFF0 } },
5632 	},
5633 	{
5634 		"ALU_MUL_X: -1 * -1 = 1",
5635 		.u.insns_int = {
5636 			BPF_LD_IMM64(R0, -1),
5637 			BPF_ALU32_IMM(BPF_MOV, R1, -1),
5638 			BPF_ALU32_REG(BPF_MUL, R0, R1),
5639 			BPF_EXIT_INSN(),
5640 		},
5641 		INTERNAL,
5642 		{ },
5643 		{ { 0, 1 } },
5644 	},
5645 	{
5646 		"ALU64_MUL_X: 2 * 3 = 6",
5647 		.u.insns_int = {
5648 			BPF_LD_IMM64(R0, 2),
5649 			BPF_ALU32_IMM(BPF_MOV, R1, 3),
5650 			BPF_ALU64_REG(BPF_MUL, R0, R1),
5651 			BPF_EXIT_INSN(),
5652 		},
5653 		INTERNAL,
5654 		{ },
5655 		{ { 0, 6 } },
5656 	},
5657 	{
5658 		"ALU64_MUL_X: 1 * 2147483647 = 2147483647",
5659 		.u.insns_int = {
5660 			BPF_LD_IMM64(R0, 1),
5661 			BPF_ALU32_IMM(BPF_MOV, R1, 2147483647),
5662 			BPF_ALU64_REG(BPF_MUL, R0, R1),
5663 			BPF_EXIT_INSN(),
5664 		},
5665 		INTERNAL,
5666 		{ },
5667 		{ { 0, 2147483647 } },
5668 	},
5669 	{
5670 		"ALU64_MUL_X: 64x64 multiply, low word",
5671 		.u.insns_int = {
5672 			BPF_LD_IMM64(R0, 0x0fedcba987654321LL),
5673 			BPF_LD_IMM64(R1, 0x123456789abcdef0LL),
5674 			BPF_ALU64_REG(BPF_MUL, R0, R1),
5675 			BPF_EXIT_INSN(),
5676 		},
5677 		INTERNAL,
5678 		{ },
5679 		{ { 0, 0xe5618cf0 } }
5680 	},
5681 	{
5682 		"ALU64_MUL_X: 64x64 multiply, high word",
5683 		.u.insns_int = {
5684 			BPF_LD_IMM64(R0, 0x0fedcba987654321LL),
5685 			BPF_LD_IMM64(R1, 0x123456789abcdef0LL),
5686 			BPF_ALU64_REG(BPF_MUL, R0, R1),
5687 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
5688 			BPF_EXIT_INSN(),
5689 		},
5690 		INTERNAL,
5691 		{ },
5692 		{ { 0, 0x2236d88f } }
5693 	},
5694 	/* BPF_ALU | BPF_MUL | BPF_K */
5695 	{
5696 		"ALU_MUL_K: 2 * 3 = 6",
5697 		.u.insns_int = {
5698 			BPF_LD_IMM64(R0, 2),
5699 			BPF_ALU32_IMM(BPF_MUL, R0, 3),
5700 			BPF_EXIT_INSN(),
5701 		},
5702 		INTERNAL,
5703 		{ },
5704 		{ { 0, 6 } },
5705 	},
5706 	{
5707 		"ALU_MUL_K: 3 * 1 = 3",
5708 		.u.insns_int = {
5709 			BPF_LD_IMM64(R0, 3),
5710 			BPF_ALU32_IMM(BPF_MUL, R0, 1),
5711 			BPF_EXIT_INSN(),
5712 		},
5713 		INTERNAL,
5714 		{ },
5715 		{ { 0, 3 } },
5716 	},
5717 	{
5718 		"ALU_MUL_K: 2 * 0x7FFFFFF8 = 0xFFFFFFF0",
5719 		.u.insns_int = {
5720 			BPF_LD_IMM64(R0, 2),
5721 			BPF_ALU32_IMM(BPF_MUL, R0, 0x7FFFFFF8),
5722 			BPF_EXIT_INSN(),
5723 		},
5724 		INTERNAL,
5725 		{ },
5726 		{ { 0, 0xFFFFFFF0 } },
5727 	},
5728 	{
5729 		"ALU_MUL_K: 1 * (-1) = 0x00000000ffffffff",
5730 		.u.insns_int = {
5731 			BPF_LD_IMM64(R2, 0x1),
5732 			BPF_LD_IMM64(R3, 0x00000000ffffffff),
5733 			BPF_ALU32_IMM(BPF_MUL, R2, 0xffffffff),
5734 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5735 			BPF_MOV32_IMM(R0, 2),
5736 			BPF_EXIT_INSN(),
5737 			BPF_MOV32_IMM(R0, 1),
5738 			BPF_EXIT_INSN(),
5739 		},
5740 		INTERNAL,
5741 		{ },
5742 		{ { 0, 0x1 } },
5743 	},
5744 	{
5745 		"ALU64_MUL_K: 2 * 3 = 6",
5746 		.u.insns_int = {
5747 			BPF_LD_IMM64(R0, 2),
5748 			BPF_ALU64_IMM(BPF_MUL, R0, 3),
5749 			BPF_EXIT_INSN(),
5750 		},
5751 		INTERNAL,
5752 		{ },
5753 		{ { 0, 6 } },
5754 	},
5755 	{
5756 		"ALU64_MUL_K: 3 * 1 = 3",
5757 		.u.insns_int = {
5758 			BPF_LD_IMM64(R0, 3),
5759 			BPF_ALU64_IMM(BPF_MUL, R0, 1),
5760 			BPF_EXIT_INSN(),
5761 		},
5762 		INTERNAL,
5763 		{ },
5764 		{ { 0, 3 } },
5765 	},
5766 	{
5767 		"ALU64_MUL_K: 1 * 2147483647 = 2147483647",
5768 		.u.insns_int = {
5769 			BPF_LD_IMM64(R0, 1),
5770 			BPF_ALU64_IMM(BPF_MUL, R0, 2147483647),
5771 			BPF_EXIT_INSN(),
5772 		},
5773 		INTERNAL,
5774 		{ },
5775 		{ { 0, 2147483647 } },
5776 	},
5777 	{
5778 		"ALU64_MUL_K: 1 * -2147483647 = -2147483647",
5779 		.u.insns_int = {
5780 			BPF_LD_IMM64(R0, 1),
5781 			BPF_ALU64_IMM(BPF_MUL, R0, -2147483647),
5782 			BPF_EXIT_INSN(),
5783 		},
5784 		INTERNAL,
5785 		{ },
5786 		{ { 0, -2147483647 } },
5787 	},
5788 	{
5789 		"ALU64_MUL_K: 1 * (-1) = 0xffffffffffffffff",
5790 		.u.insns_int = {
5791 			BPF_LD_IMM64(R2, 0x1),
5792 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
5793 			BPF_ALU64_IMM(BPF_MUL, R2, 0xffffffff),
5794 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5795 			BPF_MOV32_IMM(R0, 2),
5796 			BPF_EXIT_INSN(),
5797 			BPF_MOV32_IMM(R0, 1),
5798 			BPF_EXIT_INSN(),
5799 		},
5800 		INTERNAL,
5801 		{ },
5802 		{ { 0, 0x1 } },
5803 	},
5804 	{
5805 		"ALU64_MUL_K: 64x32 multiply, low word",
5806 		.u.insns_int = {
5807 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
5808 			BPF_ALU64_IMM(BPF_MUL, R0, 0x12345678),
5809 			BPF_EXIT_INSN(),
5810 		},
5811 		INTERNAL,
5812 		{ },
5813 		{ { 0, 0xe242d208 } }
5814 	},
5815 	{
5816 		"ALU64_MUL_K: 64x32 multiply, high word",
5817 		.u.insns_int = {
5818 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
5819 			BPF_ALU64_IMM(BPF_MUL, R0, 0x12345678),
5820 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
5821 			BPF_EXIT_INSN(),
5822 		},
5823 		INTERNAL,
5824 		{ },
5825 		{ { 0, 0xc28f5c28 } }
5826 	},
5827 	/* BPF_ALU | BPF_DIV | BPF_X */
5828 	{
5829 		"ALU_DIV_X: 6 / 2 = 3",
5830 		.u.insns_int = {
5831 			BPF_LD_IMM64(R0, 6),
5832 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
5833 			BPF_ALU32_REG(BPF_DIV, R0, R1),
5834 			BPF_EXIT_INSN(),
5835 		},
5836 		INTERNAL,
5837 		{ },
5838 		{ { 0, 3 } },
5839 	},
5840 	{
5841 		"ALU_DIV_X: 4294967295 / 4294967295 = 1",
5842 		.u.insns_int = {
5843 			BPF_LD_IMM64(R0, 4294967295U),
5844 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967295U),
5845 			BPF_ALU32_REG(BPF_DIV, R0, R1),
5846 			BPF_EXIT_INSN(),
5847 		},
5848 		INTERNAL,
5849 		{ },
5850 		{ { 0, 1 } },
5851 	},
5852 	{
5853 		"ALU64_DIV_X: 6 / 2 = 3",
5854 		.u.insns_int = {
5855 			BPF_LD_IMM64(R0, 6),
5856 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
5857 			BPF_ALU64_REG(BPF_DIV, R0, R1),
5858 			BPF_EXIT_INSN(),
5859 		},
5860 		INTERNAL,
5861 		{ },
5862 		{ { 0, 3 } },
5863 	},
5864 	{
5865 		"ALU64_DIV_X: 2147483647 / 2147483647 = 1",
5866 		.u.insns_int = {
5867 			BPF_LD_IMM64(R0, 2147483647),
5868 			BPF_ALU32_IMM(BPF_MOV, R1, 2147483647),
5869 			BPF_ALU64_REG(BPF_DIV, R0, R1),
5870 			BPF_EXIT_INSN(),
5871 		},
5872 		INTERNAL,
5873 		{ },
5874 		{ { 0, 1 } },
5875 	},
5876 	{
5877 		"ALU64_DIV_X: 0xffffffffffffffff / (-1) = 0x0000000000000001",
5878 		.u.insns_int = {
5879 			BPF_LD_IMM64(R2, 0xffffffffffffffffLL),
5880 			BPF_LD_IMM64(R4, 0xffffffffffffffffLL),
5881 			BPF_LD_IMM64(R3, 0x0000000000000001LL),
5882 			BPF_ALU64_REG(BPF_DIV, R2, R4),
5883 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5884 			BPF_MOV32_IMM(R0, 2),
5885 			BPF_EXIT_INSN(),
5886 			BPF_MOV32_IMM(R0, 1),
5887 			BPF_EXIT_INSN(),
5888 		},
5889 		INTERNAL,
5890 		{ },
5891 		{ { 0, 0x1 } },
5892 	},
5893 	/* BPF_ALU | BPF_DIV | BPF_K */
5894 	{
5895 		"ALU_DIV_K: 6 / 2 = 3",
5896 		.u.insns_int = {
5897 			BPF_LD_IMM64(R0, 6),
5898 			BPF_ALU32_IMM(BPF_DIV, R0, 2),
5899 			BPF_EXIT_INSN(),
5900 		},
5901 		INTERNAL,
5902 		{ },
5903 		{ { 0, 3 } },
5904 	},
5905 	{
5906 		"ALU_DIV_K: 3 / 1 = 3",
5907 		.u.insns_int = {
5908 			BPF_LD_IMM64(R0, 3),
5909 			BPF_ALU32_IMM(BPF_DIV, R0, 1),
5910 			BPF_EXIT_INSN(),
5911 		},
5912 		INTERNAL,
5913 		{ },
5914 		{ { 0, 3 } },
5915 	},
5916 	{
5917 		"ALU_DIV_K: 4294967295 / 4294967295 = 1",
5918 		.u.insns_int = {
5919 			BPF_LD_IMM64(R0, 4294967295U),
5920 			BPF_ALU32_IMM(BPF_DIV, R0, 4294967295U),
5921 			BPF_EXIT_INSN(),
5922 		},
5923 		INTERNAL,
5924 		{ },
5925 		{ { 0, 1 } },
5926 	},
5927 	{
5928 		"ALU_DIV_K: 0xffffffffffffffff / (-1) = 0x1",
5929 		.u.insns_int = {
5930 			BPF_LD_IMM64(R2, 0xffffffffffffffffLL),
5931 			BPF_LD_IMM64(R3, 0x1UL),
5932 			BPF_ALU32_IMM(BPF_DIV, R2, 0xffffffff),
5933 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5934 			BPF_MOV32_IMM(R0, 2),
5935 			BPF_EXIT_INSN(),
5936 			BPF_MOV32_IMM(R0, 1),
5937 			BPF_EXIT_INSN(),
5938 		},
5939 		INTERNAL,
5940 		{ },
5941 		{ { 0, 0x1 } },
5942 	},
5943 	{
5944 		"ALU64_DIV_K: 6 / 2 = 3",
5945 		.u.insns_int = {
5946 			BPF_LD_IMM64(R0, 6),
5947 			BPF_ALU64_IMM(BPF_DIV, R0, 2),
5948 			BPF_EXIT_INSN(),
5949 		},
5950 		INTERNAL,
5951 		{ },
5952 		{ { 0, 3 } },
5953 	},
5954 	{
5955 		"ALU64_DIV_K: 3 / 1 = 3",
5956 		.u.insns_int = {
5957 			BPF_LD_IMM64(R0, 3),
5958 			BPF_ALU64_IMM(BPF_DIV, R0, 1),
5959 			BPF_EXIT_INSN(),
5960 		},
5961 		INTERNAL,
5962 		{ },
5963 		{ { 0, 3 } },
5964 	},
5965 	{
5966 		"ALU64_DIV_K: 2147483647 / 2147483647 = 1",
5967 		.u.insns_int = {
5968 			BPF_LD_IMM64(R0, 2147483647),
5969 			BPF_ALU64_IMM(BPF_DIV, R0, 2147483647),
5970 			BPF_EXIT_INSN(),
5971 		},
5972 		INTERNAL,
5973 		{ },
5974 		{ { 0, 1 } },
5975 	},
5976 	{
5977 		"ALU64_DIV_K: 0xffffffffffffffff / (-1) = 0x0000000000000001",
5978 		.u.insns_int = {
5979 			BPF_LD_IMM64(R2, 0xffffffffffffffffLL),
5980 			BPF_LD_IMM64(R3, 0x0000000000000001LL),
5981 			BPF_ALU64_IMM(BPF_DIV, R2, 0xffffffff),
5982 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
5983 			BPF_MOV32_IMM(R0, 2),
5984 			BPF_EXIT_INSN(),
5985 			BPF_MOV32_IMM(R0, 1),
5986 			BPF_EXIT_INSN(),
5987 		},
5988 		INTERNAL,
5989 		{ },
5990 		{ { 0, 0x1 } },
5991 	},
5992 	/* BPF_ALU | BPF_MOD | BPF_X */
5993 	{
5994 		"ALU_MOD_X: 3 % 2 = 1",
5995 		.u.insns_int = {
5996 			BPF_LD_IMM64(R0, 3),
5997 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
5998 			BPF_ALU32_REG(BPF_MOD, R0, R1),
5999 			BPF_EXIT_INSN(),
6000 		},
6001 		INTERNAL,
6002 		{ },
6003 		{ { 0, 1 } },
6004 	},
6005 	{
6006 		"ALU_MOD_X: 4294967295 % 4294967293 = 2",
6007 		.u.insns_int = {
6008 			BPF_LD_IMM64(R0, 4294967295U),
6009 			BPF_ALU32_IMM(BPF_MOV, R1, 4294967293U),
6010 			BPF_ALU32_REG(BPF_MOD, R0, R1),
6011 			BPF_EXIT_INSN(),
6012 		},
6013 		INTERNAL,
6014 		{ },
6015 		{ { 0, 2 } },
6016 	},
6017 	{
6018 		"ALU64_MOD_X: 3 % 2 = 1",
6019 		.u.insns_int = {
6020 			BPF_LD_IMM64(R0, 3),
6021 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
6022 			BPF_ALU64_REG(BPF_MOD, R0, R1),
6023 			BPF_EXIT_INSN(),
6024 		},
6025 		INTERNAL,
6026 		{ },
6027 		{ { 0, 1 } },
6028 	},
6029 	{
6030 		"ALU64_MOD_X: 2147483647 % 2147483645 = 2",
6031 		.u.insns_int = {
6032 			BPF_LD_IMM64(R0, 2147483647),
6033 			BPF_ALU32_IMM(BPF_MOV, R1, 2147483645),
6034 			BPF_ALU64_REG(BPF_MOD, R0, R1),
6035 			BPF_EXIT_INSN(),
6036 		},
6037 		INTERNAL,
6038 		{ },
6039 		{ { 0, 2 } },
6040 	},
6041 	/* BPF_ALU | BPF_MOD | BPF_K */
6042 	{
6043 		"ALU_MOD_K: 3 % 2 = 1",
6044 		.u.insns_int = {
6045 			BPF_LD_IMM64(R0, 3),
6046 			BPF_ALU32_IMM(BPF_MOD, R0, 2),
6047 			BPF_EXIT_INSN(),
6048 		},
6049 		INTERNAL,
6050 		{ },
6051 		{ { 0, 1 } },
6052 	},
6053 	{
6054 		"ALU_MOD_K: 3 % 1 = 0",
6055 		.u.insns_int = {
6056 			BPF_LD_IMM64(R0, 3),
6057 			BPF_ALU32_IMM(BPF_MOD, R0, 1),
6058 			BPF_EXIT_INSN(),
6059 		},
6060 		INTERNAL,
6061 		{ },
6062 		{ { 0, 0 } },
6063 	},
6064 	{
6065 		"ALU_MOD_K: 4294967295 % 4294967293 = 2",
6066 		.u.insns_int = {
6067 			BPF_LD_IMM64(R0, 4294967295U),
6068 			BPF_ALU32_IMM(BPF_MOD, R0, 4294967293U),
6069 			BPF_EXIT_INSN(),
6070 		},
6071 		INTERNAL,
6072 		{ },
6073 		{ { 0, 2 } },
6074 	},
6075 	{
6076 		"ALU64_MOD_K: 3 % 2 = 1",
6077 		.u.insns_int = {
6078 			BPF_LD_IMM64(R0, 3),
6079 			BPF_ALU64_IMM(BPF_MOD, R0, 2),
6080 			BPF_EXIT_INSN(),
6081 		},
6082 		INTERNAL,
6083 		{ },
6084 		{ { 0, 1 } },
6085 	},
6086 	{
6087 		"ALU64_MOD_K: 3 % 1 = 0",
6088 		.u.insns_int = {
6089 			BPF_LD_IMM64(R0, 3),
6090 			BPF_ALU64_IMM(BPF_MOD, R0, 1),
6091 			BPF_EXIT_INSN(),
6092 		},
6093 		INTERNAL,
6094 		{ },
6095 		{ { 0, 0 } },
6096 	},
6097 	{
6098 		"ALU64_MOD_K: 2147483647 % 2147483645 = 2",
6099 		.u.insns_int = {
6100 			BPF_LD_IMM64(R0, 2147483647),
6101 			BPF_ALU64_IMM(BPF_MOD, R0, 2147483645),
6102 			BPF_EXIT_INSN(),
6103 		},
6104 		INTERNAL,
6105 		{ },
6106 		{ { 0, 2 } },
6107 	},
6108 	/* BPF_ALU | BPF_AND | BPF_X */
6109 	{
6110 		"ALU_AND_X: 3 & 2 = 2",
6111 		.u.insns_int = {
6112 			BPF_LD_IMM64(R0, 3),
6113 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
6114 			BPF_ALU32_REG(BPF_AND, R0, R1),
6115 			BPF_EXIT_INSN(),
6116 		},
6117 		INTERNAL,
6118 		{ },
6119 		{ { 0, 2 } },
6120 	},
6121 	{
6122 		"ALU_AND_X: 0xffffffff & 0xffffffff = 0xffffffff",
6123 		.u.insns_int = {
6124 			BPF_LD_IMM64(R0, 0xffffffff),
6125 			BPF_ALU32_IMM(BPF_MOV, R1, 0xffffffff),
6126 			BPF_ALU32_REG(BPF_AND, R0, R1),
6127 			BPF_EXIT_INSN(),
6128 		},
6129 		INTERNAL,
6130 		{ },
6131 		{ { 0, 0xffffffff } },
6132 	},
6133 	{
6134 		"ALU64_AND_X: 3 & 2 = 2",
6135 		.u.insns_int = {
6136 			BPF_LD_IMM64(R0, 3),
6137 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
6138 			BPF_ALU64_REG(BPF_AND, R0, R1),
6139 			BPF_EXIT_INSN(),
6140 		},
6141 		INTERNAL,
6142 		{ },
6143 		{ { 0, 2 } },
6144 	},
6145 	{
6146 		"ALU64_AND_X: 0xffffffff & 0xffffffff = 0xffffffff",
6147 		.u.insns_int = {
6148 			BPF_LD_IMM64(R0, 0xffffffff),
6149 			BPF_ALU32_IMM(BPF_MOV, R1, 0xffffffff),
6150 			BPF_ALU64_REG(BPF_AND, R0, R1),
6151 			BPF_EXIT_INSN(),
6152 		},
6153 		INTERNAL,
6154 		{ },
6155 		{ { 0, 0xffffffff } },
6156 	},
6157 	/* BPF_ALU | BPF_AND | BPF_K */
6158 	{
6159 		"ALU_AND_K: 3 & 2 = 2",
6160 		.u.insns_int = {
6161 			BPF_LD_IMM64(R0, 3),
6162 			BPF_ALU32_IMM(BPF_AND, R0, 2),
6163 			BPF_EXIT_INSN(),
6164 		},
6165 		INTERNAL,
6166 		{ },
6167 		{ { 0, 2 } },
6168 	},
6169 	{
6170 		"ALU_AND_K: 0xffffffff & 0xffffffff = 0xffffffff",
6171 		.u.insns_int = {
6172 			BPF_LD_IMM64(R0, 0xffffffff),
6173 			BPF_ALU32_IMM(BPF_AND, R0, 0xffffffff),
6174 			BPF_EXIT_INSN(),
6175 		},
6176 		INTERNAL,
6177 		{ },
6178 		{ { 0, 0xffffffff } },
6179 	},
6180 	{
6181 		"ALU_AND_K: Small immediate",
6182 		.u.insns_int = {
6183 			BPF_ALU32_IMM(BPF_MOV, R0, 0x01020304),
6184 			BPF_ALU32_IMM(BPF_AND, R0, 15),
6185 			BPF_EXIT_INSN(),
6186 		},
6187 		INTERNAL,
6188 		{ },
6189 		{ { 0, 4 } }
6190 	},
6191 	{
6192 		"ALU_AND_K: Large immediate",
6193 		.u.insns_int = {
6194 			BPF_ALU32_IMM(BPF_MOV, R0, 0xf1f2f3f4),
6195 			BPF_ALU32_IMM(BPF_AND, R0, 0xafbfcfdf),
6196 			BPF_EXIT_INSN(),
6197 		},
6198 		INTERNAL,
6199 		{ },
6200 		{ { 0, 0xa1b2c3d4 } }
6201 	},
6202 	{
6203 		"ALU_AND_K: Zero extension",
6204 		.u.insns_int = {
6205 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6206 			BPF_LD_IMM64(R1, 0x0000000080a0c0e0LL),
6207 			BPF_ALU32_IMM(BPF_AND, R0, 0xf0f0f0f0),
6208 			BPF_JMP_REG(BPF_JEQ, R0, R1, 2),
6209 			BPF_MOV32_IMM(R0, 2),
6210 			BPF_EXIT_INSN(),
6211 			BPF_MOV32_IMM(R0, 1),
6212 			BPF_EXIT_INSN(),
6213 		},
6214 		INTERNAL,
6215 		{ },
6216 		{ { 0, 1 } }
6217 	},
6218 	{
6219 		"ALU64_AND_K: 3 & 2 = 2",
6220 		.u.insns_int = {
6221 			BPF_LD_IMM64(R0, 3),
6222 			BPF_ALU64_IMM(BPF_AND, R0, 2),
6223 			BPF_EXIT_INSN(),
6224 		},
6225 		INTERNAL,
6226 		{ },
6227 		{ { 0, 2 } },
6228 	},
6229 	{
6230 		"ALU64_AND_K: 0xffffffff & 0xffffffff = 0xffffffff",
6231 		.u.insns_int = {
6232 			BPF_LD_IMM64(R0, 0xffffffff),
6233 			BPF_ALU64_IMM(BPF_AND, R0, 0xffffffff),
6234 			BPF_EXIT_INSN(),
6235 		},
6236 		INTERNAL,
6237 		{ },
6238 		{ { 0, 0xffffffff } },
6239 	},
6240 	{
6241 		"ALU64_AND_K: 0x0000ffffffff0000 & 0x0 = 0x0000000000000000",
6242 		.u.insns_int = {
6243 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
6244 			BPF_LD_IMM64(R3, 0x0000000000000000LL),
6245 			BPF_ALU64_IMM(BPF_AND, R2, 0x0),
6246 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
6247 			BPF_MOV32_IMM(R0, 2),
6248 			BPF_EXIT_INSN(),
6249 			BPF_MOV32_IMM(R0, 1),
6250 			BPF_EXIT_INSN(),
6251 		},
6252 		INTERNAL,
6253 		{ },
6254 		{ { 0, 0x1 } },
6255 	},
6256 	{
6257 		"ALU64_AND_K: 0x0000ffffffff0000 & -1 = 0x0000ffffffff0000",
6258 		.u.insns_int = {
6259 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
6260 			BPF_LD_IMM64(R3, 0x0000ffffffff0000LL),
6261 			BPF_ALU64_IMM(BPF_AND, R2, 0xffffffff),
6262 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
6263 			BPF_MOV32_IMM(R0, 2),
6264 			BPF_EXIT_INSN(),
6265 			BPF_MOV32_IMM(R0, 1),
6266 			BPF_EXIT_INSN(),
6267 		},
6268 		INTERNAL,
6269 		{ },
6270 		{ { 0, 0x1 } },
6271 	},
6272 	{
6273 		"ALU64_AND_K: 0xffffffffffffffff & -1 = 0xffffffffffffffff",
6274 		.u.insns_int = {
6275 			BPF_LD_IMM64(R2, 0xffffffffffffffffLL),
6276 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
6277 			BPF_ALU64_IMM(BPF_AND, R2, 0xffffffff),
6278 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
6279 			BPF_MOV32_IMM(R0, 2),
6280 			BPF_EXIT_INSN(),
6281 			BPF_MOV32_IMM(R0, 1),
6282 			BPF_EXIT_INSN(),
6283 		},
6284 		INTERNAL,
6285 		{ },
6286 		{ { 0, 0x1 } },
6287 	},
6288 	{
6289 		"ALU64_AND_K: Sign extension 1",
6290 		.u.insns_int = {
6291 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6292 			BPF_LD_IMM64(R1, 0x00000000090b0d0fLL),
6293 			BPF_ALU64_IMM(BPF_AND, R0, 0x0f0f0f0f),
6294 			BPF_JMP_REG(BPF_JEQ, R0, R1, 2),
6295 			BPF_MOV32_IMM(R0, 2),
6296 			BPF_EXIT_INSN(),
6297 			BPF_MOV32_IMM(R0, 1),
6298 			BPF_EXIT_INSN(),
6299 		},
6300 		INTERNAL,
6301 		{ },
6302 		{ { 0, 1 } }
6303 	},
6304 	{
6305 		"ALU64_AND_K: Sign extension 2",
6306 		.u.insns_int = {
6307 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6308 			BPF_LD_IMM64(R1, 0x0123456780a0c0e0LL),
6309 			BPF_ALU64_IMM(BPF_AND, R0, 0xf0f0f0f0),
6310 			BPF_JMP_REG(BPF_JEQ, R0, R1, 2),
6311 			BPF_MOV32_IMM(R0, 2),
6312 			BPF_EXIT_INSN(),
6313 			BPF_MOV32_IMM(R0, 1),
6314 			BPF_EXIT_INSN(),
6315 		},
6316 		INTERNAL,
6317 		{ },
6318 		{ { 0, 1 } }
6319 	},
6320 	/* BPF_ALU | BPF_OR | BPF_X */
6321 	{
6322 		"ALU_OR_X: 1 | 2 = 3",
6323 		.u.insns_int = {
6324 			BPF_LD_IMM64(R0, 1),
6325 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
6326 			BPF_ALU32_REG(BPF_OR, R0, R1),
6327 			BPF_EXIT_INSN(),
6328 		},
6329 		INTERNAL,
6330 		{ },
6331 		{ { 0, 3 } },
6332 	},
6333 	{
6334 		"ALU_OR_X: 0x0 | 0xffffffff = 0xffffffff",
6335 		.u.insns_int = {
6336 			BPF_LD_IMM64(R0, 0),
6337 			BPF_ALU32_IMM(BPF_MOV, R1, 0xffffffff),
6338 			BPF_ALU32_REG(BPF_OR, R0, R1),
6339 			BPF_EXIT_INSN(),
6340 		},
6341 		INTERNAL,
6342 		{ },
6343 		{ { 0, 0xffffffff } },
6344 	},
6345 	{
6346 		"ALU64_OR_X: 1 | 2 = 3",
6347 		.u.insns_int = {
6348 			BPF_LD_IMM64(R0, 1),
6349 			BPF_ALU32_IMM(BPF_MOV, R1, 2),
6350 			BPF_ALU64_REG(BPF_OR, R0, R1),
6351 			BPF_EXIT_INSN(),
6352 		},
6353 		INTERNAL,
6354 		{ },
6355 		{ { 0, 3 } },
6356 	},
6357 	{
6358 		"ALU64_OR_X: 0 | 0xffffffff = 0xffffffff",
6359 		.u.insns_int = {
6360 			BPF_LD_IMM64(R0, 0),
6361 			BPF_ALU32_IMM(BPF_MOV, R1, 0xffffffff),
6362 			BPF_ALU64_REG(BPF_OR, R0, R1),
6363 			BPF_EXIT_INSN(),
6364 		},
6365 		INTERNAL,
6366 		{ },
6367 		{ { 0, 0xffffffff } },
6368 	},
6369 	/* BPF_ALU | BPF_OR | BPF_K */
6370 	{
6371 		"ALU_OR_K: 1 | 2 = 3",
6372 		.u.insns_int = {
6373 			BPF_LD_IMM64(R0, 1),
6374 			BPF_ALU32_IMM(BPF_OR, R0, 2),
6375 			BPF_EXIT_INSN(),
6376 		},
6377 		INTERNAL,
6378 		{ },
6379 		{ { 0, 3 } },
6380 	},
6381 	{
6382 		"ALU_OR_K: 0 & 0xffffffff = 0xffffffff",
6383 		.u.insns_int = {
6384 			BPF_LD_IMM64(R0, 0),
6385 			BPF_ALU32_IMM(BPF_OR, R0, 0xffffffff),
6386 			BPF_EXIT_INSN(),
6387 		},
6388 		INTERNAL,
6389 		{ },
6390 		{ { 0, 0xffffffff } },
6391 	},
6392 	{
6393 		"ALU_OR_K: Small immediate",
6394 		.u.insns_int = {
6395 			BPF_ALU32_IMM(BPF_MOV, R0, 0x01020304),
6396 			BPF_ALU32_IMM(BPF_OR, R0, 1),
6397 			BPF_EXIT_INSN(),
6398 		},
6399 		INTERNAL,
6400 		{ },
6401 		{ { 0, 0x01020305 } }
6402 	},
6403 	{
6404 		"ALU_OR_K: Large immediate",
6405 		.u.insns_int = {
6406 			BPF_ALU32_IMM(BPF_MOV, R0, 0x01020304),
6407 			BPF_ALU32_IMM(BPF_OR, R0, 0xa0b0c0d0),
6408 			BPF_EXIT_INSN(),
6409 		},
6410 		INTERNAL,
6411 		{ },
6412 		{ { 0, 0xa1b2c3d4 } }
6413 	},
6414 	{
6415 		"ALU_OR_K: Zero extension",
6416 		.u.insns_int = {
6417 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6418 			BPF_LD_IMM64(R1, 0x00000000f9fbfdffLL),
6419 			BPF_ALU32_IMM(BPF_OR, R0, 0xf0f0f0f0),
6420 			BPF_JMP_REG(BPF_JEQ, R0, R1, 2),
6421 			BPF_MOV32_IMM(R0, 2),
6422 			BPF_EXIT_INSN(),
6423 			BPF_MOV32_IMM(R0, 1),
6424 			BPF_EXIT_INSN(),
6425 		},
6426 		INTERNAL,
6427 		{ },
6428 		{ { 0, 1 } }
6429 	},
6430 	{
6431 		"ALU64_OR_K: 1 | 2 = 3",
6432 		.u.insns_int = {
6433 			BPF_LD_IMM64(R0, 1),
6434 			BPF_ALU64_IMM(BPF_OR, R0, 2),
6435 			BPF_EXIT_INSN(),
6436 		},
6437 		INTERNAL,
6438 		{ },
6439 		{ { 0, 3 } },
6440 	},
6441 	{
6442 		"ALU64_OR_K: 0 & 0xffffffff = 0xffffffff",
6443 		.u.insns_int = {
6444 			BPF_LD_IMM64(R0, 0),
6445 			BPF_ALU64_IMM(BPF_OR, R0, 0xffffffff),
6446 			BPF_EXIT_INSN(),
6447 		},
6448 		INTERNAL,
6449 		{ },
6450 		{ { 0, 0xffffffff } },
6451 	},
6452 	{
6453 		"ALU64_OR_K: 0x0000ffffffff0000 | 0x0 = 0x0000ffffffff0000",
6454 		.u.insns_int = {
6455 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
6456 			BPF_LD_IMM64(R3, 0x0000ffffffff0000LL),
6457 			BPF_ALU64_IMM(BPF_OR, R2, 0x0),
6458 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
6459 			BPF_MOV32_IMM(R0, 2),
6460 			BPF_EXIT_INSN(),
6461 			BPF_MOV32_IMM(R0, 1),
6462 			BPF_EXIT_INSN(),
6463 		},
6464 		INTERNAL,
6465 		{ },
6466 		{ { 0, 0x1 } },
6467 	},
6468 	{
6469 		"ALU64_OR_K: 0x0000ffffffff0000 | -1 = 0xffffffffffffffff",
6470 		.u.insns_int = {
6471 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
6472 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
6473 			BPF_ALU64_IMM(BPF_OR, R2, 0xffffffff),
6474 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
6475 			BPF_MOV32_IMM(R0, 2),
6476 			BPF_EXIT_INSN(),
6477 			BPF_MOV32_IMM(R0, 1),
6478 			BPF_EXIT_INSN(),
6479 		},
6480 		INTERNAL,
6481 		{ },
6482 		{ { 0, 0x1 } },
6483 	},
6484 	{
6485 		"ALU64_OR_K: 0x000000000000000 | -1 = 0xffffffffffffffff",
6486 		.u.insns_int = {
6487 			BPF_LD_IMM64(R2, 0x0000000000000000LL),
6488 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
6489 			BPF_ALU64_IMM(BPF_OR, R2, 0xffffffff),
6490 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
6491 			BPF_MOV32_IMM(R0, 2),
6492 			BPF_EXIT_INSN(),
6493 			BPF_MOV32_IMM(R0, 1),
6494 			BPF_EXIT_INSN(),
6495 		},
6496 		INTERNAL,
6497 		{ },
6498 		{ { 0, 0x1 } },
6499 	},
6500 	{
6501 		"ALU64_OR_K: Sign extension 1",
6502 		.u.insns_int = {
6503 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6504 			BPF_LD_IMM64(R1, 0x012345678fafcfefLL),
6505 			BPF_ALU64_IMM(BPF_OR, R0, 0x0f0f0f0f),
6506 			BPF_JMP_REG(BPF_JEQ, R0, R1, 2),
6507 			BPF_MOV32_IMM(R0, 2),
6508 			BPF_EXIT_INSN(),
6509 			BPF_MOV32_IMM(R0, 1),
6510 			BPF_EXIT_INSN(),
6511 		},
6512 		INTERNAL,
6513 		{ },
6514 		{ { 0, 1 } }
6515 	},
6516 	{
6517 		"ALU64_OR_K: Sign extension 2",
6518 		.u.insns_int = {
6519 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6520 			BPF_LD_IMM64(R1, 0xfffffffff9fbfdffLL),
6521 			BPF_ALU64_IMM(BPF_OR, R0, 0xf0f0f0f0),
6522 			BPF_JMP_REG(BPF_JEQ, R0, R1, 2),
6523 			BPF_MOV32_IMM(R0, 2),
6524 			BPF_EXIT_INSN(),
6525 			BPF_MOV32_IMM(R0, 1),
6526 			BPF_EXIT_INSN(),
6527 		},
6528 		INTERNAL,
6529 		{ },
6530 		{ { 0, 1 } }
6531 	},
6532 	/* BPF_ALU | BPF_XOR | BPF_X */
6533 	{
6534 		"ALU_XOR_X: 5 ^ 6 = 3",
6535 		.u.insns_int = {
6536 			BPF_LD_IMM64(R0, 5),
6537 			BPF_ALU32_IMM(BPF_MOV, R1, 6),
6538 			BPF_ALU32_REG(BPF_XOR, R0, R1),
6539 			BPF_EXIT_INSN(),
6540 		},
6541 		INTERNAL,
6542 		{ },
6543 		{ { 0, 3 } },
6544 	},
6545 	{
6546 		"ALU_XOR_X: 0x1 ^ 0xffffffff = 0xfffffffe",
6547 		.u.insns_int = {
6548 			BPF_LD_IMM64(R0, 1),
6549 			BPF_ALU32_IMM(BPF_MOV, R1, 0xffffffff),
6550 			BPF_ALU32_REG(BPF_XOR, R0, R1),
6551 			BPF_EXIT_INSN(),
6552 		},
6553 		INTERNAL,
6554 		{ },
6555 		{ { 0, 0xfffffffe } },
6556 	},
6557 	{
6558 		"ALU64_XOR_X: 5 ^ 6 = 3",
6559 		.u.insns_int = {
6560 			BPF_LD_IMM64(R0, 5),
6561 			BPF_ALU32_IMM(BPF_MOV, R1, 6),
6562 			BPF_ALU64_REG(BPF_XOR, R0, R1),
6563 			BPF_EXIT_INSN(),
6564 		},
6565 		INTERNAL,
6566 		{ },
6567 		{ { 0, 3 } },
6568 	},
6569 	{
6570 		"ALU64_XOR_X: 1 ^ 0xffffffff = 0xfffffffe",
6571 		.u.insns_int = {
6572 			BPF_LD_IMM64(R0, 1),
6573 			BPF_ALU32_IMM(BPF_MOV, R1, 0xffffffff),
6574 			BPF_ALU64_REG(BPF_XOR, R0, R1),
6575 			BPF_EXIT_INSN(),
6576 		},
6577 		INTERNAL,
6578 		{ },
6579 		{ { 0, 0xfffffffe } },
6580 	},
6581 	/* BPF_ALU | BPF_XOR | BPF_K */
6582 	{
6583 		"ALU_XOR_K: 5 ^ 6 = 3",
6584 		.u.insns_int = {
6585 			BPF_LD_IMM64(R0, 5),
6586 			BPF_ALU32_IMM(BPF_XOR, R0, 6),
6587 			BPF_EXIT_INSN(),
6588 		},
6589 		INTERNAL,
6590 		{ },
6591 		{ { 0, 3 } },
6592 	},
6593 	{
6594 		"ALU_XOR_K: 1 ^ 0xffffffff = 0xfffffffe",
6595 		.u.insns_int = {
6596 			BPF_LD_IMM64(R0, 1),
6597 			BPF_ALU32_IMM(BPF_XOR, R0, 0xffffffff),
6598 			BPF_EXIT_INSN(),
6599 		},
6600 		INTERNAL,
6601 		{ },
6602 		{ { 0, 0xfffffffe } },
6603 	},
6604 	{
6605 		"ALU_XOR_K: Small immediate",
6606 		.u.insns_int = {
6607 			BPF_ALU32_IMM(BPF_MOV, R0, 0x01020304),
6608 			BPF_ALU32_IMM(BPF_XOR, R0, 15),
6609 			BPF_EXIT_INSN(),
6610 		},
6611 		INTERNAL,
6612 		{ },
6613 		{ { 0, 0x0102030b } }
6614 	},
6615 	{
6616 		"ALU_XOR_K: Large immediate",
6617 		.u.insns_int = {
6618 			BPF_ALU32_IMM(BPF_MOV, R0, 0xf1f2f3f4),
6619 			BPF_ALU32_IMM(BPF_XOR, R0, 0xafbfcfdf),
6620 			BPF_EXIT_INSN(),
6621 		},
6622 		INTERNAL,
6623 		{ },
6624 		{ { 0, 0x5e4d3c2b } }
6625 	},
6626 	{
6627 		"ALU_XOR_K: Zero extension",
6628 		.u.insns_int = {
6629 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6630 			BPF_LD_IMM64(R1, 0x00000000795b3d1fLL),
6631 			BPF_ALU32_IMM(BPF_XOR, R0, 0xf0f0f0f0),
6632 			BPF_JMP_REG(BPF_JEQ, R0, R1, 2),
6633 			BPF_MOV32_IMM(R0, 2),
6634 			BPF_EXIT_INSN(),
6635 			BPF_MOV32_IMM(R0, 1),
6636 			BPF_EXIT_INSN(),
6637 		},
6638 		INTERNAL,
6639 		{ },
6640 		{ { 0, 1 } }
6641 	},
6642 	{
6643 		"ALU64_XOR_K: 5 ^ 6 = 3",
6644 		.u.insns_int = {
6645 			BPF_LD_IMM64(R0, 5),
6646 			BPF_ALU64_IMM(BPF_XOR, R0, 6),
6647 			BPF_EXIT_INSN(),
6648 		},
6649 		INTERNAL,
6650 		{ },
6651 		{ { 0, 3 } },
6652 	},
6653 	{
6654 		"ALU64_XOR_K: 1 ^ 0xffffffff = 0xfffffffe",
6655 		.u.insns_int = {
6656 			BPF_LD_IMM64(R0, 1),
6657 			BPF_ALU64_IMM(BPF_XOR, R0, 0xffffffff),
6658 			BPF_EXIT_INSN(),
6659 		},
6660 		INTERNAL,
6661 		{ },
6662 		{ { 0, 0xfffffffe } },
6663 	},
6664 	{
6665 		"ALU64_XOR_K: 0x0000ffffffff0000 ^ 0x0 = 0x0000ffffffff0000",
6666 		.u.insns_int = {
6667 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
6668 			BPF_LD_IMM64(R3, 0x0000ffffffff0000LL),
6669 			BPF_ALU64_IMM(BPF_XOR, R2, 0x0),
6670 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
6671 			BPF_MOV32_IMM(R0, 2),
6672 			BPF_EXIT_INSN(),
6673 			BPF_MOV32_IMM(R0, 1),
6674 			BPF_EXIT_INSN(),
6675 		},
6676 		INTERNAL,
6677 		{ },
6678 		{ { 0, 0x1 } },
6679 	},
6680 	{
6681 		"ALU64_XOR_K: 0x0000ffffffff0000 ^ -1 = 0xffff00000000ffff",
6682 		.u.insns_int = {
6683 			BPF_LD_IMM64(R2, 0x0000ffffffff0000LL),
6684 			BPF_LD_IMM64(R3, 0xffff00000000ffffLL),
6685 			BPF_ALU64_IMM(BPF_XOR, R2, 0xffffffff),
6686 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
6687 			BPF_MOV32_IMM(R0, 2),
6688 			BPF_EXIT_INSN(),
6689 			BPF_MOV32_IMM(R0, 1),
6690 			BPF_EXIT_INSN(),
6691 		},
6692 		INTERNAL,
6693 		{ },
6694 		{ { 0, 0x1 } },
6695 	},
6696 	{
6697 		"ALU64_XOR_K: 0x000000000000000 ^ -1 = 0xffffffffffffffff",
6698 		.u.insns_int = {
6699 			BPF_LD_IMM64(R2, 0x0000000000000000LL),
6700 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
6701 			BPF_ALU64_IMM(BPF_XOR, R2, 0xffffffff),
6702 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
6703 			BPF_MOV32_IMM(R0, 2),
6704 			BPF_EXIT_INSN(),
6705 			BPF_MOV32_IMM(R0, 1),
6706 			BPF_EXIT_INSN(),
6707 		},
6708 		INTERNAL,
6709 		{ },
6710 		{ { 0, 0x1 } },
6711 	},
6712 	{
6713 		"ALU64_XOR_K: Sign extension 1",
6714 		.u.insns_int = {
6715 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6716 			BPF_LD_IMM64(R1, 0x0123456786a4c2e0LL),
6717 			BPF_ALU64_IMM(BPF_XOR, R0, 0x0f0f0f0f),
6718 			BPF_JMP_REG(BPF_JEQ, R0, R1, 2),
6719 			BPF_MOV32_IMM(R0, 2),
6720 			BPF_EXIT_INSN(),
6721 			BPF_MOV32_IMM(R0, 1),
6722 			BPF_EXIT_INSN(),
6723 		},
6724 		INTERNAL,
6725 		{ },
6726 		{ { 0, 1 } }
6727 	},
6728 	{
6729 		"ALU64_XOR_K: Sign extension 2",
6730 		.u.insns_int = {
6731 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6732 			BPF_LD_IMM64(R1, 0xfedcba98795b3d1fLL),
6733 			BPF_ALU64_IMM(BPF_XOR, R0, 0xf0f0f0f0),
6734 			BPF_JMP_REG(BPF_JEQ, R0, R1, 2),
6735 			BPF_MOV32_IMM(R0, 2),
6736 			BPF_EXIT_INSN(),
6737 			BPF_MOV32_IMM(R0, 1),
6738 			BPF_EXIT_INSN(),
6739 		},
6740 		INTERNAL,
6741 		{ },
6742 		{ { 0, 1 } }
6743 	},
6744 	/* BPF_ALU | BPF_LSH | BPF_X */
6745 	{
6746 		"ALU_LSH_X: 1 << 1 = 2",
6747 		.u.insns_int = {
6748 			BPF_LD_IMM64(R0, 1),
6749 			BPF_ALU32_IMM(BPF_MOV, R1, 1),
6750 			BPF_ALU32_REG(BPF_LSH, R0, R1),
6751 			BPF_EXIT_INSN(),
6752 		},
6753 		INTERNAL,
6754 		{ },
6755 		{ { 0, 2 } },
6756 	},
6757 	{
6758 		"ALU_LSH_X: 1 << 31 = 0x80000000",
6759 		.u.insns_int = {
6760 			BPF_LD_IMM64(R0, 1),
6761 			BPF_ALU32_IMM(BPF_MOV, R1, 31),
6762 			BPF_ALU32_REG(BPF_LSH, R0, R1),
6763 			BPF_EXIT_INSN(),
6764 		},
6765 		INTERNAL,
6766 		{ },
6767 		{ { 0, 0x80000000 } },
6768 	},
6769 	{
6770 		"ALU_LSH_X: 0x12345678 << 12 = 0x45678000",
6771 		.u.insns_int = {
6772 			BPF_ALU32_IMM(BPF_MOV, R0, 0x12345678),
6773 			BPF_ALU32_IMM(BPF_MOV, R1, 12),
6774 			BPF_ALU32_REG(BPF_LSH, R0, R1),
6775 			BPF_EXIT_INSN(),
6776 		},
6777 		INTERNAL,
6778 		{ },
6779 		{ { 0, 0x45678000 } }
6780 	},
6781 	{
6782 		"ALU64_LSH_X: 1 << 1 = 2",
6783 		.u.insns_int = {
6784 			BPF_LD_IMM64(R0, 1),
6785 			BPF_ALU32_IMM(BPF_MOV, R1, 1),
6786 			BPF_ALU64_REG(BPF_LSH, R0, R1),
6787 			BPF_EXIT_INSN(),
6788 		},
6789 		INTERNAL,
6790 		{ },
6791 		{ { 0, 2 } },
6792 	},
6793 	{
6794 		"ALU64_LSH_X: 1 << 31 = 0x80000000",
6795 		.u.insns_int = {
6796 			BPF_LD_IMM64(R0, 1),
6797 			BPF_ALU32_IMM(BPF_MOV, R1, 31),
6798 			BPF_ALU64_REG(BPF_LSH, R0, R1),
6799 			BPF_EXIT_INSN(),
6800 		},
6801 		INTERNAL,
6802 		{ },
6803 		{ { 0, 0x80000000 } },
6804 	},
6805 	{
6806 		"ALU64_LSH_X: Shift < 32, low word",
6807 		.u.insns_int = {
6808 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6809 			BPF_ALU32_IMM(BPF_MOV, R1, 12),
6810 			BPF_ALU64_REG(BPF_LSH, R0, R1),
6811 			BPF_EXIT_INSN(),
6812 		},
6813 		INTERNAL,
6814 		{ },
6815 		{ { 0, 0xbcdef000 } }
6816 	},
6817 	{
6818 		"ALU64_LSH_X: Shift < 32, high word",
6819 		.u.insns_int = {
6820 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6821 			BPF_ALU32_IMM(BPF_MOV, R1, 12),
6822 			BPF_ALU64_REG(BPF_LSH, R0, R1),
6823 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
6824 			BPF_EXIT_INSN(),
6825 		},
6826 		INTERNAL,
6827 		{ },
6828 		{ { 0, 0x3456789a } }
6829 	},
6830 	{
6831 		"ALU64_LSH_X: Shift > 32, low word",
6832 		.u.insns_int = {
6833 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6834 			BPF_ALU32_IMM(BPF_MOV, R1, 36),
6835 			BPF_ALU64_REG(BPF_LSH, R0, R1),
6836 			BPF_EXIT_INSN(),
6837 		},
6838 		INTERNAL,
6839 		{ },
6840 		{ { 0, 0 } }
6841 	},
6842 	{
6843 		"ALU64_LSH_X: Shift > 32, high word",
6844 		.u.insns_int = {
6845 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6846 			BPF_ALU32_IMM(BPF_MOV, R1, 36),
6847 			BPF_ALU64_REG(BPF_LSH, R0, R1),
6848 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
6849 			BPF_EXIT_INSN(),
6850 		},
6851 		INTERNAL,
6852 		{ },
6853 		{ { 0, 0x9abcdef0 } }
6854 	},
6855 	{
6856 		"ALU64_LSH_X: Shift == 32, low word",
6857 		.u.insns_int = {
6858 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6859 			BPF_ALU32_IMM(BPF_MOV, R1, 32),
6860 			BPF_ALU64_REG(BPF_LSH, R0, R1),
6861 			BPF_EXIT_INSN(),
6862 		},
6863 		INTERNAL,
6864 		{ },
6865 		{ { 0, 0 } }
6866 	},
6867 	{
6868 		"ALU64_LSH_X: Shift == 32, high word",
6869 		.u.insns_int = {
6870 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6871 			BPF_ALU32_IMM(BPF_MOV, R1, 32),
6872 			BPF_ALU64_REG(BPF_LSH, R0, R1),
6873 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
6874 			BPF_EXIT_INSN(),
6875 		},
6876 		INTERNAL,
6877 		{ },
6878 		{ { 0, 0x89abcdef } }
6879 	},
6880 	{
6881 		"ALU64_LSH_X: Zero shift, low word",
6882 		.u.insns_int = {
6883 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6884 			BPF_ALU32_IMM(BPF_MOV, R1, 0),
6885 			BPF_ALU64_REG(BPF_LSH, R0, R1),
6886 			BPF_EXIT_INSN(),
6887 		},
6888 		INTERNAL,
6889 		{ },
6890 		{ { 0, 0x89abcdef } }
6891 	},
6892 	{
6893 		"ALU64_LSH_X: Zero shift, high word",
6894 		.u.insns_int = {
6895 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6896 			BPF_ALU32_IMM(BPF_MOV, R1, 0),
6897 			BPF_ALU64_REG(BPF_LSH, R0, R1),
6898 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
6899 			BPF_EXIT_INSN(),
6900 		},
6901 		INTERNAL,
6902 		{ },
6903 		{ { 0, 0x01234567 } }
6904 	},
6905 	/* BPF_ALU | BPF_LSH | BPF_K */
6906 	{
6907 		"ALU_LSH_K: 1 << 1 = 2",
6908 		.u.insns_int = {
6909 			BPF_LD_IMM64(R0, 1),
6910 			BPF_ALU32_IMM(BPF_LSH, R0, 1),
6911 			BPF_EXIT_INSN(),
6912 		},
6913 		INTERNAL,
6914 		{ },
6915 		{ { 0, 2 } },
6916 	},
6917 	{
6918 		"ALU_LSH_K: 1 << 31 = 0x80000000",
6919 		.u.insns_int = {
6920 			BPF_LD_IMM64(R0, 1),
6921 			BPF_ALU32_IMM(BPF_LSH, R0, 31),
6922 			BPF_EXIT_INSN(),
6923 		},
6924 		INTERNAL,
6925 		{ },
6926 		{ { 0, 0x80000000 } },
6927 	},
6928 	{
6929 		"ALU_LSH_K: 0x12345678 << 12 = 0x45678000",
6930 		.u.insns_int = {
6931 			BPF_ALU32_IMM(BPF_MOV, R0, 0x12345678),
6932 			BPF_ALU32_IMM(BPF_LSH, R0, 12),
6933 			BPF_EXIT_INSN(),
6934 		},
6935 		INTERNAL,
6936 		{ },
6937 		{ { 0, 0x45678000 } }
6938 	},
6939 	{
6940 		"ALU_LSH_K: 0x12345678 << 0 = 0x12345678",
6941 		.u.insns_int = {
6942 			BPF_ALU32_IMM(BPF_MOV, R0, 0x12345678),
6943 			BPF_ALU32_IMM(BPF_LSH, R0, 0),
6944 			BPF_EXIT_INSN(),
6945 		},
6946 		INTERNAL,
6947 		{ },
6948 		{ { 0, 0x12345678 } }
6949 	},
6950 	{
6951 		"ALU64_LSH_K: 1 << 1 = 2",
6952 		.u.insns_int = {
6953 			BPF_LD_IMM64(R0, 1),
6954 			BPF_ALU64_IMM(BPF_LSH, R0, 1),
6955 			BPF_EXIT_INSN(),
6956 		},
6957 		INTERNAL,
6958 		{ },
6959 		{ { 0, 2 } },
6960 	},
6961 	{
6962 		"ALU64_LSH_K: 1 << 31 = 0x80000000",
6963 		.u.insns_int = {
6964 			BPF_LD_IMM64(R0, 1),
6965 			BPF_ALU64_IMM(BPF_LSH, R0, 31),
6966 			BPF_EXIT_INSN(),
6967 		},
6968 		INTERNAL,
6969 		{ },
6970 		{ { 0, 0x80000000 } },
6971 	},
6972 	{
6973 		"ALU64_LSH_K: Shift < 32, low word",
6974 		.u.insns_int = {
6975 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6976 			BPF_ALU64_IMM(BPF_LSH, R0, 12),
6977 			BPF_EXIT_INSN(),
6978 		},
6979 		INTERNAL,
6980 		{ },
6981 		{ { 0, 0xbcdef000 } }
6982 	},
6983 	{
6984 		"ALU64_LSH_K: Shift < 32, high word",
6985 		.u.insns_int = {
6986 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6987 			BPF_ALU64_IMM(BPF_LSH, R0, 12),
6988 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
6989 			BPF_EXIT_INSN(),
6990 		},
6991 		INTERNAL,
6992 		{ },
6993 		{ { 0, 0x3456789a } }
6994 	},
6995 	{
6996 		"ALU64_LSH_K: Shift > 32, low word",
6997 		.u.insns_int = {
6998 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
6999 			BPF_ALU64_IMM(BPF_LSH, R0, 36),
7000 			BPF_EXIT_INSN(),
7001 		},
7002 		INTERNAL,
7003 		{ },
7004 		{ { 0, 0 } }
7005 	},
7006 	{
7007 		"ALU64_LSH_K: Shift > 32, high word",
7008 		.u.insns_int = {
7009 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
7010 			BPF_ALU64_IMM(BPF_LSH, R0, 36),
7011 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7012 			BPF_EXIT_INSN(),
7013 		},
7014 		INTERNAL,
7015 		{ },
7016 		{ { 0, 0x9abcdef0 } }
7017 	},
7018 	{
7019 		"ALU64_LSH_K: Shift == 32, low word",
7020 		.u.insns_int = {
7021 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
7022 			BPF_ALU64_IMM(BPF_LSH, R0, 32),
7023 			BPF_EXIT_INSN(),
7024 		},
7025 		INTERNAL,
7026 		{ },
7027 		{ { 0, 0 } }
7028 	},
7029 	{
7030 		"ALU64_LSH_K: Shift == 32, high word",
7031 		.u.insns_int = {
7032 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
7033 			BPF_ALU64_IMM(BPF_LSH, R0, 32),
7034 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7035 			BPF_EXIT_INSN(),
7036 		},
7037 		INTERNAL,
7038 		{ },
7039 		{ { 0, 0x89abcdef } }
7040 	},
7041 	{
7042 		"ALU64_LSH_K: Zero shift",
7043 		.u.insns_int = {
7044 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
7045 			BPF_ALU64_IMM(BPF_LSH, R0, 0),
7046 			BPF_EXIT_INSN(),
7047 		},
7048 		INTERNAL,
7049 		{ },
7050 		{ { 0, 0x89abcdef } }
7051 	},
7052 	/* BPF_ALU | BPF_RSH | BPF_X */
7053 	{
7054 		"ALU_RSH_X: 2 >> 1 = 1",
7055 		.u.insns_int = {
7056 			BPF_LD_IMM64(R0, 2),
7057 			BPF_ALU32_IMM(BPF_MOV, R1, 1),
7058 			BPF_ALU32_REG(BPF_RSH, R0, R1),
7059 			BPF_EXIT_INSN(),
7060 		},
7061 		INTERNAL,
7062 		{ },
7063 		{ { 0, 1 } },
7064 	},
7065 	{
7066 		"ALU_RSH_X: 0x80000000 >> 31 = 1",
7067 		.u.insns_int = {
7068 			BPF_LD_IMM64(R0, 0x80000000),
7069 			BPF_ALU32_IMM(BPF_MOV, R1, 31),
7070 			BPF_ALU32_REG(BPF_RSH, R0, R1),
7071 			BPF_EXIT_INSN(),
7072 		},
7073 		INTERNAL,
7074 		{ },
7075 		{ { 0, 1 } },
7076 	},
7077 	{
7078 		"ALU_RSH_X: 0x12345678 >> 20 = 0x123",
7079 		.u.insns_int = {
7080 			BPF_ALU32_IMM(BPF_MOV, R0, 0x12345678),
7081 			BPF_ALU32_IMM(BPF_MOV, R1, 20),
7082 			BPF_ALU32_REG(BPF_RSH, R0, R1),
7083 			BPF_EXIT_INSN(),
7084 		},
7085 		INTERNAL,
7086 		{ },
7087 		{ { 0, 0x123 } }
7088 	},
7089 	{
7090 		"ALU64_RSH_X: 2 >> 1 = 1",
7091 		.u.insns_int = {
7092 			BPF_LD_IMM64(R0, 2),
7093 			BPF_ALU32_IMM(BPF_MOV, R1, 1),
7094 			BPF_ALU64_REG(BPF_RSH, R0, R1),
7095 			BPF_EXIT_INSN(),
7096 		},
7097 		INTERNAL,
7098 		{ },
7099 		{ { 0, 1 } },
7100 	},
7101 	{
7102 		"ALU64_RSH_X: 0x80000000 >> 31 = 1",
7103 		.u.insns_int = {
7104 			BPF_LD_IMM64(R0, 0x80000000),
7105 			BPF_ALU32_IMM(BPF_MOV, R1, 31),
7106 			BPF_ALU64_REG(BPF_RSH, R0, R1),
7107 			BPF_EXIT_INSN(),
7108 		},
7109 		INTERNAL,
7110 		{ },
7111 		{ { 0, 1 } },
7112 	},
7113 	{
7114 		"ALU64_RSH_X: Shift < 32, low word",
7115 		.u.insns_int = {
7116 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7117 			BPF_ALU32_IMM(BPF_MOV, R1, 12),
7118 			BPF_ALU64_REG(BPF_RSH, R0, R1),
7119 			BPF_EXIT_INSN(),
7120 		},
7121 		INTERNAL,
7122 		{ },
7123 		{ { 0, 0x56789abc } }
7124 	},
7125 	{
7126 		"ALU64_RSH_X: Shift < 32, high word",
7127 		.u.insns_int = {
7128 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7129 			BPF_ALU32_IMM(BPF_MOV, R1, 12),
7130 			BPF_ALU64_REG(BPF_RSH, R0, R1),
7131 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7132 			BPF_EXIT_INSN(),
7133 		},
7134 		INTERNAL,
7135 		{ },
7136 		{ { 0, 0x00081234 } }
7137 	},
7138 	{
7139 		"ALU64_RSH_X: Shift > 32, low word",
7140 		.u.insns_int = {
7141 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7142 			BPF_ALU32_IMM(BPF_MOV, R1, 36),
7143 			BPF_ALU64_REG(BPF_RSH, R0, R1),
7144 			BPF_EXIT_INSN(),
7145 		},
7146 		INTERNAL,
7147 		{ },
7148 		{ { 0, 0x08123456 } }
7149 	},
7150 	{
7151 		"ALU64_RSH_X: Shift > 32, high word",
7152 		.u.insns_int = {
7153 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7154 			BPF_ALU32_IMM(BPF_MOV, R1, 36),
7155 			BPF_ALU64_REG(BPF_RSH, R0, R1),
7156 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7157 			BPF_EXIT_INSN(),
7158 		},
7159 		INTERNAL,
7160 		{ },
7161 		{ { 0, 0 } }
7162 	},
7163 	{
7164 		"ALU64_RSH_X: Shift == 32, low word",
7165 		.u.insns_int = {
7166 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7167 			BPF_ALU32_IMM(BPF_MOV, R1, 32),
7168 			BPF_ALU64_REG(BPF_RSH, R0, R1),
7169 			BPF_EXIT_INSN(),
7170 		},
7171 		INTERNAL,
7172 		{ },
7173 		{ { 0, 0x81234567 } }
7174 	},
7175 	{
7176 		"ALU64_RSH_X: Shift == 32, high word",
7177 		.u.insns_int = {
7178 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7179 			BPF_ALU32_IMM(BPF_MOV, R1, 32),
7180 			BPF_ALU64_REG(BPF_RSH, R0, R1),
7181 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7182 			BPF_EXIT_INSN(),
7183 		},
7184 		INTERNAL,
7185 		{ },
7186 		{ { 0, 0 } }
7187 	},
7188 	{
7189 		"ALU64_RSH_X: Zero shift, low word",
7190 		.u.insns_int = {
7191 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7192 			BPF_ALU32_IMM(BPF_MOV, R1, 0),
7193 			BPF_ALU64_REG(BPF_RSH, R0, R1),
7194 			BPF_EXIT_INSN(),
7195 		},
7196 		INTERNAL,
7197 		{ },
7198 		{ { 0, 0x89abcdef } }
7199 	},
7200 	{
7201 		"ALU64_RSH_X: Zero shift, high word",
7202 		.u.insns_int = {
7203 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7204 			BPF_ALU32_IMM(BPF_MOV, R1, 0),
7205 			BPF_ALU64_REG(BPF_RSH, R0, R1),
7206 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7207 			BPF_EXIT_INSN(),
7208 		},
7209 		INTERNAL,
7210 		{ },
7211 		{ { 0, 0x81234567 } }
7212 	},
7213 	/* BPF_ALU | BPF_RSH | BPF_K */
7214 	{
7215 		"ALU_RSH_K: 2 >> 1 = 1",
7216 		.u.insns_int = {
7217 			BPF_LD_IMM64(R0, 2),
7218 			BPF_ALU32_IMM(BPF_RSH, R0, 1),
7219 			BPF_EXIT_INSN(),
7220 		},
7221 		INTERNAL,
7222 		{ },
7223 		{ { 0, 1 } },
7224 	},
7225 	{
7226 		"ALU_RSH_K: 0x80000000 >> 31 = 1",
7227 		.u.insns_int = {
7228 			BPF_LD_IMM64(R0, 0x80000000),
7229 			BPF_ALU32_IMM(BPF_RSH, R0, 31),
7230 			BPF_EXIT_INSN(),
7231 		},
7232 		INTERNAL,
7233 		{ },
7234 		{ { 0, 1 } },
7235 	},
7236 	{
7237 		"ALU_RSH_K: 0x12345678 >> 20 = 0x123",
7238 		.u.insns_int = {
7239 			BPF_ALU32_IMM(BPF_MOV, R0, 0x12345678),
7240 			BPF_ALU32_IMM(BPF_RSH, R0, 20),
7241 			BPF_EXIT_INSN(),
7242 		},
7243 		INTERNAL,
7244 		{ },
7245 		{ { 0, 0x123 } }
7246 	},
7247 	{
7248 		"ALU_RSH_K: 0x12345678 >> 0 = 0x12345678",
7249 		.u.insns_int = {
7250 			BPF_ALU32_IMM(BPF_MOV, R0, 0x12345678),
7251 			BPF_ALU32_IMM(BPF_RSH, R0, 0),
7252 			BPF_EXIT_INSN(),
7253 		},
7254 		INTERNAL,
7255 		{ },
7256 		{ { 0, 0x12345678 } }
7257 	},
7258 	{
7259 		"ALU64_RSH_K: 2 >> 1 = 1",
7260 		.u.insns_int = {
7261 			BPF_LD_IMM64(R0, 2),
7262 			BPF_ALU64_IMM(BPF_RSH, R0, 1),
7263 			BPF_EXIT_INSN(),
7264 		},
7265 		INTERNAL,
7266 		{ },
7267 		{ { 0, 1 } },
7268 	},
7269 	{
7270 		"ALU64_RSH_K: 0x80000000 >> 31 = 1",
7271 		.u.insns_int = {
7272 			BPF_LD_IMM64(R0, 0x80000000),
7273 			BPF_ALU64_IMM(BPF_RSH, R0, 31),
7274 			BPF_EXIT_INSN(),
7275 		},
7276 		INTERNAL,
7277 		{ },
7278 		{ { 0, 1 } },
7279 	},
7280 	{
7281 		"ALU64_RSH_K: Shift < 32, low word",
7282 		.u.insns_int = {
7283 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7284 			BPF_ALU64_IMM(BPF_RSH, R0, 12),
7285 			BPF_EXIT_INSN(),
7286 		},
7287 		INTERNAL,
7288 		{ },
7289 		{ { 0, 0x56789abc } }
7290 	},
7291 	{
7292 		"ALU64_RSH_K: Shift < 32, high word",
7293 		.u.insns_int = {
7294 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7295 			BPF_ALU64_IMM(BPF_RSH, R0, 12),
7296 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7297 			BPF_EXIT_INSN(),
7298 		},
7299 		INTERNAL,
7300 		{ },
7301 		{ { 0, 0x00081234 } }
7302 	},
7303 	{
7304 		"ALU64_RSH_K: Shift > 32, low word",
7305 		.u.insns_int = {
7306 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7307 			BPF_ALU64_IMM(BPF_RSH, R0, 36),
7308 			BPF_EXIT_INSN(),
7309 		},
7310 		INTERNAL,
7311 		{ },
7312 		{ { 0, 0x08123456 } }
7313 	},
7314 	{
7315 		"ALU64_RSH_K: Shift > 32, high word",
7316 		.u.insns_int = {
7317 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7318 			BPF_ALU64_IMM(BPF_RSH, R0, 36),
7319 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7320 			BPF_EXIT_INSN(),
7321 		},
7322 		INTERNAL,
7323 		{ },
7324 		{ { 0, 0 } }
7325 	},
7326 	{
7327 		"ALU64_RSH_K: Shift == 32, low word",
7328 		.u.insns_int = {
7329 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7330 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7331 			BPF_EXIT_INSN(),
7332 		},
7333 		INTERNAL,
7334 		{ },
7335 		{ { 0, 0x81234567 } }
7336 	},
7337 	{
7338 		"ALU64_RSH_K: Shift == 32, high word",
7339 		.u.insns_int = {
7340 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7341 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7342 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7343 			BPF_EXIT_INSN(),
7344 		},
7345 		INTERNAL,
7346 		{ },
7347 		{ { 0, 0 } }
7348 	},
7349 	{
7350 		"ALU64_RSH_K: Zero shift",
7351 		.u.insns_int = {
7352 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
7353 			BPF_ALU64_IMM(BPF_RSH, R0, 0),
7354 			BPF_EXIT_INSN(),
7355 		},
7356 		INTERNAL,
7357 		{ },
7358 		{ { 0, 0x89abcdef } }
7359 	},
7360 	/* BPF_ALU | BPF_ARSH | BPF_X */
7361 	{
7362 		"ALU32_ARSH_X: -1234 >> 7 = -10",
7363 		.u.insns_int = {
7364 			BPF_ALU32_IMM(BPF_MOV, R0, -1234),
7365 			BPF_ALU32_IMM(BPF_MOV, R1, 7),
7366 			BPF_ALU32_REG(BPF_ARSH, R0, R1),
7367 			BPF_EXIT_INSN(),
7368 		},
7369 		INTERNAL,
7370 		{ },
7371 		{ { 0, -10 } }
7372 	},
7373 	{
7374 		"ALU64_ARSH_X: 0xff00ff0000000000 >> 40 = 0xffffffffffff00ff",
7375 		.u.insns_int = {
7376 			BPF_LD_IMM64(R0, 0xff00ff0000000000LL),
7377 			BPF_ALU32_IMM(BPF_MOV, R1, 40),
7378 			BPF_ALU64_REG(BPF_ARSH, R0, R1),
7379 			BPF_EXIT_INSN(),
7380 		},
7381 		INTERNAL,
7382 		{ },
7383 		{ { 0, 0xffff00ff } },
7384 	},
7385 	{
7386 		"ALU64_ARSH_X: Shift < 32, low word",
7387 		.u.insns_int = {
7388 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7389 			BPF_ALU32_IMM(BPF_MOV, R1, 12),
7390 			BPF_ALU64_REG(BPF_ARSH, R0, R1),
7391 			BPF_EXIT_INSN(),
7392 		},
7393 		INTERNAL,
7394 		{ },
7395 		{ { 0, 0x56789abc } }
7396 	},
7397 	{
7398 		"ALU64_ARSH_X: Shift < 32, high word",
7399 		.u.insns_int = {
7400 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7401 			BPF_ALU32_IMM(BPF_MOV, R1, 12),
7402 			BPF_ALU64_REG(BPF_ARSH, R0, R1),
7403 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7404 			BPF_EXIT_INSN(),
7405 		},
7406 		INTERNAL,
7407 		{ },
7408 		{ { 0, 0xfff81234 } }
7409 	},
7410 	{
7411 		"ALU64_ARSH_X: Shift > 32, low word",
7412 		.u.insns_int = {
7413 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7414 			BPF_ALU32_IMM(BPF_MOV, R1, 36),
7415 			BPF_ALU64_REG(BPF_ARSH, R0, R1),
7416 			BPF_EXIT_INSN(),
7417 		},
7418 		INTERNAL,
7419 		{ },
7420 		{ { 0, 0xf8123456 } }
7421 	},
7422 	{
7423 		"ALU64_ARSH_X: Shift > 32, high word",
7424 		.u.insns_int = {
7425 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7426 			BPF_ALU32_IMM(BPF_MOV, R1, 36),
7427 			BPF_ALU64_REG(BPF_ARSH, R0, R1),
7428 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7429 			BPF_EXIT_INSN(),
7430 		},
7431 		INTERNAL,
7432 		{ },
7433 		{ { 0, -1 } }
7434 	},
7435 	{
7436 		"ALU64_ARSH_X: Shift == 32, low word",
7437 		.u.insns_int = {
7438 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7439 			BPF_ALU32_IMM(BPF_MOV, R1, 32),
7440 			BPF_ALU64_REG(BPF_ARSH, R0, R1),
7441 			BPF_EXIT_INSN(),
7442 		},
7443 		INTERNAL,
7444 		{ },
7445 		{ { 0, 0x81234567 } }
7446 	},
7447 	{
7448 		"ALU64_ARSH_X: Shift == 32, high word",
7449 		.u.insns_int = {
7450 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7451 			BPF_ALU32_IMM(BPF_MOV, R1, 32),
7452 			BPF_ALU64_REG(BPF_ARSH, R0, R1),
7453 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7454 			BPF_EXIT_INSN(),
7455 		},
7456 		INTERNAL,
7457 		{ },
7458 		{ { 0, -1 } }
7459 	},
7460 	{
7461 		"ALU64_ARSH_X: Zero shift, low word",
7462 		.u.insns_int = {
7463 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7464 			BPF_ALU32_IMM(BPF_MOV, R1, 0),
7465 			BPF_ALU64_REG(BPF_ARSH, R0, R1),
7466 			BPF_EXIT_INSN(),
7467 		},
7468 		INTERNAL,
7469 		{ },
7470 		{ { 0, 0x89abcdef } }
7471 	},
7472 	{
7473 		"ALU64_ARSH_X: Zero shift, high word",
7474 		.u.insns_int = {
7475 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7476 			BPF_ALU32_IMM(BPF_MOV, R1, 0),
7477 			BPF_ALU64_REG(BPF_ARSH, R0, R1),
7478 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7479 			BPF_EXIT_INSN(),
7480 		},
7481 		INTERNAL,
7482 		{ },
7483 		{ { 0, 0x81234567 } }
7484 	},
7485 	/* BPF_ALU | BPF_ARSH | BPF_K */
7486 	{
7487 		"ALU32_ARSH_K: -1234 >> 7 = -10",
7488 		.u.insns_int = {
7489 			BPF_ALU32_IMM(BPF_MOV, R0, -1234),
7490 			BPF_ALU32_IMM(BPF_ARSH, R0, 7),
7491 			BPF_EXIT_INSN(),
7492 		},
7493 		INTERNAL,
7494 		{ },
7495 		{ { 0, -10 } }
7496 	},
7497 	{
7498 		"ALU32_ARSH_K: -1234 >> 0 = -1234",
7499 		.u.insns_int = {
7500 			BPF_ALU32_IMM(BPF_MOV, R0, -1234),
7501 			BPF_ALU32_IMM(BPF_ARSH, R0, 0),
7502 			BPF_EXIT_INSN(),
7503 		},
7504 		INTERNAL,
7505 		{ },
7506 		{ { 0, -1234 } }
7507 	},
7508 	{
7509 		"ALU64_ARSH_K: 0xff00ff0000000000 >> 40 = 0xffffffffffff00ff",
7510 		.u.insns_int = {
7511 			BPF_LD_IMM64(R0, 0xff00ff0000000000LL),
7512 			BPF_ALU64_IMM(BPF_ARSH, R0, 40),
7513 			BPF_EXIT_INSN(),
7514 		},
7515 		INTERNAL,
7516 		{ },
7517 		{ { 0, 0xffff00ff } },
7518 	},
7519 	{
7520 		"ALU64_ARSH_K: Shift < 32, low word",
7521 		.u.insns_int = {
7522 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7523 			BPF_ALU64_IMM(BPF_RSH, R0, 12),
7524 			BPF_EXIT_INSN(),
7525 		},
7526 		INTERNAL,
7527 		{ },
7528 		{ { 0, 0x56789abc } }
7529 	},
7530 	{
7531 		"ALU64_ARSH_K: Shift < 32, high word",
7532 		.u.insns_int = {
7533 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7534 			BPF_ALU64_IMM(BPF_ARSH, R0, 12),
7535 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7536 			BPF_EXIT_INSN(),
7537 		},
7538 		INTERNAL,
7539 		{ },
7540 		{ { 0, 0xfff81234 } }
7541 	},
7542 	{
7543 		"ALU64_ARSH_K: Shift > 32, low word",
7544 		.u.insns_int = {
7545 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7546 			BPF_ALU64_IMM(BPF_ARSH, R0, 36),
7547 			BPF_EXIT_INSN(),
7548 		},
7549 		INTERNAL,
7550 		{ },
7551 		{ { 0, 0xf8123456 } }
7552 	},
7553 	{
7554 		"ALU64_ARSH_K: Shift > 32, high word",
7555 		.u.insns_int = {
7556 			BPF_LD_IMM64(R0, 0xf123456789abcdefLL),
7557 			BPF_ALU64_IMM(BPF_ARSH, R0, 36),
7558 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7559 			BPF_EXIT_INSN(),
7560 		},
7561 		INTERNAL,
7562 		{ },
7563 		{ { 0, -1 } }
7564 	},
7565 	{
7566 		"ALU64_ARSH_K: Shift == 32, low word",
7567 		.u.insns_int = {
7568 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7569 			BPF_ALU64_IMM(BPF_ARSH, R0, 32),
7570 			BPF_EXIT_INSN(),
7571 		},
7572 		INTERNAL,
7573 		{ },
7574 		{ { 0, 0x81234567 } }
7575 	},
7576 	{
7577 		"ALU64_ARSH_K: Shift == 32, high word",
7578 		.u.insns_int = {
7579 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7580 			BPF_ALU64_IMM(BPF_ARSH, R0, 32),
7581 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7582 			BPF_EXIT_INSN(),
7583 		},
7584 		INTERNAL,
7585 		{ },
7586 		{ { 0, -1 } }
7587 	},
7588 	{
7589 		"ALU64_ARSH_K: Zero shift",
7590 		.u.insns_int = {
7591 			BPF_LD_IMM64(R0, 0x8123456789abcdefLL),
7592 			BPF_ALU64_IMM(BPF_ARSH, R0, 0),
7593 			BPF_EXIT_INSN(),
7594 		},
7595 		INTERNAL,
7596 		{ },
7597 		{ { 0, 0x89abcdef } }
7598 	},
7599 	/* BPF_ALU | BPF_NEG */
7600 	{
7601 		"ALU_NEG: -(3) = -3",
7602 		.u.insns_int = {
7603 			BPF_ALU32_IMM(BPF_MOV, R0, 3),
7604 			BPF_ALU32_IMM(BPF_NEG, R0, 0),
7605 			BPF_EXIT_INSN(),
7606 		},
7607 		INTERNAL,
7608 		{ },
7609 		{ { 0, -3 } },
7610 	},
7611 	{
7612 		"ALU_NEG: -(-3) = 3",
7613 		.u.insns_int = {
7614 			BPF_ALU32_IMM(BPF_MOV, R0, -3),
7615 			BPF_ALU32_IMM(BPF_NEG, R0, 0),
7616 			BPF_EXIT_INSN(),
7617 		},
7618 		INTERNAL,
7619 		{ },
7620 		{ { 0, 3 } },
7621 	},
7622 	{
7623 		"ALU64_NEG: -(3) = -3",
7624 		.u.insns_int = {
7625 			BPF_LD_IMM64(R0, 3),
7626 			BPF_ALU64_IMM(BPF_NEG, R0, 0),
7627 			BPF_EXIT_INSN(),
7628 		},
7629 		INTERNAL,
7630 		{ },
7631 		{ { 0, -3 } },
7632 	},
7633 	{
7634 		"ALU64_NEG: -(-3) = 3",
7635 		.u.insns_int = {
7636 			BPF_LD_IMM64(R0, -3),
7637 			BPF_ALU64_IMM(BPF_NEG, R0, 0),
7638 			BPF_EXIT_INSN(),
7639 		},
7640 		INTERNAL,
7641 		{ },
7642 		{ { 0, 3 } },
7643 	},
7644 	/* BPF_ALU | BPF_END | BPF_FROM_BE */
7645 	{
7646 		"ALU_END_FROM_BE 16: 0x0123456789abcdef -> 0xcdef",
7647 		.u.insns_int = {
7648 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
7649 			BPF_ENDIAN(BPF_FROM_BE, R0, 16),
7650 			BPF_EXIT_INSN(),
7651 		},
7652 		INTERNAL,
7653 		{ },
7654 		{ { 0,  cpu_to_be16(0xcdef) } },
7655 	},
7656 	{
7657 		"ALU_END_FROM_BE 32: 0x0123456789abcdef -> 0x89abcdef",
7658 		.u.insns_int = {
7659 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
7660 			BPF_ENDIAN(BPF_FROM_BE, R0, 32),
7661 			BPF_ALU64_REG(BPF_MOV, R1, R0),
7662 			BPF_ALU64_IMM(BPF_RSH, R1, 32),
7663 			BPF_ALU32_REG(BPF_ADD, R0, R1), /* R1 = 0 */
7664 			BPF_EXIT_INSN(),
7665 		},
7666 		INTERNAL,
7667 		{ },
7668 		{ { 0, cpu_to_be32(0x89abcdef) } },
7669 	},
7670 	{
7671 		"ALU_END_FROM_BE 64: 0x0123456789abcdef -> 0x89abcdef",
7672 		.u.insns_int = {
7673 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
7674 			BPF_ENDIAN(BPF_FROM_BE, R0, 64),
7675 			BPF_EXIT_INSN(),
7676 		},
7677 		INTERNAL,
7678 		{ },
7679 		{ { 0, (u32) cpu_to_be64(0x0123456789abcdefLL) } },
7680 	},
7681 	{
7682 		"ALU_END_FROM_BE 64: 0x0123456789abcdef >> 32 -> 0x01234567",
7683 		.u.insns_int = {
7684 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
7685 			BPF_ENDIAN(BPF_FROM_BE, R0, 64),
7686 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7687 			BPF_EXIT_INSN(),
7688 		},
7689 		INTERNAL,
7690 		{ },
7691 		{ { 0, (u32) (cpu_to_be64(0x0123456789abcdefLL) >> 32) } },
7692 	},
7693 	/* BPF_ALU | BPF_END | BPF_FROM_BE, reversed */
7694 	{
7695 		"ALU_END_FROM_BE 16: 0xfedcba9876543210 -> 0x3210",
7696 		.u.insns_int = {
7697 			BPF_LD_IMM64(R0, 0xfedcba9876543210ULL),
7698 			BPF_ENDIAN(BPF_FROM_BE, R0, 16),
7699 			BPF_EXIT_INSN(),
7700 		},
7701 		INTERNAL,
7702 		{ },
7703 		{ { 0,  cpu_to_be16(0x3210) } },
7704 	},
7705 	{
7706 		"ALU_END_FROM_BE 32: 0xfedcba9876543210 -> 0x76543210",
7707 		.u.insns_int = {
7708 			BPF_LD_IMM64(R0, 0xfedcba9876543210ULL),
7709 			BPF_ENDIAN(BPF_FROM_BE, R0, 32),
7710 			BPF_ALU64_REG(BPF_MOV, R1, R0),
7711 			BPF_ALU64_IMM(BPF_RSH, R1, 32),
7712 			BPF_ALU32_REG(BPF_ADD, R0, R1), /* R1 = 0 */
7713 			BPF_EXIT_INSN(),
7714 		},
7715 		INTERNAL,
7716 		{ },
7717 		{ { 0, cpu_to_be32(0x76543210) } },
7718 	},
7719 	{
7720 		"ALU_END_FROM_BE 64: 0xfedcba9876543210 -> 0x76543210",
7721 		.u.insns_int = {
7722 			BPF_LD_IMM64(R0, 0xfedcba9876543210ULL),
7723 			BPF_ENDIAN(BPF_FROM_BE, R0, 64),
7724 			BPF_EXIT_INSN(),
7725 		},
7726 		INTERNAL,
7727 		{ },
7728 		{ { 0, (u32) cpu_to_be64(0xfedcba9876543210ULL) } },
7729 	},
7730 	{
7731 		"ALU_END_FROM_BE 64: 0xfedcba9876543210 >> 32 -> 0xfedcba98",
7732 		.u.insns_int = {
7733 			BPF_LD_IMM64(R0, 0xfedcba9876543210ULL),
7734 			BPF_ENDIAN(BPF_FROM_BE, R0, 64),
7735 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7736 			BPF_EXIT_INSN(),
7737 		},
7738 		INTERNAL,
7739 		{ },
7740 		{ { 0, (u32) (cpu_to_be64(0xfedcba9876543210ULL) >> 32) } },
7741 	},
7742 	/* BPF_ALU | BPF_END | BPF_FROM_LE */
7743 	{
7744 		"ALU_END_FROM_LE 16: 0x0123456789abcdef -> 0xefcd",
7745 		.u.insns_int = {
7746 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
7747 			BPF_ENDIAN(BPF_FROM_LE, R0, 16),
7748 			BPF_EXIT_INSN(),
7749 		},
7750 		INTERNAL,
7751 		{ },
7752 		{ { 0, cpu_to_le16(0xcdef) } },
7753 	},
7754 	{
7755 		"ALU_END_FROM_LE 32: 0x0123456789abcdef -> 0xefcdab89",
7756 		.u.insns_int = {
7757 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
7758 			BPF_ENDIAN(BPF_FROM_LE, R0, 32),
7759 			BPF_ALU64_REG(BPF_MOV, R1, R0),
7760 			BPF_ALU64_IMM(BPF_RSH, R1, 32),
7761 			BPF_ALU32_REG(BPF_ADD, R0, R1), /* R1 = 0 */
7762 			BPF_EXIT_INSN(),
7763 		},
7764 		INTERNAL,
7765 		{ },
7766 		{ { 0, cpu_to_le32(0x89abcdef) } },
7767 	},
7768 	{
7769 		"ALU_END_FROM_LE 64: 0x0123456789abcdef -> 0x67452301",
7770 		.u.insns_int = {
7771 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
7772 			BPF_ENDIAN(BPF_FROM_LE, R0, 64),
7773 			BPF_EXIT_INSN(),
7774 		},
7775 		INTERNAL,
7776 		{ },
7777 		{ { 0, (u32) cpu_to_le64(0x0123456789abcdefLL) } },
7778 	},
7779 	{
7780 		"ALU_END_FROM_LE 64: 0x0123456789abcdef >> 32 -> 0xefcdab89",
7781 		.u.insns_int = {
7782 			BPF_LD_IMM64(R0, 0x0123456789abcdefLL),
7783 			BPF_ENDIAN(BPF_FROM_LE, R0, 64),
7784 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7785 			BPF_EXIT_INSN(),
7786 		},
7787 		INTERNAL,
7788 		{ },
7789 		{ { 0, (u32) (cpu_to_le64(0x0123456789abcdefLL) >> 32) } },
7790 	},
7791 	/* BPF_ALU | BPF_END | BPF_FROM_LE, reversed */
7792 	{
7793 		"ALU_END_FROM_LE 16: 0xfedcba9876543210 -> 0x1032",
7794 		.u.insns_int = {
7795 			BPF_LD_IMM64(R0, 0xfedcba9876543210ULL),
7796 			BPF_ENDIAN(BPF_FROM_LE, R0, 16),
7797 			BPF_EXIT_INSN(),
7798 		},
7799 		INTERNAL,
7800 		{ },
7801 		{ { 0,  cpu_to_le16(0x3210) } },
7802 	},
7803 	{
7804 		"ALU_END_FROM_LE 32: 0xfedcba9876543210 -> 0x10325476",
7805 		.u.insns_int = {
7806 			BPF_LD_IMM64(R0, 0xfedcba9876543210ULL),
7807 			BPF_ENDIAN(BPF_FROM_LE, R0, 32),
7808 			BPF_ALU64_REG(BPF_MOV, R1, R0),
7809 			BPF_ALU64_IMM(BPF_RSH, R1, 32),
7810 			BPF_ALU32_REG(BPF_ADD, R0, R1), /* R1 = 0 */
7811 			BPF_EXIT_INSN(),
7812 		},
7813 		INTERNAL,
7814 		{ },
7815 		{ { 0, cpu_to_le32(0x76543210) } },
7816 	},
7817 	{
7818 		"ALU_END_FROM_LE 64: 0xfedcba9876543210 -> 0x10325476",
7819 		.u.insns_int = {
7820 			BPF_LD_IMM64(R0, 0xfedcba9876543210ULL),
7821 			BPF_ENDIAN(BPF_FROM_LE, R0, 64),
7822 			BPF_EXIT_INSN(),
7823 		},
7824 		INTERNAL,
7825 		{ },
7826 		{ { 0, (u32) cpu_to_le64(0xfedcba9876543210ULL) } },
7827 	},
7828 	{
7829 		"ALU_END_FROM_LE 64: 0xfedcba9876543210 >> 32 -> 0x98badcfe",
7830 		.u.insns_int = {
7831 			BPF_LD_IMM64(R0, 0xfedcba9876543210ULL),
7832 			BPF_ENDIAN(BPF_FROM_LE, R0, 64),
7833 			BPF_ALU64_IMM(BPF_RSH, R0, 32),
7834 			BPF_EXIT_INSN(),
7835 		},
7836 		INTERNAL,
7837 		{ },
7838 		{ { 0, (u32) (cpu_to_le64(0xfedcba9876543210ULL) >> 32) } },
7839 	},
7840 	/* BPF_LDX_MEM B/H/W/DW */
7841 	{
7842 		"BPF_LDX_MEM | BPF_B, base",
7843 		.u.insns_int = {
7844 			BPF_LD_IMM64(R1, 0x0102030405060708ULL),
7845 			BPF_LD_IMM64(R2, 0x0000000000000008ULL),
7846 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
7847 #ifdef __BIG_ENDIAN
7848 			BPF_LDX_MEM(BPF_B, R0, R10, -1),
7849 #else
7850 			BPF_LDX_MEM(BPF_B, R0, R10, -8),
7851 #endif
7852 			BPF_JMP_REG(BPF_JNE, R0, R2, 1),
7853 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
7854 			BPF_EXIT_INSN(),
7855 		},
7856 		INTERNAL,
7857 		{ },
7858 		{ { 0, 0 } },
7859 		.stack_depth = 8,
7860 	},
7861 	{
7862 		"BPF_LDX_MEM | BPF_B, MSB set",
7863 		.u.insns_int = {
7864 			BPF_LD_IMM64(R1, 0x8182838485868788ULL),
7865 			BPF_LD_IMM64(R2, 0x0000000000000088ULL),
7866 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
7867 #ifdef __BIG_ENDIAN
7868 			BPF_LDX_MEM(BPF_B, R0, R10, -1),
7869 #else
7870 			BPF_LDX_MEM(BPF_B, R0, R10, -8),
7871 #endif
7872 			BPF_JMP_REG(BPF_JNE, R0, R2, 1),
7873 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
7874 			BPF_EXIT_INSN(),
7875 		},
7876 		INTERNAL,
7877 		{ },
7878 		{ { 0, 0 } },
7879 		.stack_depth = 8,
7880 	},
7881 	{
7882 		"BPF_LDX_MEM | BPF_B, negative offset",
7883 		.u.insns_int = {
7884 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
7885 			BPF_LD_IMM64(R3, 0x0000000000000088ULL),
7886 			BPF_ALU64_IMM(BPF_ADD, R1, 512),
7887 			BPF_STX_MEM(BPF_B, R1, R2, -256),
7888 			BPF_LDX_MEM(BPF_B, R0, R1, -256),
7889 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
7890 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
7891 			BPF_EXIT_INSN(),
7892 		},
7893 		INTERNAL | FLAG_LARGE_MEM,
7894 		{ },
7895 		{ { 512, 0 } },
7896 		.stack_depth = 0,
7897 	},
7898 	{
7899 		"BPF_LDX_MEM | BPF_B, small positive offset",
7900 		.u.insns_int = {
7901 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
7902 			BPF_LD_IMM64(R3, 0x0000000000000088ULL),
7903 			BPF_STX_MEM(BPF_B, R1, R2, 256),
7904 			BPF_LDX_MEM(BPF_B, R0, R1, 256),
7905 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
7906 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
7907 			BPF_EXIT_INSN(),
7908 		},
7909 		INTERNAL | FLAG_LARGE_MEM,
7910 		{ },
7911 		{ { 512, 0 } },
7912 		.stack_depth = 0,
7913 	},
7914 	{
7915 		"BPF_LDX_MEM | BPF_B, large positive offset",
7916 		.u.insns_int = {
7917 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
7918 			BPF_LD_IMM64(R3, 0x0000000000000088ULL),
7919 			BPF_STX_MEM(BPF_B, R1, R2, 4096),
7920 			BPF_LDX_MEM(BPF_B, R0, R1, 4096),
7921 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
7922 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
7923 			BPF_EXIT_INSN(),
7924 		},
7925 		INTERNAL | FLAG_LARGE_MEM,
7926 		{ },
7927 		{ { 4096 + 16, 0 } },
7928 		.stack_depth = 0,
7929 	},
7930 	{
7931 		"BPF_LDX_MEM | BPF_H, base",
7932 		.u.insns_int = {
7933 			BPF_LD_IMM64(R1, 0x0102030405060708ULL),
7934 			BPF_LD_IMM64(R2, 0x0000000000000708ULL),
7935 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
7936 #ifdef __BIG_ENDIAN
7937 			BPF_LDX_MEM(BPF_H, R0, R10, -2),
7938 #else
7939 			BPF_LDX_MEM(BPF_H, R0, R10, -8),
7940 #endif
7941 			BPF_JMP_REG(BPF_JNE, R0, R2, 1),
7942 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
7943 			BPF_EXIT_INSN(),
7944 		},
7945 		INTERNAL,
7946 		{ },
7947 		{ { 0, 0 } },
7948 		.stack_depth = 8,
7949 	},
7950 	{
7951 		"BPF_LDX_MEM | BPF_H, MSB set",
7952 		.u.insns_int = {
7953 			BPF_LD_IMM64(R1, 0x8182838485868788ULL),
7954 			BPF_LD_IMM64(R2, 0x0000000000008788ULL),
7955 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
7956 #ifdef __BIG_ENDIAN
7957 			BPF_LDX_MEM(BPF_H, R0, R10, -2),
7958 #else
7959 			BPF_LDX_MEM(BPF_H, R0, R10, -8),
7960 #endif
7961 			BPF_JMP_REG(BPF_JNE, R0, R2, 1),
7962 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
7963 			BPF_EXIT_INSN(),
7964 		},
7965 		INTERNAL,
7966 		{ },
7967 		{ { 0, 0 } },
7968 		.stack_depth = 8,
7969 	},
7970 	{
7971 		"BPF_LDX_MEM | BPF_H, negative offset",
7972 		.u.insns_int = {
7973 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
7974 			BPF_LD_IMM64(R3, 0x0000000000008788ULL),
7975 			BPF_ALU64_IMM(BPF_ADD, R1, 512),
7976 			BPF_STX_MEM(BPF_H, R1, R2, -256),
7977 			BPF_LDX_MEM(BPF_H, R0, R1, -256),
7978 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
7979 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
7980 			BPF_EXIT_INSN(),
7981 		},
7982 		INTERNAL | FLAG_LARGE_MEM,
7983 		{ },
7984 		{ { 512, 0 } },
7985 		.stack_depth = 0,
7986 	},
7987 	{
7988 		"BPF_LDX_MEM | BPF_H, small positive offset",
7989 		.u.insns_int = {
7990 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
7991 			BPF_LD_IMM64(R3, 0x0000000000008788ULL),
7992 			BPF_STX_MEM(BPF_H, R1, R2, 256),
7993 			BPF_LDX_MEM(BPF_H, R0, R1, 256),
7994 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
7995 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
7996 			BPF_EXIT_INSN(),
7997 		},
7998 		INTERNAL | FLAG_LARGE_MEM,
7999 		{ },
8000 		{ { 512, 0 } },
8001 		.stack_depth = 0,
8002 	},
8003 	{
8004 		"BPF_LDX_MEM | BPF_H, large positive offset",
8005 		.u.insns_int = {
8006 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
8007 			BPF_LD_IMM64(R3, 0x0000000000008788ULL),
8008 			BPF_STX_MEM(BPF_H, R1, R2, 8192),
8009 			BPF_LDX_MEM(BPF_H, R0, R1, 8192),
8010 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
8011 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8012 			BPF_EXIT_INSN(),
8013 		},
8014 		INTERNAL | FLAG_LARGE_MEM,
8015 		{ },
8016 		{ { 8192 + 16, 0 } },
8017 		.stack_depth = 0,
8018 	},
8019 	{
8020 		"BPF_LDX_MEM | BPF_H, unaligned positive offset",
8021 		.u.insns_int = {
8022 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
8023 			BPF_LD_IMM64(R3, 0x0000000000008788ULL),
8024 			BPF_STX_MEM(BPF_H, R1, R2, 13),
8025 			BPF_LDX_MEM(BPF_H, R0, R1, 13),
8026 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
8027 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8028 			BPF_EXIT_INSN(),
8029 		},
8030 		INTERNAL | FLAG_LARGE_MEM,
8031 		{ },
8032 		{ { 32, 0 } },
8033 		.stack_depth = 0,
8034 	},
8035 	{
8036 		"BPF_LDX_MEM | BPF_W, base",
8037 		.u.insns_int = {
8038 			BPF_LD_IMM64(R1, 0x0102030405060708ULL),
8039 			BPF_LD_IMM64(R2, 0x0000000005060708ULL),
8040 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
8041 #ifdef __BIG_ENDIAN
8042 			BPF_LDX_MEM(BPF_W, R0, R10, -4),
8043 #else
8044 			BPF_LDX_MEM(BPF_W, R0, R10, -8),
8045 #endif
8046 			BPF_JMP_REG(BPF_JNE, R0, R2, 1),
8047 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8048 			BPF_EXIT_INSN(),
8049 		},
8050 		INTERNAL,
8051 		{ },
8052 		{ { 0, 0 } },
8053 		.stack_depth = 8,
8054 	},
8055 	{
8056 		"BPF_LDX_MEM | BPF_W, MSB set",
8057 		.u.insns_int = {
8058 			BPF_LD_IMM64(R1, 0x8182838485868788ULL),
8059 			BPF_LD_IMM64(R2, 0x0000000085868788ULL),
8060 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
8061 #ifdef __BIG_ENDIAN
8062 			BPF_LDX_MEM(BPF_W, R0, R10, -4),
8063 #else
8064 			BPF_LDX_MEM(BPF_W, R0, R10, -8),
8065 #endif
8066 			BPF_JMP_REG(BPF_JNE, R0, R2, 1),
8067 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8068 			BPF_EXIT_INSN(),
8069 		},
8070 		INTERNAL,
8071 		{ },
8072 		{ { 0, 0 } },
8073 		.stack_depth = 8,
8074 	},
8075 	{
8076 		"BPF_LDX_MEM | BPF_W, negative offset",
8077 		.u.insns_int = {
8078 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
8079 			BPF_LD_IMM64(R3, 0x0000000085868788ULL),
8080 			BPF_ALU64_IMM(BPF_ADD, R1, 512),
8081 			BPF_STX_MEM(BPF_W, R1, R2, -256),
8082 			BPF_LDX_MEM(BPF_W, R0, R1, -256),
8083 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
8084 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8085 			BPF_EXIT_INSN(),
8086 		},
8087 		INTERNAL | FLAG_LARGE_MEM,
8088 		{ },
8089 		{ { 512, 0 } },
8090 		.stack_depth = 0,
8091 	},
8092 	{
8093 		"BPF_LDX_MEM | BPF_W, small positive offset",
8094 		.u.insns_int = {
8095 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
8096 			BPF_LD_IMM64(R3, 0x0000000085868788ULL),
8097 			BPF_STX_MEM(BPF_W, R1, R2, 256),
8098 			BPF_LDX_MEM(BPF_W, R0, R1, 256),
8099 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
8100 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8101 			BPF_EXIT_INSN(),
8102 		},
8103 		INTERNAL | FLAG_LARGE_MEM,
8104 		{ },
8105 		{ { 512, 0 } },
8106 		.stack_depth = 0,
8107 	},
8108 	{
8109 		"BPF_LDX_MEM | BPF_W, large positive offset",
8110 		.u.insns_int = {
8111 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
8112 			BPF_LD_IMM64(R3, 0x0000000085868788ULL),
8113 			BPF_STX_MEM(BPF_W, R1, R2, 16384),
8114 			BPF_LDX_MEM(BPF_W, R0, R1, 16384),
8115 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
8116 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8117 			BPF_EXIT_INSN(),
8118 		},
8119 		INTERNAL | FLAG_LARGE_MEM,
8120 		{ },
8121 		{ { 16384 + 16, 0 } },
8122 		.stack_depth = 0,
8123 	},
8124 	{
8125 		"BPF_LDX_MEM | BPF_W, unaligned positive offset",
8126 		.u.insns_int = {
8127 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
8128 			BPF_LD_IMM64(R3, 0x0000000085868788ULL),
8129 			BPF_STX_MEM(BPF_W, R1, R2, 13),
8130 			BPF_LDX_MEM(BPF_W, R0, R1, 13),
8131 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
8132 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8133 			BPF_EXIT_INSN(),
8134 		},
8135 		INTERNAL | FLAG_LARGE_MEM,
8136 		{ },
8137 		{ { 32, 0 } },
8138 		.stack_depth = 0,
8139 	},
8140 	{
8141 		"BPF_LDX_MEM | BPF_DW, base",
8142 		.u.insns_int = {
8143 			BPF_LD_IMM64(R1, 0x0102030405060708ULL),
8144 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
8145 			BPF_LDX_MEM(BPF_DW, R0, R10, -8),
8146 			BPF_JMP_REG(BPF_JNE, R0, R1, 1),
8147 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8148 			BPF_EXIT_INSN(),
8149 		},
8150 		INTERNAL,
8151 		{ },
8152 		{ { 0, 0 } },
8153 		.stack_depth = 8,
8154 	},
8155 	{
8156 		"BPF_LDX_MEM | BPF_DW, MSB set",
8157 		.u.insns_int = {
8158 			BPF_LD_IMM64(R1, 0x8182838485868788ULL),
8159 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
8160 			BPF_LDX_MEM(BPF_DW, R0, R10, -8),
8161 			BPF_JMP_REG(BPF_JNE, R0, R1, 1),
8162 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8163 			BPF_EXIT_INSN(),
8164 		},
8165 		INTERNAL,
8166 		{ },
8167 		{ { 0, 0 } },
8168 		.stack_depth = 8,
8169 	},
8170 	{
8171 		"BPF_LDX_MEM | BPF_DW, negative offset",
8172 		.u.insns_int = {
8173 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
8174 			BPF_ALU64_IMM(BPF_ADD, R1, 512),
8175 			BPF_STX_MEM(BPF_DW, R1, R2, -256),
8176 			BPF_LDX_MEM(BPF_DW, R0, R1, -256),
8177 			BPF_JMP_REG(BPF_JNE, R0, R2, 1),
8178 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8179 			BPF_EXIT_INSN(),
8180 		},
8181 		INTERNAL | FLAG_LARGE_MEM,
8182 		{ },
8183 		{ { 512, 0 } },
8184 		.stack_depth = 0,
8185 	},
8186 	{
8187 		"BPF_LDX_MEM | BPF_DW, small positive offset",
8188 		.u.insns_int = {
8189 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
8190 			BPF_STX_MEM(BPF_DW, R1, R2, 256),
8191 			BPF_LDX_MEM(BPF_DW, R0, R1, 256),
8192 			BPF_JMP_REG(BPF_JNE, R0, R2, 1),
8193 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8194 			BPF_EXIT_INSN(),
8195 		},
8196 		INTERNAL | FLAG_LARGE_MEM,
8197 		{ },
8198 		{ { 512, 0 } },
8199 		.stack_depth = 8,
8200 	},
8201 	{
8202 		"BPF_LDX_MEM | BPF_DW, large positive offset",
8203 		.u.insns_int = {
8204 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
8205 			BPF_STX_MEM(BPF_DW, R1, R2, 32760),
8206 			BPF_LDX_MEM(BPF_DW, R0, R1, 32760),
8207 			BPF_JMP_REG(BPF_JNE, R0, R2, 1),
8208 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8209 			BPF_EXIT_INSN(),
8210 		},
8211 		INTERNAL | FLAG_LARGE_MEM,
8212 		{ },
8213 		{ { 32768, 0 } },
8214 		.stack_depth = 0,
8215 	},
8216 	{
8217 		"BPF_LDX_MEM | BPF_DW, unaligned positive offset",
8218 		.u.insns_int = {
8219 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
8220 			BPF_STX_MEM(BPF_DW, R1, R2, 13),
8221 			BPF_LDX_MEM(BPF_DW, R0, R1, 13),
8222 			BPF_JMP_REG(BPF_JNE, R0, R2, 1),
8223 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8224 			BPF_EXIT_INSN(),
8225 		},
8226 		INTERNAL | FLAG_LARGE_MEM,
8227 		{ },
8228 		{ { 32, 0 } },
8229 		.stack_depth = 0,
8230 	},
8231 	/* BPF_STX_MEM B/H/W/DW */
8232 	{
8233 		"BPF_STX_MEM | BPF_B",
8234 		.u.insns_int = {
8235 			BPF_LD_IMM64(R1, 0x8090a0b0c0d0e0f0ULL),
8236 			BPF_LD_IMM64(R2, 0x0102030405060708ULL),
8237 			BPF_LD_IMM64(R3, 0x8090a0b0c0d0e008ULL),
8238 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
8239 #ifdef __BIG_ENDIAN
8240 			BPF_STX_MEM(BPF_B, R10, R2, -1),
8241 #else
8242 			BPF_STX_MEM(BPF_B, R10, R2, -8),
8243 #endif
8244 			BPF_LDX_MEM(BPF_DW, R0, R10, -8),
8245 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
8246 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8247 			BPF_EXIT_INSN(),
8248 		},
8249 		INTERNAL,
8250 		{ },
8251 		{ { 0, 0 } },
8252 		.stack_depth = 8,
8253 	},
8254 	{
8255 		"BPF_STX_MEM | BPF_B, MSB set",
8256 		.u.insns_int = {
8257 			BPF_LD_IMM64(R1, 0x8090a0b0c0d0e0f0ULL),
8258 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
8259 			BPF_LD_IMM64(R3, 0x8090a0b0c0d0e088ULL),
8260 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
8261 #ifdef __BIG_ENDIAN
8262 			BPF_STX_MEM(BPF_B, R10, R2, -1),
8263 #else
8264 			BPF_STX_MEM(BPF_B, R10, R2, -8),
8265 #endif
8266 			BPF_LDX_MEM(BPF_DW, R0, R10, -8),
8267 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
8268 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8269 			BPF_EXIT_INSN(),
8270 		},
8271 		INTERNAL,
8272 		{ },
8273 		{ { 0, 0 } },
8274 		.stack_depth = 8,
8275 	},
8276 	{
8277 		"BPF_STX_MEM | BPF_H",
8278 		.u.insns_int = {
8279 			BPF_LD_IMM64(R1, 0x8090a0b0c0d0e0f0ULL),
8280 			BPF_LD_IMM64(R2, 0x0102030405060708ULL),
8281 			BPF_LD_IMM64(R3, 0x8090a0b0c0d00708ULL),
8282 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
8283 #ifdef __BIG_ENDIAN
8284 			BPF_STX_MEM(BPF_H, R10, R2, -2),
8285 #else
8286 			BPF_STX_MEM(BPF_H, R10, R2, -8),
8287 #endif
8288 			BPF_LDX_MEM(BPF_DW, R0, R10, -8),
8289 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
8290 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8291 			BPF_EXIT_INSN(),
8292 		},
8293 		INTERNAL,
8294 		{ },
8295 		{ { 0, 0 } },
8296 		.stack_depth = 8,
8297 	},
8298 	{
8299 		"BPF_STX_MEM | BPF_H, MSB set",
8300 		.u.insns_int = {
8301 			BPF_LD_IMM64(R1, 0x8090a0b0c0d0e0f0ULL),
8302 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
8303 			BPF_LD_IMM64(R3, 0x8090a0b0c0d08788ULL),
8304 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
8305 #ifdef __BIG_ENDIAN
8306 			BPF_STX_MEM(BPF_H, R10, R2, -2),
8307 #else
8308 			BPF_STX_MEM(BPF_H, R10, R2, -8),
8309 #endif
8310 			BPF_LDX_MEM(BPF_DW, R0, R10, -8),
8311 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
8312 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8313 			BPF_EXIT_INSN(),
8314 		},
8315 		INTERNAL,
8316 		{ },
8317 		{ { 0, 0 } },
8318 		.stack_depth = 8,
8319 	},
8320 	{
8321 		"BPF_STX_MEM | BPF_W",
8322 		.u.insns_int = {
8323 			BPF_LD_IMM64(R1, 0x8090a0b0c0d0e0f0ULL),
8324 			BPF_LD_IMM64(R2, 0x0102030405060708ULL),
8325 			BPF_LD_IMM64(R3, 0x8090a0b005060708ULL),
8326 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
8327 #ifdef __BIG_ENDIAN
8328 			BPF_STX_MEM(BPF_W, R10, R2, -4),
8329 #else
8330 			BPF_STX_MEM(BPF_W, R10, R2, -8),
8331 #endif
8332 			BPF_LDX_MEM(BPF_DW, R0, R10, -8),
8333 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
8334 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8335 			BPF_EXIT_INSN(),
8336 		},
8337 		INTERNAL,
8338 		{ },
8339 		{ { 0, 0 } },
8340 		.stack_depth = 8,
8341 	},
8342 	{
8343 		"BPF_STX_MEM | BPF_W, MSB set",
8344 		.u.insns_int = {
8345 			BPF_LD_IMM64(R1, 0x8090a0b0c0d0e0f0ULL),
8346 			BPF_LD_IMM64(R2, 0x8182838485868788ULL),
8347 			BPF_LD_IMM64(R3, 0x8090a0b085868788ULL),
8348 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
8349 #ifdef __BIG_ENDIAN
8350 			BPF_STX_MEM(BPF_W, R10, R2, -4),
8351 #else
8352 			BPF_STX_MEM(BPF_W, R10, R2, -8),
8353 #endif
8354 			BPF_LDX_MEM(BPF_DW, R0, R10, -8),
8355 			BPF_JMP_REG(BPF_JNE, R0, R3, 1),
8356 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
8357 			BPF_EXIT_INSN(),
8358 		},
8359 		INTERNAL,
8360 		{ },
8361 		{ { 0, 0 } },
8362 		.stack_depth = 8,
8363 	},
8364 	/* BPF_ST(X) | BPF_MEM | BPF_B/H/W/DW */
8365 	{
8366 		"ST_MEM_B: Store/Load byte: max negative",
8367 		.u.insns_int = {
8368 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
8369 			BPF_ST_MEM(BPF_B, R10, -40, 0xff),
8370 			BPF_LDX_MEM(BPF_B, R0, R10, -40),
8371 			BPF_EXIT_INSN(),
8372 		},
8373 		INTERNAL,
8374 		{ },
8375 		{ { 0, 0xff } },
8376 		.stack_depth = 40,
8377 	},
8378 	{
8379 		"ST_MEM_B: Store/Load byte: max positive",
8380 		.u.insns_int = {
8381 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
8382 			BPF_ST_MEM(BPF_H, R10, -40, 0x7f),
8383 			BPF_LDX_MEM(BPF_H, R0, R10, -40),
8384 			BPF_EXIT_INSN(),
8385 		},
8386 		INTERNAL,
8387 		{ },
8388 		{ { 0, 0x7f } },
8389 		.stack_depth = 40,
8390 	},
8391 	{
8392 		"STX_MEM_B: Store/Load byte: max negative",
8393 		.u.insns_int = {
8394 			BPF_LD_IMM64(R0, 0),
8395 			BPF_LD_IMM64(R1, 0xffLL),
8396 			BPF_STX_MEM(BPF_B, R10, R1, -40),
8397 			BPF_LDX_MEM(BPF_B, R0, R10, -40),
8398 			BPF_EXIT_INSN(),
8399 		},
8400 		INTERNAL,
8401 		{ },
8402 		{ { 0, 0xff } },
8403 		.stack_depth = 40,
8404 	},
8405 	{
8406 		"ST_MEM_H: Store/Load half word: max negative",
8407 		.u.insns_int = {
8408 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
8409 			BPF_ST_MEM(BPF_H, R10, -40, 0xffff),
8410 			BPF_LDX_MEM(BPF_H, R0, R10, -40),
8411 			BPF_EXIT_INSN(),
8412 		},
8413 		INTERNAL,
8414 		{ },
8415 		{ { 0, 0xffff } },
8416 		.stack_depth = 40,
8417 	},
8418 	{
8419 		"ST_MEM_H: Store/Load half word: max positive",
8420 		.u.insns_int = {
8421 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
8422 			BPF_ST_MEM(BPF_H, R10, -40, 0x7fff),
8423 			BPF_LDX_MEM(BPF_H, R0, R10, -40),
8424 			BPF_EXIT_INSN(),
8425 		},
8426 		INTERNAL,
8427 		{ },
8428 		{ { 0, 0x7fff } },
8429 		.stack_depth = 40,
8430 	},
8431 	{
8432 		"STX_MEM_H: Store/Load half word: max negative",
8433 		.u.insns_int = {
8434 			BPF_LD_IMM64(R0, 0),
8435 			BPF_LD_IMM64(R1, 0xffffLL),
8436 			BPF_STX_MEM(BPF_H, R10, R1, -40),
8437 			BPF_LDX_MEM(BPF_H, R0, R10, -40),
8438 			BPF_EXIT_INSN(),
8439 		},
8440 		INTERNAL,
8441 		{ },
8442 		{ { 0, 0xffff } },
8443 		.stack_depth = 40,
8444 	},
8445 	{
8446 		"ST_MEM_W: Store/Load word: max negative",
8447 		.u.insns_int = {
8448 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
8449 			BPF_ST_MEM(BPF_W, R10, -40, 0xffffffff),
8450 			BPF_LDX_MEM(BPF_W, R0, R10, -40),
8451 			BPF_EXIT_INSN(),
8452 		},
8453 		INTERNAL,
8454 		{ },
8455 		{ { 0, 0xffffffff } },
8456 		.stack_depth = 40,
8457 	},
8458 	{
8459 		"ST_MEM_W: Store/Load word: max positive",
8460 		.u.insns_int = {
8461 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
8462 			BPF_ST_MEM(BPF_W, R10, -40, 0x7fffffff),
8463 			BPF_LDX_MEM(BPF_W, R0, R10, -40),
8464 			BPF_EXIT_INSN(),
8465 		},
8466 		INTERNAL,
8467 		{ },
8468 		{ { 0, 0x7fffffff } },
8469 		.stack_depth = 40,
8470 	},
8471 	{
8472 		"STX_MEM_W: Store/Load word: max negative",
8473 		.u.insns_int = {
8474 			BPF_LD_IMM64(R0, 0),
8475 			BPF_LD_IMM64(R1, 0xffffffffLL),
8476 			BPF_STX_MEM(BPF_W, R10, R1, -40),
8477 			BPF_LDX_MEM(BPF_W, R0, R10, -40),
8478 			BPF_EXIT_INSN(),
8479 		},
8480 		INTERNAL,
8481 		{ },
8482 		{ { 0, 0xffffffff } },
8483 		.stack_depth = 40,
8484 	},
8485 	{
8486 		"ST_MEM_DW: Store/Load double word: max negative",
8487 		.u.insns_int = {
8488 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
8489 			BPF_ST_MEM(BPF_DW, R10, -40, 0xffffffff),
8490 			BPF_LDX_MEM(BPF_DW, R0, R10, -40),
8491 			BPF_EXIT_INSN(),
8492 		},
8493 		INTERNAL,
8494 		{ },
8495 		{ { 0, 0xffffffff } },
8496 		.stack_depth = 40,
8497 	},
8498 	{
8499 		"ST_MEM_DW: Store/Load double word: max negative 2",
8500 		.u.insns_int = {
8501 			BPF_LD_IMM64(R2, 0xffff00000000ffffLL),
8502 			BPF_LD_IMM64(R3, 0xffffffffffffffffLL),
8503 			BPF_ST_MEM(BPF_DW, R10, -40, 0xffffffff),
8504 			BPF_LDX_MEM(BPF_DW, R2, R10, -40),
8505 			BPF_JMP_REG(BPF_JEQ, R2, R3, 2),
8506 			BPF_MOV32_IMM(R0, 2),
8507 			BPF_EXIT_INSN(),
8508 			BPF_MOV32_IMM(R0, 1),
8509 			BPF_EXIT_INSN(),
8510 		},
8511 		INTERNAL,
8512 		{ },
8513 		{ { 0, 0x1 } },
8514 		.stack_depth = 40,
8515 	},
8516 	{
8517 		"ST_MEM_DW: Store/Load double word: max positive",
8518 		.u.insns_int = {
8519 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
8520 			BPF_ST_MEM(BPF_DW, R10, -40, 0x7fffffff),
8521 			BPF_LDX_MEM(BPF_DW, R0, R10, -40),
8522 			BPF_EXIT_INSN(),
8523 		},
8524 		INTERNAL,
8525 		{ },
8526 		{ { 0, 0x7fffffff } },
8527 		.stack_depth = 40,
8528 	},
8529 	{
8530 		"STX_MEM_DW: Store/Load double word: max negative",
8531 		.u.insns_int = {
8532 			BPF_LD_IMM64(R0, 0),
8533 			BPF_LD_IMM64(R1, 0xffffffffffffffffLL),
8534 			BPF_STX_MEM(BPF_DW, R10, R1, -40),
8535 			BPF_LDX_MEM(BPF_DW, R0, R10, -40),
8536 			BPF_EXIT_INSN(),
8537 		},
8538 		INTERNAL,
8539 		{ },
8540 		{ { 0, 0xffffffff } },
8541 		.stack_depth = 40,
8542 	},
8543 	{
8544 		"STX_MEM_DW: Store double word: first word in memory",
8545 		.u.insns_int = {
8546 			BPF_LD_IMM64(R0, 0),
8547 			BPF_LD_IMM64(R1, 0x0123456789abcdefLL),
8548 			BPF_STX_MEM(BPF_DW, R10, R1, -40),
8549 			BPF_LDX_MEM(BPF_W, R0, R10, -40),
8550 			BPF_EXIT_INSN(),
8551 		},
8552 		INTERNAL,
8553 		{ },
8554 #ifdef __BIG_ENDIAN
8555 		{ { 0, 0x01234567 } },
8556 #else
8557 		{ { 0, 0x89abcdef } },
8558 #endif
8559 		.stack_depth = 40,
8560 	},
8561 	{
8562 		"STX_MEM_DW: Store double word: second word in memory",
8563 		.u.insns_int = {
8564 			BPF_LD_IMM64(R0, 0),
8565 			BPF_LD_IMM64(R1, 0x0123456789abcdefLL),
8566 			BPF_STX_MEM(BPF_DW, R10, R1, -40),
8567 			BPF_LDX_MEM(BPF_W, R0, R10, -36),
8568 			BPF_EXIT_INSN(),
8569 		},
8570 		INTERNAL,
8571 		{ },
8572 #ifdef __BIG_ENDIAN
8573 		{ { 0, 0x89abcdef } },
8574 #else
8575 		{ { 0, 0x01234567 } },
8576 #endif
8577 		.stack_depth = 40,
8578 	},
8579 	/* BPF_STX | BPF_ATOMIC | BPF_W/DW */
8580 	{
8581 		"STX_XADD_W: X + 1 + 1 + 1 + ...",
8582 		{ },
8583 		INTERNAL,
8584 		{ },
8585 		{ { 0, 4134 } },
8586 		.fill_helper = bpf_fill_stxw,
8587 	},
8588 	{
8589 		"STX_XADD_DW: X + 1 + 1 + 1 + ...",
8590 		{ },
8591 		INTERNAL,
8592 		{ },
8593 		{ { 0, 4134 } },
8594 		.fill_helper = bpf_fill_stxdw,
8595 	},
8596 	/*
8597 	 * Exhaustive tests of atomic operation variants.
8598 	 * Individual tests are expanded from template macros for all
8599 	 * combinations of ALU operation, word size and fetching.
8600 	 */
8601 #define BPF_ATOMIC_POISON(width) ((width) == BPF_W ? (0xbaadf00dULL << 32) : 0)
8602 
8603 #define BPF_ATOMIC_OP_TEST1(width, op, logic, old, update, result)	\
8604 {									\
8605 	"BPF_ATOMIC | " #width ", " #op ": Test: "			\
8606 		#old " " #logic " " #update " = " #result,		\
8607 	.u.insns_int = {						\
8608 		BPF_LD_IMM64(R5, (update) | BPF_ATOMIC_POISON(width)),	\
8609 		BPF_ST_MEM(width, R10, -40, old),			\
8610 		BPF_ATOMIC_OP(width, op, R10, R5, -40),			\
8611 		BPF_LDX_MEM(width, R0, R10, -40),			\
8612 		BPF_ALU64_REG(BPF_MOV, R1, R0),				\
8613 		BPF_ALU64_IMM(BPF_RSH, R1, 32),				\
8614 		BPF_ALU64_REG(BPF_OR, R0, R1),				\
8615 		BPF_EXIT_INSN(),					\
8616 	},								\
8617 	INTERNAL,							\
8618 	{ },								\
8619 	{ { 0, result } },						\
8620 	.stack_depth = 40,						\
8621 }
8622 #define BPF_ATOMIC_OP_TEST2(width, op, logic, old, update, result)	\
8623 {									\
8624 	"BPF_ATOMIC | " #width ", " #op ": Test side effects, r10: "	\
8625 		#old " " #logic " " #update " = " #result,		\
8626 	.u.insns_int = {						\
8627 		BPF_ALU64_REG(BPF_MOV, R1, R10),			\
8628 		BPF_LD_IMM64(R0, (update) | BPF_ATOMIC_POISON(width)),	\
8629 		BPF_ST_MEM(BPF_W, R10, -40, old),			\
8630 		BPF_ATOMIC_OP(width, op, R10, R0, -40),			\
8631 		BPF_ALU64_REG(BPF_MOV, R0, R10),			\
8632 		BPF_ALU64_REG(BPF_SUB, R0, R1),				\
8633 		BPF_ALU64_REG(BPF_MOV, R1, R0),				\
8634 		BPF_ALU64_IMM(BPF_RSH, R1, 32),				\
8635 		BPF_ALU64_REG(BPF_OR, R0, R1),				\
8636 		BPF_EXIT_INSN(),					\
8637 	},								\
8638 	INTERNAL,							\
8639 	{ },								\
8640 	{ { 0, 0 } },							\
8641 	.stack_depth = 40,						\
8642 }
8643 #define BPF_ATOMIC_OP_TEST3(width, op, logic, old, update, result)	\
8644 {									\
8645 	"BPF_ATOMIC | " #width ", " #op ": Test side effects, r0: "	\
8646 		#old " " #logic " " #update " = " #result,		\
8647 	.u.insns_int = {						\
8648 		BPF_ALU64_REG(BPF_MOV, R0, R10),			\
8649 		BPF_LD_IMM64(R1, (update) | BPF_ATOMIC_POISON(width)),	\
8650 		BPF_ST_MEM(width, R10, -40, old),			\
8651 		BPF_ATOMIC_OP(width, op, R10, R1, -40),			\
8652 		BPF_ALU64_REG(BPF_SUB, R0, R10),			\
8653 		BPF_ALU64_REG(BPF_MOV, R1, R0),				\
8654 		BPF_ALU64_IMM(BPF_RSH, R1, 32),				\
8655 		BPF_ALU64_REG(BPF_OR, R0, R1),				\
8656 		BPF_EXIT_INSN(),					\
8657 	},								\
8658 	INTERNAL,                                                       \
8659 	{ },                                                            \
8660 	{ { 0, 0 } },                                                   \
8661 	.stack_depth = 40,                                              \
8662 }
8663 #define BPF_ATOMIC_OP_TEST4(width, op, logic, old, update, result)	\
8664 {									\
8665 	"BPF_ATOMIC | " #width ", " #op ": Test fetch: "		\
8666 		#old " " #logic " " #update " = " #result,		\
8667 	.u.insns_int = {						\
8668 		BPF_LD_IMM64(R3, (update) | BPF_ATOMIC_POISON(width)),	\
8669 		BPF_ST_MEM(width, R10, -40, old),			\
8670 		BPF_ATOMIC_OP(width, op, R10, R3, -40),			\
8671 		BPF_ALU32_REG(BPF_MOV, R0, R3),                         \
8672 		BPF_EXIT_INSN(),					\
8673 	},								\
8674 	INTERNAL,                                                       \
8675 	{ },                                                            \
8676 	{ { 0, (op) & BPF_FETCH ? old : update } },			\
8677 	.stack_depth = 40,                                              \
8678 }
8679 	/* BPF_ATOMIC | BPF_W: BPF_ADD */
8680 	BPF_ATOMIC_OP_TEST1(BPF_W, BPF_ADD, +, 0x12, 0xab, 0xbd),
8681 	BPF_ATOMIC_OP_TEST2(BPF_W, BPF_ADD, +, 0x12, 0xab, 0xbd),
8682 	BPF_ATOMIC_OP_TEST3(BPF_W, BPF_ADD, +, 0x12, 0xab, 0xbd),
8683 	BPF_ATOMIC_OP_TEST4(BPF_W, BPF_ADD, +, 0x12, 0xab, 0xbd),
8684 	/* BPF_ATOMIC | BPF_W: BPF_ADD | BPF_FETCH */
8685 	BPF_ATOMIC_OP_TEST1(BPF_W, BPF_ADD | BPF_FETCH, +, 0x12, 0xab, 0xbd),
8686 	BPF_ATOMIC_OP_TEST2(BPF_W, BPF_ADD | BPF_FETCH, +, 0x12, 0xab, 0xbd),
8687 	BPF_ATOMIC_OP_TEST3(BPF_W, BPF_ADD | BPF_FETCH, +, 0x12, 0xab, 0xbd),
8688 	BPF_ATOMIC_OP_TEST4(BPF_W, BPF_ADD | BPF_FETCH, +, 0x12, 0xab, 0xbd),
8689 	/* BPF_ATOMIC | BPF_DW: BPF_ADD */
8690 	BPF_ATOMIC_OP_TEST1(BPF_DW, BPF_ADD, +, 0x12, 0xab, 0xbd),
8691 	BPF_ATOMIC_OP_TEST2(BPF_DW, BPF_ADD, +, 0x12, 0xab, 0xbd),
8692 	BPF_ATOMIC_OP_TEST3(BPF_DW, BPF_ADD, +, 0x12, 0xab, 0xbd),
8693 	BPF_ATOMIC_OP_TEST4(BPF_DW, BPF_ADD, +, 0x12, 0xab, 0xbd),
8694 	/* BPF_ATOMIC | BPF_DW: BPF_ADD | BPF_FETCH */
8695 	BPF_ATOMIC_OP_TEST1(BPF_DW, BPF_ADD | BPF_FETCH, +, 0x12, 0xab, 0xbd),
8696 	BPF_ATOMIC_OP_TEST2(BPF_DW, BPF_ADD | BPF_FETCH, +, 0x12, 0xab, 0xbd),
8697 	BPF_ATOMIC_OP_TEST3(BPF_DW, BPF_ADD | BPF_FETCH, +, 0x12, 0xab, 0xbd),
8698 	BPF_ATOMIC_OP_TEST4(BPF_DW, BPF_ADD | BPF_FETCH, +, 0x12, 0xab, 0xbd),
8699 	/* BPF_ATOMIC | BPF_W: BPF_AND */
8700 	BPF_ATOMIC_OP_TEST1(BPF_W, BPF_AND, &, 0x12, 0xab, 0x02),
8701 	BPF_ATOMIC_OP_TEST2(BPF_W, BPF_AND, &, 0x12, 0xab, 0x02),
8702 	BPF_ATOMIC_OP_TEST3(BPF_W, BPF_AND, &, 0x12, 0xab, 0x02),
8703 	BPF_ATOMIC_OP_TEST4(BPF_W, BPF_AND, &, 0x12, 0xab, 0x02),
8704 	/* BPF_ATOMIC | BPF_W: BPF_AND | BPF_FETCH */
8705 	BPF_ATOMIC_OP_TEST1(BPF_W, BPF_AND | BPF_FETCH, &, 0x12, 0xab, 0x02),
8706 	BPF_ATOMIC_OP_TEST2(BPF_W, BPF_AND | BPF_FETCH, &, 0x12, 0xab, 0x02),
8707 	BPF_ATOMIC_OP_TEST3(BPF_W, BPF_AND | BPF_FETCH, &, 0x12, 0xab, 0x02),
8708 	BPF_ATOMIC_OP_TEST4(BPF_W, BPF_AND | BPF_FETCH, &, 0x12, 0xab, 0x02),
8709 	/* BPF_ATOMIC | BPF_DW: BPF_AND */
8710 	BPF_ATOMIC_OP_TEST1(BPF_DW, BPF_AND, &, 0x12, 0xab, 0x02),
8711 	BPF_ATOMIC_OP_TEST2(BPF_DW, BPF_AND, &, 0x12, 0xab, 0x02),
8712 	BPF_ATOMIC_OP_TEST3(BPF_DW, BPF_AND, &, 0x12, 0xab, 0x02),
8713 	BPF_ATOMIC_OP_TEST4(BPF_DW, BPF_AND, &, 0x12, 0xab, 0x02),
8714 	/* BPF_ATOMIC | BPF_DW: BPF_AND | BPF_FETCH */
8715 	BPF_ATOMIC_OP_TEST1(BPF_DW, BPF_AND | BPF_FETCH, &, 0x12, 0xab, 0x02),
8716 	BPF_ATOMIC_OP_TEST2(BPF_DW, BPF_AND | BPF_FETCH, &, 0x12, 0xab, 0x02),
8717 	BPF_ATOMIC_OP_TEST3(BPF_DW, BPF_AND | BPF_FETCH, &, 0x12, 0xab, 0x02),
8718 	BPF_ATOMIC_OP_TEST4(BPF_DW, BPF_AND | BPF_FETCH, &, 0x12, 0xab, 0x02),
8719 	/* BPF_ATOMIC | BPF_W: BPF_OR */
8720 	BPF_ATOMIC_OP_TEST1(BPF_W, BPF_OR, |, 0x12, 0xab, 0xbb),
8721 	BPF_ATOMIC_OP_TEST2(BPF_W, BPF_OR, |, 0x12, 0xab, 0xbb),
8722 	BPF_ATOMIC_OP_TEST3(BPF_W, BPF_OR, |, 0x12, 0xab, 0xbb),
8723 	BPF_ATOMIC_OP_TEST4(BPF_W, BPF_OR, |, 0x12, 0xab, 0xbb),
8724 	/* BPF_ATOMIC | BPF_W: BPF_OR | BPF_FETCH */
8725 	BPF_ATOMIC_OP_TEST1(BPF_W, BPF_OR | BPF_FETCH, |, 0x12, 0xab, 0xbb),
8726 	BPF_ATOMIC_OP_TEST2(BPF_W, BPF_OR | BPF_FETCH, |, 0x12, 0xab, 0xbb),
8727 	BPF_ATOMIC_OP_TEST3(BPF_W, BPF_OR | BPF_FETCH, |, 0x12, 0xab, 0xbb),
8728 	BPF_ATOMIC_OP_TEST4(BPF_W, BPF_OR | BPF_FETCH, |, 0x12, 0xab, 0xbb),
8729 	/* BPF_ATOMIC | BPF_DW: BPF_OR */
8730 	BPF_ATOMIC_OP_TEST1(BPF_DW, BPF_OR, |, 0x12, 0xab, 0xbb),
8731 	BPF_ATOMIC_OP_TEST2(BPF_DW, BPF_OR, |, 0x12, 0xab, 0xbb),
8732 	BPF_ATOMIC_OP_TEST3(BPF_DW, BPF_OR, |, 0x12, 0xab, 0xbb),
8733 	BPF_ATOMIC_OP_TEST4(BPF_DW, BPF_OR, |, 0x12, 0xab, 0xbb),
8734 	/* BPF_ATOMIC | BPF_DW: BPF_OR | BPF_FETCH */
8735 	BPF_ATOMIC_OP_TEST1(BPF_DW, BPF_OR | BPF_FETCH, |, 0x12, 0xab, 0xbb),
8736 	BPF_ATOMIC_OP_TEST2(BPF_DW, BPF_OR | BPF_FETCH, |, 0x12, 0xab, 0xbb),
8737 	BPF_ATOMIC_OP_TEST3(BPF_DW, BPF_OR | BPF_FETCH, |, 0x12, 0xab, 0xbb),
8738 	BPF_ATOMIC_OP_TEST4(BPF_DW, BPF_OR | BPF_FETCH, |, 0x12, 0xab, 0xbb),
8739 	/* BPF_ATOMIC | BPF_W: BPF_XOR */
8740 	BPF_ATOMIC_OP_TEST1(BPF_W, BPF_XOR, ^, 0x12, 0xab, 0xb9),
8741 	BPF_ATOMIC_OP_TEST2(BPF_W, BPF_XOR, ^, 0x12, 0xab, 0xb9),
8742 	BPF_ATOMIC_OP_TEST3(BPF_W, BPF_XOR, ^, 0x12, 0xab, 0xb9),
8743 	BPF_ATOMIC_OP_TEST4(BPF_W, BPF_XOR, ^, 0x12, 0xab, 0xb9),
8744 	/* BPF_ATOMIC | BPF_W: BPF_XOR | BPF_FETCH */
8745 	BPF_ATOMIC_OP_TEST1(BPF_W, BPF_XOR | BPF_FETCH, ^, 0x12, 0xab, 0xb9),
8746 	BPF_ATOMIC_OP_TEST2(BPF_W, BPF_XOR | BPF_FETCH, ^, 0x12, 0xab, 0xb9),
8747 	BPF_ATOMIC_OP_TEST3(BPF_W, BPF_XOR | BPF_FETCH, ^, 0x12, 0xab, 0xb9),
8748 	BPF_ATOMIC_OP_TEST4(BPF_W, BPF_XOR | BPF_FETCH, ^, 0x12, 0xab, 0xb9),
8749 	/* BPF_ATOMIC | BPF_DW: BPF_XOR */
8750 	BPF_ATOMIC_OP_TEST1(BPF_DW, BPF_XOR, ^, 0x12, 0xab, 0xb9),
8751 	BPF_ATOMIC_OP_TEST2(BPF_DW, BPF_XOR, ^, 0x12, 0xab, 0xb9),
8752 	BPF_ATOMIC_OP_TEST3(BPF_DW, BPF_XOR, ^, 0x12, 0xab, 0xb9),
8753 	BPF_ATOMIC_OP_TEST4(BPF_DW, BPF_XOR, ^, 0x12, 0xab, 0xb9),
8754 	/* BPF_ATOMIC | BPF_DW: BPF_XOR | BPF_FETCH */
8755 	BPF_ATOMIC_OP_TEST1(BPF_DW, BPF_XOR | BPF_FETCH, ^, 0x12, 0xab, 0xb9),
8756 	BPF_ATOMIC_OP_TEST2(BPF_DW, BPF_XOR | BPF_FETCH, ^, 0x12, 0xab, 0xb9),
8757 	BPF_ATOMIC_OP_TEST3(BPF_DW, BPF_XOR | BPF_FETCH, ^, 0x12, 0xab, 0xb9),
8758 	BPF_ATOMIC_OP_TEST4(BPF_DW, BPF_XOR | BPF_FETCH, ^, 0x12, 0xab, 0xb9),
8759 	/* BPF_ATOMIC | BPF_W: BPF_XCHG */
8760 	BPF_ATOMIC_OP_TEST1(BPF_W, BPF_XCHG, xchg, 0x12, 0xab, 0xab),
8761 	BPF_ATOMIC_OP_TEST2(BPF_W, BPF_XCHG, xchg, 0x12, 0xab, 0xab),
8762 	BPF_ATOMIC_OP_TEST3(BPF_W, BPF_XCHG, xchg, 0x12, 0xab, 0xab),
8763 	BPF_ATOMIC_OP_TEST4(BPF_W, BPF_XCHG, xchg, 0x12, 0xab, 0xab),
8764 	/* BPF_ATOMIC | BPF_DW: BPF_XCHG */
8765 	BPF_ATOMIC_OP_TEST1(BPF_DW, BPF_XCHG, xchg, 0x12, 0xab, 0xab),
8766 	BPF_ATOMIC_OP_TEST2(BPF_DW, BPF_XCHG, xchg, 0x12, 0xab, 0xab),
8767 	BPF_ATOMIC_OP_TEST3(BPF_DW, BPF_XCHG, xchg, 0x12, 0xab, 0xab),
8768 	BPF_ATOMIC_OP_TEST4(BPF_DW, BPF_XCHG, xchg, 0x12, 0xab, 0xab),
8769 #undef BPF_ATOMIC_POISON
8770 #undef BPF_ATOMIC_OP_TEST1
8771 #undef BPF_ATOMIC_OP_TEST2
8772 #undef BPF_ATOMIC_OP_TEST3
8773 #undef BPF_ATOMIC_OP_TEST4
8774 	/* BPF_ATOMIC | BPF_W, BPF_CMPXCHG */
8775 	{
8776 		"BPF_ATOMIC | BPF_W, BPF_CMPXCHG: Test successful return",
8777 		.u.insns_int = {
8778 			BPF_ST_MEM(BPF_W, R10, -40, 0x01234567),
8779 			BPF_ALU32_IMM(BPF_MOV, R0, 0x01234567),
8780 			BPF_ALU32_IMM(BPF_MOV, R3, 0x89abcdef),
8781 			BPF_ATOMIC_OP(BPF_W, BPF_CMPXCHG, R10, R3, -40),
8782 			BPF_EXIT_INSN(),
8783 		},
8784 		INTERNAL,
8785 		{ },
8786 		{ { 0, 0x01234567 } },
8787 		.stack_depth = 40,
8788 	},
8789 	{
8790 		"BPF_ATOMIC | BPF_W, BPF_CMPXCHG: Test successful store",
8791 		.u.insns_int = {
8792 			BPF_ST_MEM(BPF_W, R10, -40, 0x01234567),
8793 			BPF_ALU32_IMM(BPF_MOV, R0, 0x01234567),
8794 			BPF_ALU32_IMM(BPF_MOV, R3, 0x89abcdef),
8795 			BPF_ATOMIC_OP(BPF_W, BPF_CMPXCHG, R10, R3, -40),
8796 			BPF_LDX_MEM(BPF_W, R0, R10, -40),
8797 			BPF_EXIT_INSN(),
8798 		},
8799 		INTERNAL,
8800 		{ },
8801 		{ { 0, 0x89abcdef } },
8802 		.stack_depth = 40,
8803 	},
8804 	{
8805 		"BPF_ATOMIC | BPF_W, BPF_CMPXCHG: Test failure return",
8806 		.u.insns_int = {
8807 			BPF_ST_MEM(BPF_W, R10, -40, 0x01234567),
8808 			BPF_ALU32_IMM(BPF_MOV, R0, 0x76543210),
8809 			BPF_ALU32_IMM(BPF_MOV, R3, 0x89abcdef),
8810 			BPF_ATOMIC_OP(BPF_W, BPF_CMPXCHG, R10, R3, -40),
8811 			BPF_EXIT_INSN(),
8812 		},
8813 		INTERNAL,
8814 		{ },
8815 		{ { 0, 0x01234567 } },
8816 		.stack_depth = 40,
8817 	},
8818 	{
8819 		"BPF_ATOMIC | BPF_W, BPF_CMPXCHG: Test failure store",
8820 		.u.insns_int = {
8821 			BPF_ST_MEM(BPF_W, R10, -40, 0x01234567),
8822 			BPF_ALU32_IMM(BPF_MOV, R0, 0x76543210),
8823 			BPF_ALU32_IMM(BPF_MOV, R3, 0x89abcdef),
8824 			BPF_ATOMIC_OP(BPF_W, BPF_CMPXCHG, R10, R3, -40),
8825 			BPF_LDX_MEM(BPF_W, R0, R10, -40),
8826 			BPF_EXIT_INSN(),
8827 		},
8828 		INTERNAL,
8829 		{ },
8830 		{ { 0, 0x01234567 } },
8831 		.stack_depth = 40,
8832 	},
8833 	{
8834 		"BPF_ATOMIC | BPF_W, BPF_CMPXCHG: Test side effects",
8835 		.u.insns_int = {
8836 			BPF_ST_MEM(BPF_W, R10, -40, 0x01234567),
8837 			BPF_ALU32_IMM(BPF_MOV, R0, 0x01234567),
8838 			BPF_ALU32_IMM(BPF_MOV, R3, 0x89abcdef),
8839 			BPF_ATOMIC_OP(BPF_W, BPF_CMPXCHG, R10, R3, -40),
8840 			BPF_ATOMIC_OP(BPF_W, BPF_CMPXCHG, R10, R3, -40),
8841 			BPF_ALU32_REG(BPF_MOV, R0, R3),
8842 			BPF_EXIT_INSN(),
8843 		},
8844 		INTERNAL,
8845 		{ },
8846 		{ { 0, 0x89abcdef } },
8847 		.stack_depth = 40,
8848 	},
8849 	/* BPF_ATOMIC | BPF_DW, BPF_CMPXCHG */
8850 	{
8851 		"BPF_ATOMIC | BPF_DW, BPF_CMPXCHG: Test successful return",
8852 		.u.insns_int = {
8853 			BPF_LD_IMM64(R1, 0x0123456789abcdefULL),
8854 			BPF_LD_IMM64(R2, 0xfedcba9876543210ULL),
8855 			BPF_ALU64_REG(BPF_MOV, R0, R1),
8856 			BPF_STX_MEM(BPF_DW, R10, R1, -40),
8857 			BPF_ATOMIC_OP(BPF_DW, BPF_CMPXCHG, R10, R2, -40),
8858 			BPF_JMP_REG(BPF_JNE, R0, R1, 1),
8859 			BPF_ALU64_REG(BPF_SUB, R0, R1),
8860 			BPF_EXIT_INSN(),
8861 		},
8862 		INTERNAL,
8863 		{ },
8864 		{ { 0, 0 } },
8865 		.stack_depth = 40,
8866 	},
8867 	{
8868 		"BPF_ATOMIC | BPF_DW, BPF_CMPXCHG: Test successful store",
8869 		.u.insns_int = {
8870 			BPF_LD_IMM64(R1, 0x0123456789abcdefULL),
8871 			BPF_LD_IMM64(R2, 0xfedcba9876543210ULL),
8872 			BPF_ALU64_REG(BPF_MOV, R0, R1),
8873 			BPF_STX_MEM(BPF_DW, R10, R0, -40),
8874 			BPF_ATOMIC_OP(BPF_DW, BPF_CMPXCHG, R10, R2, -40),
8875 			BPF_LDX_MEM(BPF_DW, R0, R10, -40),
8876 			BPF_JMP_REG(BPF_JNE, R0, R2, 1),
8877 			BPF_ALU64_REG(BPF_SUB, R0, R2),
8878 			BPF_EXIT_INSN(),
8879 		},
8880 		INTERNAL,
8881 		{ },
8882 		{ { 0, 0 } },
8883 		.stack_depth = 40,
8884 	},
8885 	{
8886 		"BPF_ATOMIC | BPF_DW, BPF_CMPXCHG: Test failure return",
8887 		.u.insns_int = {
8888 			BPF_LD_IMM64(R1, 0x0123456789abcdefULL),
8889 			BPF_LD_IMM64(R2, 0xfedcba9876543210ULL),
8890 			BPF_ALU64_REG(BPF_MOV, R0, R1),
8891 			BPF_ALU64_IMM(BPF_ADD, R0, 1),
8892 			BPF_STX_MEM(BPF_DW, R10, R1, -40),
8893 			BPF_ATOMIC_OP(BPF_DW, BPF_CMPXCHG, R10, R2, -40),
8894 			BPF_JMP_REG(BPF_JNE, R0, R1, 1),
8895 			BPF_ALU64_REG(BPF_SUB, R0, R1),
8896 			BPF_EXIT_INSN(),
8897 		},
8898 		INTERNAL,
8899 		{ },
8900 		{ { 0, 0 } },
8901 		.stack_depth = 40,
8902 	},
8903 	{
8904 		"BPF_ATOMIC | BPF_DW, BPF_CMPXCHG: Test failure store",
8905 		.u.insns_int = {
8906 			BPF_LD_IMM64(R1, 0x0123456789abcdefULL),
8907 			BPF_LD_IMM64(R2, 0xfedcba9876543210ULL),
8908 			BPF_ALU64_REG(BPF_MOV, R0, R1),
8909 			BPF_ALU64_IMM(BPF_ADD, R0, 1),
8910 			BPF_STX_MEM(BPF_DW, R10, R1, -40),
8911 			BPF_ATOMIC_OP(BPF_DW, BPF_CMPXCHG, R10, R2, -40),
8912 			BPF_LDX_MEM(BPF_DW, R0, R10, -40),
8913 			BPF_JMP_REG(BPF_JNE, R0, R1, 1),
8914 			BPF_ALU64_REG(BPF_SUB, R0, R1),
8915 			BPF_EXIT_INSN(),
8916 		},
8917 		INTERNAL,
8918 		{ },
8919 		{ { 0, 0 } },
8920 		.stack_depth = 40,
8921 	},
8922 	{
8923 		"BPF_ATOMIC | BPF_DW, BPF_CMPXCHG: Test side effects",
8924 		.u.insns_int = {
8925 			BPF_LD_IMM64(R1, 0x0123456789abcdefULL),
8926 			BPF_LD_IMM64(R2, 0xfedcba9876543210ULL),
8927 			BPF_ALU64_REG(BPF_MOV, R0, R1),
8928 			BPF_STX_MEM(BPF_DW, R10, R1, -40),
8929 			BPF_ATOMIC_OP(BPF_DW, BPF_CMPXCHG, R10, R2, -40),
8930 			BPF_LD_IMM64(R0, 0xfedcba9876543210ULL),
8931 			BPF_JMP_REG(BPF_JNE, R0, R2, 1),
8932 			BPF_ALU64_REG(BPF_SUB, R0, R2),
8933 			BPF_EXIT_INSN(),
8934 		},
8935 		INTERNAL,
8936 		{ },
8937 		{ { 0, 0 } },
8938 		.stack_depth = 40,
8939 	},
8940 	/* BPF_JMP32 | BPF_JEQ | BPF_K */
8941 	{
8942 		"JMP32_JEQ_K: Small immediate",
8943 		.u.insns_int = {
8944 			BPF_ALU32_IMM(BPF_MOV, R0, 123),
8945 			BPF_JMP32_IMM(BPF_JEQ, R0, 321, 1),
8946 			BPF_JMP32_IMM(BPF_JEQ, R0, 123, 1),
8947 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
8948 			BPF_EXIT_INSN(),
8949 		},
8950 		INTERNAL,
8951 		{ },
8952 		{ { 0, 123 } }
8953 	},
8954 	{
8955 		"JMP32_JEQ_K: Large immediate",
8956 		.u.insns_int = {
8957 			BPF_ALU32_IMM(BPF_MOV, R0, 12345678),
8958 			BPF_JMP32_IMM(BPF_JEQ, R0, 12345678 & 0xffff, 1),
8959 			BPF_JMP32_IMM(BPF_JEQ, R0, 12345678, 1),
8960 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
8961 			BPF_EXIT_INSN(),
8962 		},
8963 		INTERNAL,
8964 		{ },
8965 		{ { 0, 12345678 } }
8966 	},
8967 	{
8968 		"JMP32_JEQ_K: negative immediate",
8969 		.u.insns_int = {
8970 			BPF_ALU32_IMM(BPF_MOV, R0, -123),
8971 			BPF_JMP32_IMM(BPF_JEQ, R0,  123, 1),
8972 			BPF_JMP32_IMM(BPF_JEQ, R0, -123, 1),
8973 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
8974 			BPF_EXIT_INSN(),
8975 		},
8976 		INTERNAL,
8977 		{ },
8978 		{ { 0, -123 } }
8979 	},
8980 	/* BPF_JMP32 | BPF_JEQ | BPF_X */
8981 	{
8982 		"JMP32_JEQ_X",
8983 		.u.insns_int = {
8984 			BPF_ALU32_IMM(BPF_MOV, R0, 1234),
8985 			BPF_ALU32_IMM(BPF_MOV, R1, 4321),
8986 			BPF_JMP32_REG(BPF_JEQ, R0, R1, 2),
8987 			BPF_ALU32_IMM(BPF_MOV, R1, 1234),
8988 			BPF_JMP32_REG(BPF_JEQ, R0, R1, 1),
8989 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
8990 			BPF_EXIT_INSN(),
8991 		},
8992 		INTERNAL,
8993 		{ },
8994 		{ { 0, 1234 } }
8995 	},
8996 	/* BPF_JMP32 | BPF_JNE | BPF_K */
8997 	{
8998 		"JMP32_JNE_K: Small immediate",
8999 		.u.insns_int = {
9000 			BPF_ALU32_IMM(BPF_MOV, R0, 123),
9001 			BPF_JMP32_IMM(BPF_JNE, R0, 123, 1),
9002 			BPF_JMP32_IMM(BPF_JNE, R0, 321, 1),
9003 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9004 			BPF_EXIT_INSN(),
9005 		},
9006 		INTERNAL,
9007 		{ },
9008 		{ { 0, 123 } }
9009 	},
9010 	{
9011 		"JMP32_JNE_K: Large immediate",
9012 		.u.insns_int = {
9013 			BPF_ALU32_IMM(BPF_MOV, R0, 12345678),
9014 			BPF_JMP32_IMM(BPF_JNE, R0, 12345678, 1),
9015 			BPF_JMP32_IMM(BPF_JNE, R0, 12345678 & 0xffff, 1),
9016 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9017 			BPF_EXIT_INSN(),
9018 		},
9019 		INTERNAL,
9020 		{ },
9021 		{ { 0, 12345678 } }
9022 	},
9023 	{
9024 		"JMP32_JNE_K: negative immediate",
9025 		.u.insns_int = {
9026 			BPF_ALU32_IMM(BPF_MOV, R0, -123),
9027 			BPF_JMP32_IMM(BPF_JNE, R0, -123, 1),
9028 			BPF_JMP32_IMM(BPF_JNE, R0,  123, 1),
9029 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9030 			BPF_EXIT_INSN(),
9031 		},
9032 		INTERNAL,
9033 		{ },
9034 		{ { 0, -123 } }
9035 	},
9036 	/* BPF_JMP32 | BPF_JNE | BPF_X */
9037 	{
9038 		"JMP32_JNE_X",
9039 		.u.insns_int = {
9040 			BPF_ALU32_IMM(BPF_MOV, R0, 1234),
9041 			BPF_ALU32_IMM(BPF_MOV, R1, 1234),
9042 			BPF_JMP32_REG(BPF_JNE, R0, R1, 2),
9043 			BPF_ALU32_IMM(BPF_MOV, R1, 4321),
9044 			BPF_JMP32_REG(BPF_JNE, R0, R1, 1),
9045 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9046 			BPF_EXIT_INSN(),
9047 		},
9048 		INTERNAL,
9049 		{ },
9050 		{ { 0, 1234 } }
9051 	},
9052 	/* BPF_JMP32 | BPF_JSET | BPF_K */
9053 	{
9054 		"JMP32_JSET_K: Small immediate",
9055 		.u.insns_int = {
9056 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9057 			BPF_JMP32_IMM(BPF_JSET, R0, 2, 1),
9058 			BPF_JMP32_IMM(BPF_JSET, R0, 3, 1),
9059 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9060 			BPF_EXIT_INSN(),
9061 		},
9062 		INTERNAL,
9063 		{ },
9064 		{ { 0, 1 } }
9065 	},
9066 	{
9067 		"JMP32_JSET_K: Large immediate",
9068 		.u.insns_int = {
9069 			BPF_ALU32_IMM(BPF_MOV, R0, 0x40000000),
9070 			BPF_JMP32_IMM(BPF_JSET, R0, 0x3fffffff, 1),
9071 			BPF_JMP32_IMM(BPF_JSET, R0, 0x60000000, 1),
9072 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9073 			BPF_EXIT_INSN(),
9074 		},
9075 		INTERNAL,
9076 		{ },
9077 		{ { 0, 0x40000000 } }
9078 	},
9079 	{
9080 		"JMP32_JSET_K: negative immediate",
9081 		.u.insns_int = {
9082 			BPF_ALU32_IMM(BPF_MOV, R0, -123),
9083 			BPF_JMP32_IMM(BPF_JSET, R0, -1, 1),
9084 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9085 			BPF_EXIT_INSN(),
9086 		},
9087 		INTERNAL,
9088 		{ },
9089 		{ { 0, -123 } }
9090 	},
9091 	/* BPF_JMP32 | BPF_JSET | BPF_X */
9092 	{
9093 		"JMP32_JSET_X",
9094 		.u.insns_int = {
9095 			BPF_ALU32_IMM(BPF_MOV, R0, 8),
9096 			BPF_ALU32_IMM(BPF_MOV, R1, 7),
9097 			BPF_JMP32_REG(BPF_JSET, R0, R1, 2),
9098 			BPF_ALU32_IMM(BPF_MOV, R1, 8 | 2),
9099 			BPF_JMP32_REG(BPF_JNE, R0, R1, 1),
9100 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9101 			BPF_EXIT_INSN(),
9102 		},
9103 		INTERNAL,
9104 		{ },
9105 		{ { 0, 8 } }
9106 	},
9107 	/* BPF_JMP32 | BPF_JGT | BPF_K */
9108 	{
9109 		"JMP32_JGT_K: Small immediate",
9110 		.u.insns_int = {
9111 			BPF_ALU32_IMM(BPF_MOV, R0, 123),
9112 			BPF_JMP32_IMM(BPF_JGT, R0, 123, 1),
9113 			BPF_JMP32_IMM(BPF_JGT, R0, 122, 1),
9114 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9115 			BPF_EXIT_INSN(),
9116 		},
9117 		INTERNAL,
9118 		{ },
9119 		{ { 0, 123 } }
9120 	},
9121 	{
9122 		"JMP32_JGT_K: Large immediate",
9123 		.u.insns_int = {
9124 			BPF_ALU32_IMM(BPF_MOV, R0, 0xfffffffe),
9125 			BPF_JMP32_IMM(BPF_JGT, R0, 0xffffffff, 1),
9126 			BPF_JMP32_IMM(BPF_JGT, R0, 0xfffffffd, 1),
9127 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9128 			BPF_EXIT_INSN(),
9129 		},
9130 		INTERNAL,
9131 		{ },
9132 		{ { 0, 0xfffffffe } }
9133 	},
9134 	/* BPF_JMP32 | BPF_JGT | BPF_X */
9135 	{
9136 		"JMP32_JGT_X",
9137 		.u.insns_int = {
9138 			BPF_ALU32_IMM(BPF_MOV, R0, 0xfffffffe),
9139 			BPF_ALU32_IMM(BPF_MOV, R1, 0xffffffff),
9140 			BPF_JMP32_REG(BPF_JGT, R0, R1, 2),
9141 			BPF_ALU32_IMM(BPF_MOV, R1, 0xfffffffd),
9142 			BPF_JMP32_REG(BPF_JGT, R0, R1, 1),
9143 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9144 			BPF_EXIT_INSN(),
9145 		},
9146 		INTERNAL,
9147 		{ },
9148 		{ { 0, 0xfffffffe } }
9149 	},
9150 	/* BPF_JMP32 | BPF_JGE | BPF_K */
9151 	{
9152 		"JMP32_JGE_K: Small immediate",
9153 		.u.insns_int = {
9154 			BPF_ALU32_IMM(BPF_MOV, R0, 123),
9155 			BPF_JMP32_IMM(BPF_JGE, R0, 124, 1),
9156 			BPF_JMP32_IMM(BPF_JGE, R0, 123, 1),
9157 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9158 			BPF_EXIT_INSN(),
9159 		},
9160 		INTERNAL,
9161 		{ },
9162 		{ { 0, 123 } }
9163 	},
9164 	{
9165 		"JMP32_JGE_K: Large immediate",
9166 		.u.insns_int = {
9167 			BPF_ALU32_IMM(BPF_MOV, R0, 0xfffffffe),
9168 			BPF_JMP32_IMM(BPF_JGE, R0, 0xffffffff, 1),
9169 			BPF_JMP32_IMM(BPF_JGE, R0, 0xfffffffe, 1),
9170 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9171 			BPF_EXIT_INSN(),
9172 		},
9173 		INTERNAL,
9174 		{ },
9175 		{ { 0, 0xfffffffe } }
9176 	},
9177 	/* BPF_JMP32 | BPF_JGE | BPF_X */
9178 	{
9179 		"JMP32_JGE_X",
9180 		.u.insns_int = {
9181 			BPF_ALU32_IMM(BPF_MOV, R0, 0xfffffffe),
9182 			BPF_ALU32_IMM(BPF_MOV, R1, 0xffffffff),
9183 			BPF_JMP32_REG(BPF_JGE, R0, R1, 2),
9184 			BPF_ALU32_IMM(BPF_MOV, R1, 0xfffffffe),
9185 			BPF_JMP32_REG(BPF_JGE, R0, R1, 1),
9186 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9187 			BPF_EXIT_INSN(),
9188 		},
9189 		INTERNAL,
9190 		{ },
9191 		{ { 0, 0xfffffffe } }
9192 	},
9193 	/* BPF_JMP32 | BPF_JLT | BPF_K */
9194 	{
9195 		"JMP32_JLT_K: Small immediate",
9196 		.u.insns_int = {
9197 			BPF_ALU32_IMM(BPF_MOV, R0, 123),
9198 			BPF_JMP32_IMM(BPF_JLT, R0, 123, 1),
9199 			BPF_JMP32_IMM(BPF_JLT, R0, 124, 1),
9200 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9201 			BPF_EXIT_INSN(),
9202 		},
9203 		INTERNAL,
9204 		{ },
9205 		{ { 0, 123 } }
9206 	},
9207 	{
9208 		"JMP32_JLT_K: Large immediate",
9209 		.u.insns_int = {
9210 			BPF_ALU32_IMM(BPF_MOV, R0, 0xfffffffe),
9211 			BPF_JMP32_IMM(BPF_JLT, R0, 0xfffffffd, 1),
9212 			BPF_JMP32_IMM(BPF_JLT, R0, 0xffffffff, 1),
9213 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9214 			BPF_EXIT_INSN(),
9215 		},
9216 		INTERNAL,
9217 		{ },
9218 		{ { 0, 0xfffffffe } }
9219 	},
9220 	/* BPF_JMP32 | BPF_JLT | BPF_X */
9221 	{
9222 		"JMP32_JLT_X",
9223 		.u.insns_int = {
9224 			BPF_ALU32_IMM(BPF_MOV, R0, 0xfffffffe),
9225 			BPF_ALU32_IMM(BPF_MOV, R1, 0xfffffffd),
9226 			BPF_JMP32_REG(BPF_JLT, R0, R1, 2),
9227 			BPF_ALU32_IMM(BPF_MOV, R1, 0xffffffff),
9228 			BPF_JMP32_REG(BPF_JLT, R0, R1, 1),
9229 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9230 			BPF_EXIT_INSN(),
9231 		},
9232 		INTERNAL,
9233 		{ },
9234 		{ { 0, 0xfffffffe } }
9235 	},
9236 	/* BPF_JMP32 | BPF_JLE | BPF_K */
9237 	{
9238 		"JMP32_JLE_K: Small immediate",
9239 		.u.insns_int = {
9240 			BPF_ALU32_IMM(BPF_MOV, R0, 123),
9241 			BPF_JMP32_IMM(BPF_JLE, R0, 122, 1),
9242 			BPF_JMP32_IMM(BPF_JLE, R0, 123, 1),
9243 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9244 			BPF_EXIT_INSN(),
9245 		},
9246 		INTERNAL,
9247 		{ },
9248 		{ { 0, 123 } }
9249 	},
9250 	{
9251 		"JMP32_JLE_K: Large immediate",
9252 		.u.insns_int = {
9253 			BPF_ALU32_IMM(BPF_MOV, R0, 0xfffffffe),
9254 			BPF_JMP32_IMM(BPF_JLE, R0, 0xfffffffd, 1),
9255 			BPF_JMP32_IMM(BPF_JLE, R0, 0xfffffffe, 1),
9256 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9257 			BPF_EXIT_INSN(),
9258 		},
9259 		INTERNAL,
9260 		{ },
9261 		{ { 0, 0xfffffffe } }
9262 	},
9263 	/* BPF_JMP32 | BPF_JLE | BPF_X */
9264 	{
9265 		"JMP32_JLE_X",
9266 		.u.insns_int = {
9267 			BPF_ALU32_IMM(BPF_MOV, R0, 0xfffffffe),
9268 			BPF_ALU32_IMM(BPF_MOV, R1, 0xfffffffd),
9269 			BPF_JMP32_REG(BPF_JLE, R0, R1, 2),
9270 			BPF_ALU32_IMM(BPF_MOV, R1, 0xfffffffe),
9271 			BPF_JMP32_REG(BPF_JLE, R0, R1, 1),
9272 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9273 			BPF_EXIT_INSN(),
9274 		},
9275 		INTERNAL,
9276 		{ },
9277 		{ { 0, 0xfffffffe } }
9278 	},
9279 	/* BPF_JMP32 | BPF_JSGT | BPF_K */
9280 	{
9281 		"JMP32_JSGT_K: Small immediate",
9282 		.u.insns_int = {
9283 			BPF_ALU32_IMM(BPF_MOV, R0, -123),
9284 			BPF_JMP32_IMM(BPF_JSGT, R0, -123, 1),
9285 			BPF_JMP32_IMM(BPF_JSGT, R0, -124, 1),
9286 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9287 			BPF_EXIT_INSN(),
9288 		},
9289 		INTERNAL,
9290 		{ },
9291 		{ { 0, -123 } }
9292 	},
9293 	{
9294 		"JMP32_JSGT_K: Large immediate",
9295 		.u.insns_int = {
9296 			BPF_ALU32_IMM(BPF_MOV, R0, -12345678),
9297 			BPF_JMP32_IMM(BPF_JSGT, R0, -12345678, 1),
9298 			BPF_JMP32_IMM(BPF_JSGT, R0, -12345679, 1),
9299 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9300 			BPF_EXIT_INSN(),
9301 		},
9302 		INTERNAL,
9303 		{ },
9304 		{ { 0, -12345678 } }
9305 	},
9306 	/* BPF_JMP32 | BPF_JSGT | BPF_X */
9307 	{
9308 		"JMP32_JSGT_X",
9309 		.u.insns_int = {
9310 			BPF_ALU32_IMM(BPF_MOV, R0, -12345678),
9311 			BPF_ALU32_IMM(BPF_MOV, R1, -12345678),
9312 			BPF_JMP32_REG(BPF_JSGT, R0, R1, 2),
9313 			BPF_ALU32_IMM(BPF_MOV, R1, -12345679),
9314 			BPF_JMP32_REG(BPF_JSGT, R0, R1, 1),
9315 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9316 			BPF_EXIT_INSN(),
9317 		},
9318 		INTERNAL,
9319 		{ },
9320 		{ { 0, -12345678 } }
9321 	},
9322 	/* BPF_JMP32 | BPF_JSGE | BPF_K */
9323 	{
9324 		"JMP32_JSGE_K: Small immediate",
9325 		.u.insns_int = {
9326 			BPF_ALU32_IMM(BPF_MOV, R0, -123),
9327 			BPF_JMP32_IMM(BPF_JSGE, R0, -122, 1),
9328 			BPF_JMP32_IMM(BPF_JSGE, R0, -123, 1),
9329 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9330 			BPF_EXIT_INSN(),
9331 		},
9332 		INTERNAL,
9333 		{ },
9334 		{ { 0, -123 } }
9335 	},
9336 	{
9337 		"JMP32_JSGE_K: Large immediate",
9338 		.u.insns_int = {
9339 			BPF_ALU32_IMM(BPF_MOV, R0, -12345678),
9340 			BPF_JMP32_IMM(BPF_JSGE, R0, -12345677, 1),
9341 			BPF_JMP32_IMM(BPF_JSGE, R0, -12345678, 1),
9342 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9343 			BPF_EXIT_INSN(),
9344 		},
9345 		INTERNAL,
9346 		{ },
9347 		{ { 0, -12345678 } }
9348 	},
9349 	/* BPF_JMP32 | BPF_JSGE | BPF_X */
9350 	{
9351 		"JMP32_JSGE_X",
9352 		.u.insns_int = {
9353 			BPF_ALU32_IMM(BPF_MOV, R0, -12345678),
9354 			BPF_ALU32_IMM(BPF_MOV, R1, -12345677),
9355 			BPF_JMP32_REG(BPF_JSGE, R0, R1, 2),
9356 			BPF_ALU32_IMM(BPF_MOV, R1, -12345678),
9357 			BPF_JMP32_REG(BPF_JSGE, R0, R1, 1),
9358 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9359 			BPF_EXIT_INSN(),
9360 		},
9361 		INTERNAL,
9362 		{ },
9363 		{ { 0, -12345678 } }
9364 	},
9365 	/* BPF_JMP32 | BPF_JSLT | BPF_K */
9366 	{
9367 		"JMP32_JSLT_K: Small immediate",
9368 		.u.insns_int = {
9369 			BPF_ALU32_IMM(BPF_MOV, R0, -123),
9370 			BPF_JMP32_IMM(BPF_JSLT, R0, -123, 1),
9371 			BPF_JMP32_IMM(BPF_JSLT, R0, -122, 1),
9372 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9373 			BPF_EXIT_INSN(),
9374 		},
9375 		INTERNAL,
9376 		{ },
9377 		{ { 0, -123 } }
9378 	},
9379 	{
9380 		"JMP32_JSLT_K: Large immediate",
9381 		.u.insns_int = {
9382 			BPF_ALU32_IMM(BPF_MOV, R0, -12345678),
9383 			BPF_JMP32_IMM(BPF_JSLT, R0, -12345678, 1),
9384 			BPF_JMP32_IMM(BPF_JSLT, R0, -12345677, 1),
9385 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9386 			BPF_EXIT_INSN(),
9387 		},
9388 		INTERNAL,
9389 		{ },
9390 		{ { 0, -12345678 } }
9391 	},
9392 	/* BPF_JMP32 | BPF_JSLT | BPF_X */
9393 	{
9394 		"JMP32_JSLT_X",
9395 		.u.insns_int = {
9396 			BPF_ALU32_IMM(BPF_MOV, R0, -12345678),
9397 			BPF_ALU32_IMM(BPF_MOV, R1, -12345678),
9398 			BPF_JMP32_REG(BPF_JSLT, R0, R1, 2),
9399 			BPF_ALU32_IMM(BPF_MOV, R1, -12345677),
9400 			BPF_JMP32_REG(BPF_JSLT, R0, R1, 1),
9401 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9402 			BPF_EXIT_INSN(),
9403 		},
9404 		INTERNAL,
9405 		{ },
9406 		{ { 0, -12345678 } }
9407 	},
9408 	/* BPF_JMP32 | BPF_JSLE | BPF_K */
9409 	{
9410 		"JMP32_JSLE_K: Small immediate",
9411 		.u.insns_int = {
9412 			BPF_ALU32_IMM(BPF_MOV, R0, -123),
9413 			BPF_JMP32_IMM(BPF_JSLE, R0, -124, 1),
9414 			BPF_JMP32_IMM(BPF_JSLE, R0, -123, 1),
9415 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9416 			BPF_EXIT_INSN(),
9417 		},
9418 		INTERNAL,
9419 		{ },
9420 		{ { 0, -123 } }
9421 	},
9422 	{
9423 		"JMP32_JSLE_K: Large immediate",
9424 		.u.insns_int = {
9425 			BPF_ALU32_IMM(BPF_MOV, R0, -12345678),
9426 			BPF_JMP32_IMM(BPF_JSLE, R0, -12345679, 1),
9427 			BPF_JMP32_IMM(BPF_JSLE, R0, -12345678, 1),
9428 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9429 			BPF_EXIT_INSN(),
9430 		},
9431 		INTERNAL,
9432 		{ },
9433 		{ { 0, -12345678 } }
9434 	},
9435 	/* BPF_JMP32 | BPF_JSLE | BPF_K */
9436 	{
9437 		"JMP32_JSLE_X",
9438 		.u.insns_int = {
9439 			BPF_ALU32_IMM(BPF_MOV, R0, -12345678),
9440 			BPF_ALU32_IMM(BPF_MOV, R1, -12345679),
9441 			BPF_JMP32_REG(BPF_JSLE, R0, R1, 2),
9442 			BPF_ALU32_IMM(BPF_MOV, R1, -12345678),
9443 			BPF_JMP32_REG(BPF_JSLE, R0, R1, 1),
9444 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9445 			BPF_EXIT_INSN(),
9446 		},
9447 		INTERNAL,
9448 		{ },
9449 		{ { 0, -12345678 } }
9450 	},
9451 	/* BPF_JMP | BPF_EXIT */
9452 	{
9453 		"JMP_EXIT",
9454 		.u.insns_int = {
9455 			BPF_ALU32_IMM(BPF_MOV, R0, 0x4711),
9456 			BPF_EXIT_INSN(),
9457 			BPF_ALU32_IMM(BPF_MOV, R0, 0x4712),
9458 		},
9459 		INTERNAL,
9460 		{ },
9461 		{ { 0, 0x4711 } },
9462 	},
9463 	/* BPF_JMP | BPF_JA */
9464 	{
9465 		"JMP_JA: Unconditional jump: if (true) return 1",
9466 		.u.insns_int = {
9467 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9468 			BPF_JMP_IMM(BPF_JA, 0, 0, 1),
9469 			BPF_EXIT_INSN(),
9470 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9471 			BPF_EXIT_INSN(),
9472 		},
9473 		INTERNAL,
9474 		{ },
9475 		{ { 0, 1 } },
9476 	},
9477 	/* BPF_JMP | BPF_JSLT | BPF_K */
9478 	{
9479 		"JMP_JSLT_K: Signed jump: if (-2 < -1) return 1",
9480 		.u.insns_int = {
9481 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9482 			BPF_LD_IMM64(R1, 0xfffffffffffffffeLL),
9483 			BPF_JMP_IMM(BPF_JSLT, R1, -1, 1),
9484 			BPF_EXIT_INSN(),
9485 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9486 			BPF_EXIT_INSN(),
9487 		},
9488 		INTERNAL,
9489 		{ },
9490 		{ { 0, 1 } },
9491 	},
9492 	{
9493 		"JMP_JSLT_K: Signed jump: if (-1 < -1) return 0",
9494 		.u.insns_int = {
9495 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9496 			BPF_LD_IMM64(R1, 0xffffffffffffffffLL),
9497 			BPF_JMP_IMM(BPF_JSLT, R1, -1, 1),
9498 			BPF_EXIT_INSN(),
9499 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9500 			BPF_EXIT_INSN(),
9501 		},
9502 		INTERNAL,
9503 		{ },
9504 		{ { 0, 1 } },
9505 	},
9506 	/* BPF_JMP | BPF_JSGT | BPF_K */
9507 	{
9508 		"JMP_JSGT_K: Signed jump: if (-1 > -2) return 1",
9509 		.u.insns_int = {
9510 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9511 			BPF_LD_IMM64(R1, 0xffffffffffffffffLL),
9512 			BPF_JMP_IMM(BPF_JSGT, R1, -2, 1),
9513 			BPF_EXIT_INSN(),
9514 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9515 			BPF_EXIT_INSN(),
9516 		},
9517 		INTERNAL,
9518 		{ },
9519 		{ { 0, 1 } },
9520 	},
9521 	{
9522 		"JMP_JSGT_K: Signed jump: if (-1 > -1) return 0",
9523 		.u.insns_int = {
9524 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9525 			BPF_LD_IMM64(R1, 0xffffffffffffffffLL),
9526 			BPF_JMP_IMM(BPF_JSGT, R1, -1, 1),
9527 			BPF_EXIT_INSN(),
9528 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9529 			BPF_EXIT_INSN(),
9530 		},
9531 		INTERNAL,
9532 		{ },
9533 		{ { 0, 1 } },
9534 	},
9535 	/* BPF_JMP | BPF_JSLE | BPF_K */
9536 	{
9537 		"JMP_JSLE_K: Signed jump: if (-2 <= -1) return 1",
9538 		.u.insns_int = {
9539 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9540 			BPF_LD_IMM64(R1, 0xfffffffffffffffeLL),
9541 			BPF_JMP_IMM(BPF_JSLE, R1, -1, 1),
9542 			BPF_EXIT_INSN(),
9543 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9544 			BPF_EXIT_INSN(),
9545 		},
9546 		INTERNAL,
9547 		{ },
9548 		{ { 0, 1 } },
9549 	},
9550 	{
9551 		"JMP_JSLE_K: Signed jump: if (-1 <= -1) return 1",
9552 		.u.insns_int = {
9553 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9554 			BPF_LD_IMM64(R1, 0xffffffffffffffffLL),
9555 			BPF_JMP_IMM(BPF_JSLE, R1, -1, 1),
9556 			BPF_EXIT_INSN(),
9557 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9558 			BPF_EXIT_INSN(),
9559 		},
9560 		INTERNAL,
9561 		{ },
9562 		{ { 0, 1 } },
9563 	},
9564 	{
9565 		"JMP_JSLE_K: Signed jump: value walk 1",
9566 		.u.insns_int = {
9567 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9568 			BPF_LD_IMM64(R1, 3),
9569 			BPF_JMP_IMM(BPF_JSLE, R1, 0, 6),
9570 			BPF_ALU64_IMM(BPF_SUB, R1, 1),
9571 			BPF_JMP_IMM(BPF_JSLE, R1, 0, 4),
9572 			BPF_ALU64_IMM(BPF_SUB, R1, 1),
9573 			BPF_JMP_IMM(BPF_JSLE, R1, 0, 2),
9574 			BPF_ALU64_IMM(BPF_SUB, R1, 1),
9575 			BPF_JMP_IMM(BPF_JSLE, R1, 0, 1),
9576 			BPF_EXIT_INSN(),		/* bad exit */
9577 			BPF_ALU32_IMM(BPF_MOV, R0, 1),	/* good exit */
9578 			BPF_EXIT_INSN(),
9579 		},
9580 		INTERNAL,
9581 		{ },
9582 		{ { 0, 1 } },
9583 	},
9584 	{
9585 		"JMP_JSLE_K: Signed jump: value walk 2",
9586 		.u.insns_int = {
9587 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9588 			BPF_LD_IMM64(R1, 3),
9589 			BPF_JMP_IMM(BPF_JSLE, R1, 0, 4),
9590 			BPF_ALU64_IMM(BPF_SUB, R1, 2),
9591 			BPF_JMP_IMM(BPF_JSLE, R1, 0, 2),
9592 			BPF_ALU64_IMM(BPF_SUB, R1, 2),
9593 			BPF_JMP_IMM(BPF_JSLE, R1, 0, 1),
9594 			BPF_EXIT_INSN(),		/* bad exit */
9595 			BPF_ALU32_IMM(BPF_MOV, R0, 1),	/* good exit */
9596 			BPF_EXIT_INSN(),
9597 		},
9598 		INTERNAL,
9599 		{ },
9600 		{ { 0, 1 } },
9601 	},
9602 	/* BPF_JMP | BPF_JSGE | BPF_K */
9603 	{
9604 		"JMP_JSGE_K: Signed jump: if (-1 >= -2) return 1",
9605 		.u.insns_int = {
9606 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9607 			BPF_LD_IMM64(R1, 0xffffffffffffffffLL),
9608 			BPF_JMP_IMM(BPF_JSGE, R1, -2, 1),
9609 			BPF_EXIT_INSN(),
9610 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9611 			BPF_EXIT_INSN(),
9612 		},
9613 		INTERNAL,
9614 		{ },
9615 		{ { 0, 1 } },
9616 	},
9617 	{
9618 		"JMP_JSGE_K: Signed jump: if (-1 >= -1) return 1",
9619 		.u.insns_int = {
9620 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9621 			BPF_LD_IMM64(R1, 0xffffffffffffffffLL),
9622 			BPF_JMP_IMM(BPF_JSGE, R1, -1, 1),
9623 			BPF_EXIT_INSN(),
9624 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9625 			BPF_EXIT_INSN(),
9626 		},
9627 		INTERNAL,
9628 		{ },
9629 		{ { 0, 1 } },
9630 	},
9631 	{
9632 		"JMP_JSGE_K: Signed jump: value walk 1",
9633 		.u.insns_int = {
9634 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9635 			BPF_LD_IMM64(R1, -3),
9636 			BPF_JMP_IMM(BPF_JSGE, R1, 0, 6),
9637 			BPF_ALU64_IMM(BPF_ADD, R1, 1),
9638 			BPF_JMP_IMM(BPF_JSGE, R1, 0, 4),
9639 			BPF_ALU64_IMM(BPF_ADD, R1, 1),
9640 			BPF_JMP_IMM(BPF_JSGE, R1, 0, 2),
9641 			BPF_ALU64_IMM(BPF_ADD, R1, 1),
9642 			BPF_JMP_IMM(BPF_JSGE, R1, 0, 1),
9643 			BPF_EXIT_INSN(),		/* bad exit */
9644 			BPF_ALU32_IMM(BPF_MOV, R0, 1),	/* good exit */
9645 			BPF_EXIT_INSN(),
9646 		},
9647 		INTERNAL,
9648 		{ },
9649 		{ { 0, 1 } },
9650 	},
9651 	{
9652 		"JMP_JSGE_K: Signed jump: value walk 2",
9653 		.u.insns_int = {
9654 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9655 			BPF_LD_IMM64(R1, -3),
9656 			BPF_JMP_IMM(BPF_JSGE, R1, 0, 4),
9657 			BPF_ALU64_IMM(BPF_ADD, R1, 2),
9658 			BPF_JMP_IMM(BPF_JSGE, R1, 0, 2),
9659 			BPF_ALU64_IMM(BPF_ADD, R1, 2),
9660 			BPF_JMP_IMM(BPF_JSGE, R1, 0, 1),
9661 			BPF_EXIT_INSN(),		/* bad exit */
9662 			BPF_ALU32_IMM(BPF_MOV, R0, 1),	/* good exit */
9663 			BPF_EXIT_INSN(),
9664 		},
9665 		INTERNAL,
9666 		{ },
9667 		{ { 0, 1 } },
9668 	},
9669 	/* BPF_JMP | BPF_JGT | BPF_K */
9670 	{
9671 		"JMP_JGT_K: if (3 > 2) return 1",
9672 		.u.insns_int = {
9673 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9674 			BPF_LD_IMM64(R1, 3),
9675 			BPF_JMP_IMM(BPF_JGT, R1, 2, 1),
9676 			BPF_EXIT_INSN(),
9677 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9678 			BPF_EXIT_INSN(),
9679 		},
9680 		INTERNAL,
9681 		{ },
9682 		{ { 0, 1 } },
9683 	},
9684 	{
9685 		"JMP_JGT_K: Unsigned jump: if (-1 > 1) return 1",
9686 		.u.insns_int = {
9687 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9688 			BPF_LD_IMM64(R1, -1),
9689 			BPF_JMP_IMM(BPF_JGT, R1, 1, 1),
9690 			BPF_EXIT_INSN(),
9691 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9692 			BPF_EXIT_INSN(),
9693 		},
9694 		INTERNAL,
9695 		{ },
9696 		{ { 0, 1 } },
9697 	},
9698 	/* BPF_JMP | BPF_JLT | BPF_K */
9699 	{
9700 		"JMP_JLT_K: if (2 < 3) return 1",
9701 		.u.insns_int = {
9702 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9703 			BPF_LD_IMM64(R1, 2),
9704 			BPF_JMP_IMM(BPF_JLT, R1, 3, 1),
9705 			BPF_EXIT_INSN(),
9706 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9707 			BPF_EXIT_INSN(),
9708 		},
9709 		INTERNAL,
9710 		{ },
9711 		{ { 0, 1 } },
9712 	},
9713 	{
9714 		"JMP_JGT_K: Unsigned jump: if (1 < -1) return 1",
9715 		.u.insns_int = {
9716 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9717 			BPF_LD_IMM64(R1, 1),
9718 			BPF_JMP_IMM(BPF_JLT, R1, -1, 1),
9719 			BPF_EXIT_INSN(),
9720 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9721 			BPF_EXIT_INSN(),
9722 		},
9723 		INTERNAL,
9724 		{ },
9725 		{ { 0, 1 } },
9726 	},
9727 	/* BPF_JMP | BPF_JGE | BPF_K */
9728 	{
9729 		"JMP_JGE_K: if (3 >= 2) return 1",
9730 		.u.insns_int = {
9731 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9732 			BPF_LD_IMM64(R1, 3),
9733 			BPF_JMP_IMM(BPF_JGE, R1, 2, 1),
9734 			BPF_EXIT_INSN(),
9735 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9736 			BPF_EXIT_INSN(),
9737 		},
9738 		INTERNAL,
9739 		{ },
9740 		{ { 0, 1 } },
9741 	},
9742 	/* BPF_JMP | BPF_JLE | BPF_K */
9743 	{
9744 		"JMP_JLE_K: if (2 <= 3) return 1",
9745 		.u.insns_int = {
9746 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9747 			BPF_LD_IMM64(R1, 2),
9748 			BPF_JMP_IMM(BPF_JLE, R1, 3, 1),
9749 			BPF_EXIT_INSN(),
9750 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9751 			BPF_EXIT_INSN(),
9752 		},
9753 		INTERNAL,
9754 		{ },
9755 		{ { 0, 1 } },
9756 	},
9757 	/* BPF_JMP | BPF_JGT | BPF_K jump backwards */
9758 	{
9759 		"JMP_JGT_K: if (3 > 2) return 1 (jump backwards)",
9760 		.u.insns_int = {
9761 			BPF_JMP_IMM(BPF_JA, 0, 0, 2), /* goto start */
9762 			BPF_ALU32_IMM(BPF_MOV, R0, 1), /* out: */
9763 			BPF_EXIT_INSN(),
9764 			BPF_ALU32_IMM(BPF_MOV, R0, 0), /* start: */
9765 			BPF_LD_IMM64(R1, 3), /* note: this takes 2 insns */
9766 			BPF_JMP_IMM(BPF_JGT, R1, 2, -6), /* goto out */
9767 			BPF_EXIT_INSN(),
9768 		},
9769 		INTERNAL,
9770 		{ },
9771 		{ { 0, 1 } },
9772 	},
9773 	{
9774 		"JMP_JGE_K: if (3 >= 3) return 1",
9775 		.u.insns_int = {
9776 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9777 			BPF_LD_IMM64(R1, 3),
9778 			BPF_JMP_IMM(BPF_JGE, R1, 3, 1),
9779 			BPF_EXIT_INSN(),
9780 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9781 			BPF_EXIT_INSN(),
9782 		},
9783 		INTERNAL,
9784 		{ },
9785 		{ { 0, 1 } },
9786 	},
9787 	/* BPF_JMP | BPF_JLT | BPF_K jump backwards */
9788 	{
9789 		"JMP_JGT_K: if (2 < 3) return 1 (jump backwards)",
9790 		.u.insns_int = {
9791 			BPF_JMP_IMM(BPF_JA, 0, 0, 2), /* goto start */
9792 			BPF_ALU32_IMM(BPF_MOV, R0, 1), /* out: */
9793 			BPF_EXIT_INSN(),
9794 			BPF_ALU32_IMM(BPF_MOV, R0, 0), /* start: */
9795 			BPF_LD_IMM64(R1, 2), /* note: this takes 2 insns */
9796 			BPF_JMP_IMM(BPF_JLT, R1, 3, -6), /* goto out */
9797 			BPF_EXIT_INSN(),
9798 		},
9799 		INTERNAL,
9800 		{ },
9801 		{ { 0, 1 } },
9802 	},
9803 	{
9804 		"JMP_JLE_K: if (3 <= 3) return 1",
9805 		.u.insns_int = {
9806 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9807 			BPF_LD_IMM64(R1, 3),
9808 			BPF_JMP_IMM(BPF_JLE, R1, 3, 1),
9809 			BPF_EXIT_INSN(),
9810 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9811 			BPF_EXIT_INSN(),
9812 		},
9813 		INTERNAL,
9814 		{ },
9815 		{ { 0, 1 } },
9816 	},
9817 	/* BPF_JMP | BPF_JNE | BPF_K */
9818 	{
9819 		"JMP_JNE_K: if (3 != 2) return 1",
9820 		.u.insns_int = {
9821 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9822 			BPF_LD_IMM64(R1, 3),
9823 			BPF_JMP_IMM(BPF_JNE, R1, 2, 1),
9824 			BPF_EXIT_INSN(),
9825 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9826 			BPF_EXIT_INSN(),
9827 		},
9828 		INTERNAL,
9829 		{ },
9830 		{ { 0, 1 } },
9831 	},
9832 	/* BPF_JMP | BPF_JEQ | BPF_K */
9833 	{
9834 		"JMP_JEQ_K: if (3 == 3) return 1",
9835 		.u.insns_int = {
9836 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9837 			BPF_LD_IMM64(R1, 3),
9838 			BPF_JMP_IMM(BPF_JEQ, R1, 3, 1),
9839 			BPF_EXIT_INSN(),
9840 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9841 			BPF_EXIT_INSN(),
9842 		},
9843 		INTERNAL,
9844 		{ },
9845 		{ { 0, 1 } },
9846 	},
9847 	/* BPF_JMP | BPF_JSET | BPF_K */
9848 	{
9849 		"JMP_JSET_K: if (0x3 & 0x2) return 1",
9850 		.u.insns_int = {
9851 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9852 			BPF_LD_IMM64(R1, 3),
9853 			BPF_JMP_IMM(BPF_JSET, R1, 2, 1),
9854 			BPF_EXIT_INSN(),
9855 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9856 			BPF_EXIT_INSN(),
9857 		},
9858 		INTERNAL,
9859 		{ },
9860 		{ { 0, 1 } },
9861 	},
9862 	{
9863 		"JMP_JSET_K: if (0x3 & 0xffffffff) return 1",
9864 		.u.insns_int = {
9865 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9866 			BPF_LD_IMM64(R1, 3),
9867 			BPF_JMP_IMM(BPF_JSET, R1, 0xffffffff, 1),
9868 			BPF_EXIT_INSN(),
9869 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9870 			BPF_EXIT_INSN(),
9871 		},
9872 		INTERNAL,
9873 		{ },
9874 		{ { 0, 1 } },
9875 	},
9876 	/* BPF_JMP | BPF_JSGT | BPF_X */
9877 	{
9878 		"JMP_JSGT_X: Signed jump: if (-1 > -2) return 1",
9879 		.u.insns_int = {
9880 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9881 			BPF_LD_IMM64(R1, -1),
9882 			BPF_LD_IMM64(R2, -2),
9883 			BPF_JMP_REG(BPF_JSGT, R1, R2, 1),
9884 			BPF_EXIT_INSN(),
9885 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9886 			BPF_EXIT_INSN(),
9887 		},
9888 		INTERNAL,
9889 		{ },
9890 		{ { 0, 1 } },
9891 	},
9892 	{
9893 		"JMP_JSGT_X: Signed jump: if (-1 > -1) return 0",
9894 		.u.insns_int = {
9895 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9896 			BPF_LD_IMM64(R1, -1),
9897 			BPF_LD_IMM64(R2, -1),
9898 			BPF_JMP_REG(BPF_JSGT, R1, R2, 1),
9899 			BPF_EXIT_INSN(),
9900 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9901 			BPF_EXIT_INSN(),
9902 		},
9903 		INTERNAL,
9904 		{ },
9905 		{ { 0, 1 } },
9906 	},
9907 	/* BPF_JMP | BPF_JSLT | BPF_X */
9908 	{
9909 		"JMP_JSLT_X: Signed jump: if (-2 < -1) return 1",
9910 		.u.insns_int = {
9911 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9912 			BPF_LD_IMM64(R1, -1),
9913 			BPF_LD_IMM64(R2, -2),
9914 			BPF_JMP_REG(BPF_JSLT, R2, R1, 1),
9915 			BPF_EXIT_INSN(),
9916 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9917 			BPF_EXIT_INSN(),
9918 		},
9919 		INTERNAL,
9920 		{ },
9921 		{ { 0, 1 } },
9922 	},
9923 	{
9924 		"JMP_JSLT_X: Signed jump: if (-1 < -1) return 0",
9925 		.u.insns_int = {
9926 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9927 			BPF_LD_IMM64(R1, -1),
9928 			BPF_LD_IMM64(R2, -1),
9929 			BPF_JMP_REG(BPF_JSLT, R1, R2, 1),
9930 			BPF_EXIT_INSN(),
9931 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9932 			BPF_EXIT_INSN(),
9933 		},
9934 		INTERNAL,
9935 		{ },
9936 		{ { 0, 1 } },
9937 	},
9938 	/* BPF_JMP | BPF_JSGE | BPF_X */
9939 	{
9940 		"JMP_JSGE_X: Signed jump: if (-1 >= -2) return 1",
9941 		.u.insns_int = {
9942 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9943 			BPF_LD_IMM64(R1, -1),
9944 			BPF_LD_IMM64(R2, -2),
9945 			BPF_JMP_REG(BPF_JSGE, R1, R2, 1),
9946 			BPF_EXIT_INSN(),
9947 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9948 			BPF_EXIT_INSN(),
9949 		},
9950 		INTERNAL,
9951 		{ },
9952 		{ { 0, 1 } },
9953 	},
9954 	{
9955 		"JMP_JSGE_X: Signed jump: if (-1 >= -1) return 1",
9956 		.u.insns_int = {
9957 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9958 			BPF_LD_IMM64(R1, -1),
9959 			BPF_LD_IMM64(R2, -1),
9960 			BPF_JMP_REG(BPF_JSGE, R1, R2, 1),
9961 			BPF_EXIT_INSN(),
9962 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9963 			BPF_EXIT_INSN(),
9964 		},
9965 		INTERNAL,
9966 		{ },
9967 		{ { 0, 1 } },
9968 	},
9969 	/* BPF_JMP | BPF_JSLE | BPF_X */
9970 	{
9971 		"JMP_JSLE_X: Signed jump: if (-2 <= -1) return 1",
9972 		.u.insns_int = {
9973 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9974 			BPF_LD_IMM64(R1, -1),
9975 			BPF_LD_IMM64(R2, -2),
9976 			BPF_JMP_REG(BPF_JSLE, R2, R1, 1),
9977 			BPF_EXIT_INSN(),
9978 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9979 			BPF_EXIT_INSN(),
9980 		},
9981 		INTERNAL,
9982 		{ },
9983 		{ { 0, 1 } },
9984 	},
9985 	{
9986 		"JMP_JSLE_X: Signed jump: if (-1 <= -1) return 1",
9987 		.u.insns_int = {
9988 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
9989 			BPF_LD_IMM64(R1, -1),
9990 			BPF_LD_IMM64(R2, -1),
9991 			BPF_JMP_REG(BPF_JSLE, R1, R2, 1),
9992 			BPF_EXIT_INSN(),
9993 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
9994 			BPF_EXIT_INSN(),
9995 		},
9996 		INTERNAL,
9997 		{ },
9998 		{ { 0, 1 } },
9999 	},
10000 	/* BPF_JMP | BPF_JGT | BPF_X */
10001 	{
10002 		"JMP_JGT_X: if (3 > 2) return 1",
10003 		.u.insns_int = {
10004 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10005 			BPF_LD_IMM64(R1, 3),
10006 			BPF_LD_IMM64(R2, 2),
10007 			BPF_JMP_REG(BPF_JGT, R1, R2, 1),
10008 			BPF_EXIT_INSN(),
10009 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
10010 			BPF_EXIT_INSN(),
10011 		},
10012 		INTERNAL,
10013 		{ },
10014 		{ { 0, 1 } },
10015 	},
10016 	{
10017 		"JMP_JGT_X: Unsigned jump: if (-1 > 1) return 1",
10018 		.u.insns_int = {
10019 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10020 			BPF_LD_IMM64(R1, -1),
10021 			BPF_LD_IMM64(R2, 1),
10022 			BPF_JMP_REG(BPF_JGT, R1, R2, 1),
10023 			BPF_EXIT_INSN(),
10024 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
10025 			BPF_EXIT_INSN(),
10026 		},
10027 		INTERNAL,
10028 		{ },
10029 		{ { 0, 1 } },
10030 	},
10031 	/* BPF_JMP | BPF_JLT | BPF_X */
10032 	{
10033 		"JMP_JLT_X: if (2 < 3) return 1",
10034 		.u.insns_int = {
10035 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10036 			BPF_LD_IMM64(R1, 3),
10037 			BPF_LD_IMM64(R2, 2),
10038 			BPF_JMP_REG(BPF_JLT, R2, R1, 1),
10039 			BPF_EXIT_INSN(),
10040 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
10041 			BPF_EXIT_INSN(),
10042 		},
10043 		INTERNAL,
10044 		{ },
10045 		{ { 0, 1 } },
10046 	},
10047 	{
10048 		"JMP_JLT_X: Unsigned jump: if (1 < -1) return 1",
10049 		.u.insns_int = {
10050 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10051 			BPF_LD_IMM64(R1, -1),
10052 			BPF_LD_IMM64(R2, 1),
10053 			BPF_JMP_REG(BPF_JLT, R2, R1, 1),
10054 			BPF_EXIT_INSN(),
10055 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
10056 			BPF_EXIT_INSN(),
10057 		},
10058 		INTERNAL,
10059 		{ },
10060 		{ { 0, 1 } },
10061 	},
10062 	/* BPF_JMP | BPF_JGE | BPF_X */
10063 	{
10064 		"JMP_JGE_X: if (3 >= 2) return 1",
10065 		.u.insns_int = {
10066 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10067 			BPF_LD_IMM64(R1, 3),
10068 			BPF_LD_IMM64(R2, 2),
10069 			BPF_JMP_REG(BPF_JGE, R1, R2, 1),
10070 			BPF_EXIT_INSN(),
10071 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
10072 			BPF_EXIT_INSN(),
10073 		},
10074 		INTERNAL,
10075 		{ },
10076 		{ { 0, 1 } },
10077 	},
10078 	{
10079 		"JMP_JGE_X: if (3 >= 3) return 1",
10080 		.u.insns_int = {
10081 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10082 			BPF_LD_IMM64(R1, 3),
10083 			BPF_LD_IMM64(R2, 3),
10084 			BPF_JMP_REG(BPF_JGE, R1, R2, 1),
10085 			BPF_EXIT_INSN(),
10086 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
10087 			BPF_EXIT_INSN(),
10088 		},
10089 		INTERNAL,
10090 		{ },
10091 		{ { 0, 1 } },
10092 	},
10093 	/* BPF_JMP | BPF_JLE | BPF_X */
10094 	{
10095 		"JMP_JLE_X: if (2 <= 3) return 1",
10096 		.u.insns_int = {
10097 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10098 			BPF_LD_IMM64(R1, 3),
10099 			BPF_LD_IMM64(R2, 2),
10100 			BPF_JMP_REG(BPF_JLE, R2, R1, 1),
10101 			BPF_EXIT_INSN(),
10102 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
10103 			BPF_EXIT_INSN(),
10104 		},
10105 		INTERNAL,
10106 		{ },
10107 		{ { 0, 1 } },
10108 	},
10109 	{
10110 		"JMP_JLE_X: if (3 <= 3) return 1",
10111 		.u.insns_int = {
10112 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10113 			BPF_LD_IMM64(R1, 3),
10114 			BPF_LD_IMM64(R2, 3),
10115 			BPF_JMP_REG(BPF_JLE, R1, R2, 1),
10116 			BPF_EXIT_INSN(),
10117 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
10118 			BPF_EXIT_INSN(),
10119 		},
10120 		INTERNAL,
10121 		{ },
10122 		{ { 0, 1 } },
10123 	},
10124 	{
10125 		/* Mainly testing JIT + imm64 here. */
10126 		"JMP_JGE_X: ldimm64 test 1",
10127 		.u.insns_int = {
10128 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10129 			BPF_LD_IMM64(R1, 3),
10130 			BPF_LD_IMM64(R2, 2),
10131 			BPF_JMP_REG(BPF_JGE, R1, R2, 2),
10132 			BPF_LD_IMM64(R0, 0xffffffffffffffffULL),
10133 			BPF_LD_IMM64(R0, 0xeeeeeeeeeeeeeeeeULL),
10134 			BPF_EXIT_INSN(),
10135 		},
10136 		INTERNAL,
10137 		{ },
10138 		{ { 0, 0xeeeeeeeeU } },
10139 	},
10140 	{
10141 		"JMP_JGE_X: ldimm64 test 2",
10142 		.u.insns_int = {
10143 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10144 			BPF_LD_IMM64(R1, 3),
10145 			BPF_LD_IMM64(R2, 2),
10146 			BPF_JMP_REG(BPF_JGE, R1, R2, 0),
10147 			BPF_LD_IMM64(R0, 0xffffffffffffffffULL),
10148 			BPF_EXIT_INSN(),
10149 		},
10150 		INTERNAL,
10151 		{ },
10152 		{ { 0, 0xffffffffU } },
10153 	},
10154 	{
10155 		"JMP_JGE_X: ldimm64 test 3",
10156 		.u.insns_int = {
10157 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
10158 			BPF_LD_IMM64(R1, 3),
10159 			BPF_LD_IMM64(R2, 2),
10160 			BPF_JMP_REG(BPF_JGE, R1, R2, 4),
10161 			BPF_LD_IMM64(R0, 0xffffffffffffffffULL),
10162 			BPF_LD_IMM64(R0, 0xeeeeeeeeeeeeeeeeULL),
10163 			BPF_EXIT_INSN(),
10164 		},
10165 		INTERNAL,
10166 		{ },
10167 		{ { 0, 1 } },
10168 	},
10169 	{
10170 		"JMP_JLE_X: ldimm64 test 1",
10171 		.u.insns_int = {
10172 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10173 			BPF_LD_IMM64(R1, 3),
10174 			BPF_LD_IMM64(R2, 2),
10175 			BPF_JMP_REG(BPF_JLE, R2, R1, 2),
10176 			BPF_LD_IMM64(R0, 0xffffffffffffffffULL),
10177 			BPF_LD_IMM64(R0, 0xeeeeeeeeeeeeeeeeULL),
10178 			BPF_EXIT_INSN(),
10179 		},
10180 		INTERNAL,
10181 		{ },
10182 		{ { 0, 0xeeeeeeeeU } },
10183 	},
10184 	{
10185 		"JMP_JLE_X: ldimm64 test 2",
10186 		.u.insns_int = {
10187 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10188 			BPF_LD_IMM64(R1, 3),
10189 			BPF_LD_IMM64(R2, 2),
10190 			BPF_JMP_REG(BPF_JLE, R2, R1, 0),
10191 			BPF_LD_IMM64(R0, 0xffffffffffffffffULL),
10192 			BPF_EXIT_INSN(),
10193 		},
10194 		INTERNAL,
10195 		{ },
10196 		{ { 0, 0xffffffffU } },
10197 	},
10198 	{
10199 		"JMP_JLE_X: ldimm64 test 3",
10200 		.u.insns_int = {
10201 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
10202 			BPF_LD_IMM64(R1, 3),
10203 			BPF_LD_IMM64(R2, 2),
10204 			BPF_JMP_REG(BPF_JLE, R2, R1, 4),
10205 			BPF_LD_IMM64(R0, 0xffffffffffffffffULL),
10206 			BPF_LD_IMM64(R0, 0xeeeeeeeeeeeeeeeeULL),
10207 			BPF_EXIT_INSN(),
10208 		},
10209 		INTERNAL,
10210 		{ },
10211 		{ { 0, 1 } },
10212 	},
10213 	/* BPF_JMP | BPF_JNE | BPF_X */
10214 	{
10215 		"JMP_JNE_X: if (3 != 2) return 1",
10216 		.u.insns_int = {
10217 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10218 			BPF_LD_IMM64(R1, 3),
10219 			BPF_LD_IMM64(R2, 2),
10220 			BPF_JMP_REG(BPF_JNE, R1, R2, 1),
10221 			BPF_EXIT_INSN(),
10222 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
10223 			BPF_EXIT_INSN(),
10224 		},
10225 		INTERNAL,
10226 		{ },
10227 		{ { 0, 1 } },
10228 	},
10229 	/* BPF_JMP | BPF_JEQ | BPF_X */
10230 	{
10231 		"JMP_JEQ_X: if (3 == 3) return 1",
10232 		.u.insns_int = {
10233 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10234 			BPF_LD_IMM64(R1, 3),
10235 			BPF_LD_IMM64(R2, 3),
10236 			BPF_JMP_REG(BPF_JEQ, R1, R2, 1),
10237 			BPF_EXIT_INSN(),
10238 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
10239 			BPF_EXIT_INSN(),
10240 		},
10241 		INTERNAL,
10242 		{ },
10243 		{ { 0, 1 } },
10244 	},
10245 	/* BPF_JMP | BPF_JSET | BPF_X */
10246 	{
10247 		"JMP_JSET_X: if (0x3 & 0x2) return 1",
10248 		.u.insns_int = {
10249 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10250 			BPF_LD_IMM64(R1, 3),
10251 			BPF_LD_IMM64(R2, 2),
10252 			BPF_JMP_REG(BPF_JSET, R1, R2, 1),
10253 			BPF_EXIT_INSN(),
10254 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
10255 			BPF_EXIT_INSN(),
10256 		},
10257 		INTERNAL,
10258 		{ },
10259 		{ { 0, 1 } },
10260 	},
10261 	{
10262 		"JMP_JSET_X: if (0x3 & 0xffffffff) return 1",
10263 		.u.insns_int = {
10264 			BPF_ALU32_IMM(BPF_MOV, R0, 0),
10265 			BPF_LD_IMM64(R1, 3),
10266 			BPF_LD_IMM64(R2, 0xffffffff),
10267 			BPF_JMP_REG(BPF_JSET, R1, R2, 1),
10268 			BPF_EXIT_INSN(),
10269 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
10270 			BPF_EXIT_INSN(),
10271 		},
10272 		INTERNAL,
10273 		{ },
10274 		{ { 0, 1 } },
10275 	},
10276 	{
10277 		"JMP_JA: Jump, gap, jump, ...",
10278 		{ },
10279 		CLASSIC | FLAG_NO_DATA,
10280 		{ },
10281 		{ { 0, 0xababcbac } },
10282 		.fill_helper = bpf_fill_ja,
10283 	},
10284 	{	/* Mainly checking JIT here. */
10285 		"BPF_MAXINSNS: Maximum possible literals",
10286 		{ },
10287 		CLASSIC | FLAG_NO_DATA,
10288 		{ },
10289 		{ { 0, 0xffffffff } },
10290 		.fill_helper = bpf_fill_maxinsns1,
10291 	},
10292 	{	/* Mainly checking JIT here. */
10293 		"BPF_MAXINSNS: Single literal",
10294 		{ },
10295 		CLASSIC | FLAG_NO_DATA,
10296 		{ },
10297 		{ { 0, 0xfefefefe } },
10298 		.fill_helper = bpf_fill_maxinsns2,
10299 	},
10300 	{	/* Mainly checking JIT here. */
10301 		"BPF_MAXINSNS: Run/add until end",
10302 		{ },
10303 		CLASSIC | FLAG_NO_DATA,
10304 		{ },
10305 		{ { 0, 0x947bf368 } },
10306 		.fill_helper = bpf_fill_maxinsns3,
10307 	},
10308 	{
10309 		"BPF_MAXINSNS: Too many instructions",
10310 		{ },
10311 		CLASSIC | FLAG_NO_DATA | FLAG_EXPECTED_FAIL,
10312 		{ },
10313 		{ },
10314 		.fill_helper = bpf_fill_maxinsns4,
10315 		.expected_errcode = -EINVAL,
10316 	},
10317 	{	/* Mainly checking JIT here. */
10318 		"BPF_MAXINSNS: Very long jump",
10319 		{ },
10320 		CLASSIC | FLAG_NO_DATA,
10321 		{ },
10322 		{ { 0, 0xabababab } },
10323 		.fill_helper = bpf_fill_maxinsns5,
10324 	},
10325 	{	/* Mainly checking JIT here. */
10326 		"BPF_MAXINSNS: Ctx heavy transformations",
10327 		{ },
10328 		CLASSIC,
10329 		{ },
10330 		{
10331 			{  1, SKB_VLAN_PRESENT },
10332 			{ 10, SKB_VLAN_PRESENT }
10333 		},
10334 		.fill_helper = bpf_fill_maxinsns6,
10335 	},
10336 	{	/* Mainly checking JIT here. */
10337 		"BPF_MAXINSNS: Call heavy transformations",
10338 		{ },
10339 		CLASSIC | FLAG_NO_DATA,
10340 		{ },
10341 		{ { 1, 0 }, { 10, 0 } },
10342 		.fill_helper = bpf_fill_maxinsns7,
10343 	},
10344 	{	/* Mainly checking JIT here. */
10345 		"BPF_MAXINSNS: Jump heavy test",
10346 		{ },
10347 		CLASSIC | FLAG_NO_DATA,
10348 		{ },
10349 		{ { 0, 0xffffffff } },
10350 		.fill_helper = bpf_fill_maxinsns8,
10351 	},
10352 	{	/* Mainly checking JIT here. */
10353 		"BPF_MAXINSNS: Very long jump backwards",
10354 		{ },
10355 		INTERNAL | FLAG_NO_DATA,
10356 		{ },
10357 		{ { 0, 0xcbababab } },
10358 		.fill_helper = bpf_fill_maxinsns9,
10359 	},
10360 	{	/* Mainly checking JIT here. */
10361 		"BPF_MAXINSNS: Edge hopping nuthouse",
10362 		{ },
10363 		INTERNAL | FLAG_NO_DATA,
10364 		{ },
10365 		{ { 0, 0xabababac } },
10366 		.fill_helper = bpf_fill_maxinsns10,
10367 	},
10368 	{
10369 		"BPF_MAXINSNS: Jump, gap, jump, ...",
10370 		{ },
10371 		CLASSIC | FLAG_NO_DATA,
10372 		{ },
10373 		{ { 0, 0xababcbac } },
10374 		.fill_helper = bpf_fill_maxinsns11,
10375 	},
10376 	{
10377 		"BPF_MAXINSNS: jump over MSH",
10378 		{ },
10379 		CLASSIC | FLAG_EXPECTED_FAIL,
10380 		{ 0xfa, 0xfb, 0xfc, 0xfd, },
10381 		{ { 4, 0xabababab } },
10382 		.fill_helper = bpf_fill_maxinsns12,
10383 		.expected_errcode = -EINVAL,
10384 	},
10385 	{
10386 		"BPF_MAXINSNS: exec all MSH",
10387 		{ },
10388 		CLASSIC,
10389 		{ 0xfa, 0xfb, 0xfc, 0xfd, },
10390 		{ { 4, 0xababab83 } },
10391 		.fill_helper = bpf_fill_maxinsns13,
10392 	},
10393 	{
10394 		"BPF_MAXINSNS: ld_abs+get_processor_id",
10395 		{ },
10396 		CLASSIC,
10397 		{ },
10398 		{ { 1, 0xbee } },
10399 		.fill_helper = bpf_fill_ld_abs_get_processor_id,
10400 	},
10401 	/*
10402 	 * LD_IND / LD_ABS on fragmented SKBs
10403 	 */
10404 	{
10405 		"LD_IND byte frag",
10406 		.u.insns = {
10407 			BPF_STMT(BPF_LDX | BPF_IMM, 0x40),
10408 			BPF_STMT(BPF_LD | BPF_IND | BPF_B, 0x0),
10409 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10410 		},
10411 		CLASSIC | FLAG_SKB_FRAG,
10412 		{ },
10413 		{ {0x40, 0x42} },
10414 		.frag_data = {
10415 			0x42, 0x00, 0x00, 0x00,
10416 			0x43, 0x44, 0x00, 0x00,
10417 			0x21, 0x07, 0x19, 0x83,
10418 		},
10419 	},
10420 	{
10421 		"LD_IND halfword frag",
10422 		.u.insns = {
10423 			BPF_STMT(BPF_LDX | BPF_IMM, 0x40),
10424 			BPF_STMT(BPF_LD | BPF_IND | BPF_H, 0x4),
10425 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10426 		},
10427 		CLASSIC | FLAG_SKB_FRAG,
10428 		{ },
10429 		{ {0x40, 0x4344} },
10430 		.frag_data = {
10431 			0x42, 0x00, 0x00, 0x00,
10432 			0x43, 0x44, 0x00, 0x00,
10433 			0x21, 0x07, 0x19, 0x83,
10434 		},
10435 	},
10436 	{
10437 		"LD_IND word frag",
10438 		.u.insns = {
10439 			BPF_STMT(BPF_LDX | BPF_IMM, 0x40),
10440 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, 0x8),
10441 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10442 		},
10443 		CLASSIC | FLAG_SKB_FRAG,
10444 		{ },
10445 		{ {0x40, 0x21071983} },
10446 		.frag_data = {
10447 			0x42, 0x00, 0x00, 0x00,
10448 			0x43, 0x44, 0x00, 0x00,
10449 			0x21, 0x07, 0x19, 0x83,
10450 		},
10451 	},
10452 	{
10453 		"LD_IND halfword mixed head/frag",
10454 		.u.insns = {
10455 			BPF_STMT(BPF_LDX | BPF_IMM, 0x40),
10456 			BPF_STMT(BPF_LD | BPF_IND | BPF_H, -0x1),
10457 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10458 		},
10459 		CLASSIC | FLAG_SKB_FRAG,
10460 		{ [0x3e] = 0x25, [0x3f] = 0x05, },
10461 		{ {0x40, 0x0519} },
10462 		.frag_data = { 0x19, 0x82 },
10463 	},
10464 	{
10465 		"LD_IND word mixed head/frag",
10466 		.u.insns = {
10467 			BPF_STMT(BPF_LDX | BPF_IMM, 0x40),
10468 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, -0x2),
10469 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10470 		},
10471 		CLASSIC | FLAG_SKB_FRAG,
10472 		{ [0x3e] = 0x25, [0x3f] = 0x05, },
10473 		{ {0x40, 0x25051982} },
10474 		.frag_data = { 0x19, 0x82 },
10475 	},
10476 	{
10477 		"LD_ABS byte frag",
10478 		.u.insns = {
10479 			BPF_STMT(BPF_LD | BPF_ABS | BPF_B, 0x40),
10480 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10481 		},
10482 		CLASSIC | FLAG_SKB_FRAG,
10483 		{ },
10484 		{ {0x40, 0x42} },
10485 		.frag_data = {
10486 			0x42, 0x00, 0x00, 0x00,
10487 			0x43, 0x44, 0x00, 0x00,
10488 			0x21, 0x07, 0x19, 0x83,
10489 		},
10490 	},
10491 	{
10492 		"LD_ABS halfword frag",
10493 		.u.insns = {
10494 			BPF_STMT(BPF_LD | BPF_ABS | BPF_H, 0x44),
10495 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10496 		},
10497 		CLASSIC | FLAG_SKB_FRAG,
10498 		{ },
10499 		{ {0x40, 0x4344} },
10500 		.frag_data = {
10501 			0x42, 0x00, 0x00, 0x00,
10502 			0x43, 0x44, 0x00, 0x00,
10503 			0x21, 0x07, 0x19, 0x83,
10504 		},
10505 	},
10506 	{
10507 		"LD_ABS word frag",
10508 		.u.insns = {
10509 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, 0x48),
10510 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10511 		},
10512 		CLASSIC | FLAG_SKB_FRAG,
10513 		{ },
10514 		{ {0x40, 0x21071983} },
10515 		.frag_data = {
10516 			0x42, 0x00, 0x00, 0x00,
10517 			0x43, 0x44, 0x00, 0x00,
10518 			0x21, 0x07, 0x19, 0x83,
10519 		},
10520 	},
10521 	{
10522 		"LD_ABS halfword mixed head/frag",
10523 		.u.insns = {
10524 			BPF_STMT(BPF_LD | BPF_ABS | BPF_H, 0x3f),
10525 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10526 		},
10527 		CLASSIC | FLAG_SKB_FRAG,
10528 		{ [0x3e] = 0x25, [0x3f] = 0x05, },
10529 		{ {0x40, 0x0519} },
10530 		.frag_data = { 0x19, 0x82 },
10531 	},
10532 	{
10533 		"LD_ABS word mixed head/frag",
10534 		.u.insns = {
10535 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, 0x3e),
10536 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10537 		},
10538 		CLASSIC | FLAG_SKB_FRAG,
10539 		{ [0x3e] = 0x25, [0x3f] = 0x05, },
10540 		{ {0x40, 0x25051982} },
10541 		.frag_data = { 0x19, 0x82 },
10542 	},
10543 	/*
10544 	 * LD_IND / LD_ABS on non fragmented SKBs
10545 	 */
10546 	{
10547 		/*
10548 		 * this tests that the JIT/interpreter correctly resets X
10549 		 * before using it in an LD_IND instruction.
10550 		 */
10551 		"LD_IND byte default X",
10552 		.u.insns = {
10553 			BPF_STMT(BPF_LD | BPF_IND | BPF_B, 0x1),
10554 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10555 		},
10556 		CLASSIC,
10557 		{ [0x1] = 0x42 },
10558 		{ {0x40, 0x42 } },
10559 	},
10560 	{
10561 		"LD_IND byte positive offset",
10562 		.u.insns = {
10563 			BPF_STMT(BPF_LDX | BPF_IMM, 0x3e),
10564 			BPF_STMT(BPF_LD | BPF_IND | BPF_B, 0x1),
10565 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10566 		},
10567 		CLASSIC,
10568 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10569 		{ {0x40, 0x82 } },
10570 	},
10571 	{
10572 		"LD_IND byte negative offset",
10573 		.u.insns = {
10574 			BPF_STMT(BPF_LDX | BPF_IMM, 0x3e),
10575 			BPF_STMT(BPF_LD | BPF_IND | BPF_B, -0x1),
10576 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10577 		},
10578 		CLASSIC,
10579 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10580 		{ {0x40, 0x05 } },
10581 	},
10582 	{
10583 		"LD_IND byte positive offset, all ff",
10584 		.u.insns = {
10585 			BPF_STMT(BPF_LDX | BPF_IMM, 0x3e),
10586 			BPF_STMT(BPF_LD | BPF_IND | BPF_B, 0x1),
10587 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10588 		},
10589 		CLASSIC,
10590 		{ [0x3c] = 0xff, [0x3d] = 0xff,  [0x3e] = 0xff, [0x3f] = 0xff },
10591 		{ {0x40, 0xff } },
10592 	},
10593 	{
10594 		"LD_IND byte positive offset, out of bounds",
10595 		.u.insns = {
10596 			BPF_STMT(BPF_LDX | BPF_IMM, 0x3e),
10597 			BPF_STMT(BPF_LD | BPF_IND | BPF_B, 0x1),
10598 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10599 		},
10600 		CLASSIC,
10601 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10602 		{ {0x3f, 0 }, },
10603 	},
10604 	{
10605 		"LD_IND byte negative offset, out of bounds",
10606 		.u.insns = {
10607 			BPF_STMT(BPF_LDX | BPF_IMM, 0x3e),
10608 			BPF_STMT(BPF_LD | BPF_IND | BPF_B, -0x3f),
10609 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10610 		},
10611 		CLASSIC,
10612 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10613 		{ {0x3f, 0 } },
10614 	},
10615 	{
10616 		"LD_IND byte negative offset, multiple calls",
10617 		.u.insns = {
10618 			BPF_STMT(BPF_LDX | BPF_IMM, 0x3b),
10619 			BPF_STMT(BPF_LD | BPF_IND | BPF_B, SKF_LL_OFF + 1),
10620 			BPF_STMT(BPF_LD | BPF_IND | BPF_B, SKF_LL_OFF + 2),
10621 			BPF_STMT(BPF_LD | BPF_IND | BPF_B, SKF_LL_OFF + 3),
10622 			BPF_STMT(BPF_LD | BPF_IND | BPF_B, SKF_LL_OFF + 4),
10623 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10624 		},
10625 		CLASSIC,
10626 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10627 		{ {0x40, 0x82 }, },
10628 	},
10629 	{
10630 		"LD_IND halfword positive offset",
10631 		.u.insns = {
10632 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
10633 			BPF_STMT(BPF_LD | BPF_IND | BPF_H, 0x2),
10634 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10635 		},
10636 		CLASSIC,
10637 		{
10638 			[0x1c] = 0xaa, [0x1d] = 0x55,
10639 			[0x1e] = 0xbb, [0x1f] = 0x66,
10640 			[0x20] = 0xcc, [0x21] = 0x77,
10641 			[0x22] = 0xdd, [0x23] = 0x88,
10642 		},
10643 		{ {0x40, 0xdd88 } },
10644 	},
10645 	{
10646 		"LD_IND halfword negative offset",
10647 		.u.insns = {
10648 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
10649 			BPF_STMT(BPF_LD | BPF_IND | BPF_H, -0x2),
10650 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10651 		},
10652 		CLASSIC,
10653 		{
10654 			[0x1c] = 0xaa, [0x1d] = 0x55,
10655 			[0x1e] = 0xbb, [0x1f] = 0x66,
10656 			[0x20] = 0xcc, [0x21] = 0x77,
10657 			[0x22] = 0xdd, [0x23] = 0x88,
10658 		},
10659 		{ {0x40, 0xbb66 } },
10660 	},
10661 	{
10662 		"LD_IND halfword unaligned",
10663 		.u.insns = {
10664 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
10665 			BPF_STMT(BPF_LD | BPF_IND | BPF_H, -0x1),
10666 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10667 		},
10668 		CLASSIC,
10669 		{
10670 			[0x1c] = 0xaa, [0x1d] = 0x55,
10671 			[0x1e] = 0xbb, [0x1f] = 0x66,
10672 			[0x20] = 0xcc, [0x21] = 0x77,
10673 			[0x22] = 0xdd, [0x23] = 0x88,
10674 		},
10675 		{ {0x40, 0x66cc } },
10676 	},
10677 	{
10678 		"LD_IND halfword positive offset, all ff",
10679 		.u.insns = {
10680 			BPF_STMT(BPF_LDX | BPF_IMM, 0x3d),
10681 			BPF_STMT(BPF_LD | BPF_IND | BPF_H, 0x1),
10682 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10683 		},
10684 		CLASSIC,
10685 		{ [0x3c] = 0xff, [0x3d] = 0xff,  [0x3e] = 0xff, [0x3f] = 0xff },
10686 		{ {0x40, 0xffff } },
10687 	},
10688 	{
10689 		"LD_IND halfword positive offset, out of bounds",
10690 		.u.insns = {
10691 			BPF_STMT(BPF_LDX | BPF_IMM, 0x3e),
10692 			BPF_STMT(BPF_LD | BPF_IND | BPF_H, 0x1),
10693 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10694 		},
10695 		CLASSIC,
10696 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10697 		{ {0x3f, 0 }, },
10698 	},
10699 	{
10700 		"LD_IND halfword negative offset, out of bounds",
10701 		.u.insns = {
10702 			BPF_STMT(BPF_LDX | BPF_IMM, 0x3e),
10703 			BPF_STMT(BPF_LD | BPF_IND | BPF_H, -0x3f),
10704 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10705 		},
10706 		CLASSIC,
10707 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10708 		{ {0x3f, 0 } },
10709 	},
10710 	{
10711 		"LD_IND word positive offset",
10712 		.u.insns = {
10713 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
10714 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, 0x4),
10715 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10716 		},
10717 		CLASSIC,
10718 		{
10719 			[0x1c] = 0xaa, [0x1d] = 0x55,
10720 			[0x1e] = 0xbb, [0x1f] = 0x66,
10721 			[0x20] = 0xcc, [0x21] = 0x77,
10722 			[0x22] = 0xdd, [0x23] = 0x88,
10723 			[0x24] = 0xee, [0x25] = 0x99,
10724 			[0x26] = 0xff, [0x27] = 0xaa,
10725 		},
10726 		{ {0x40, 0xee99ffaa } },
10727 	},
10728 	{
10729 		"LD_IND word negative offset",
10730 		.u.insns = {
10731 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
10732 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, -0x4),
10733 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10734 		},
10735 		CLASSIC,
10736 		{
10737 			[0x1c] = 0xaa, [0x1d] = 0x55,
10738 			[0x1e] = 0xbb, [0x1f] = 0x66,
10739 			[0x20] = 0xcc, [0x21] = 0x77,
10740 			[0x22] = 0xdd, [0x23] = 0x88,
10741 			[0x24] = 0xee, [0x25] = 0x99,
10742 			[0x26] = 0xff, [0x27] = 0xaa,
10743 		},
10744 		{ {0x40, 0xaa55bb66 } },
10745 	},
10746 	{
10747 		"LD_IND word unaligned (addr & 3 == 2)",
10748 		.u.insns = {
10749 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
10750 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, -0x2),
10751 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10752 		},
10753 		CLASSIC,
10754 		{
10755 			[0x1c] = 0xaa, [0x1d] = 0x55,
10756 			[0x1e] = 0xbb, [0x1f] = 0x66,
10757 			[0x20] = 0xcc, [0x21] = 0x77,
10758 			[0x22] = 0xdd, [0x23] = 0x88,
10759 			[0x24] = 0xee, [0x25] = 0x99,
10760 			[0x26] = 0xff, [0x27] = 0xaa,
10761 		},
10762 		{ {0x40, 0xbb66cc77 } },
10763 	},
10764 	{
10765 		"LD_IND word unaligned (addr & 3 == 1)",
10766 		.u.insns = {
10767 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
10768 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, -0x3),
10769 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10770 		},
10771 		CLASSIC,
10772 		{
10773 			[0x1c] = 0xaa, [0x1d] = 0x55,
10774 			[0x1e] = 0xbb, [0x1f] = 0x66,
10775 			[0x20] = 0xcc, [0x21] = 0x77,
10776 			[0x22] = 0xdd, [0x23] = 0x88,
10777 			[0x24] = 0xee, [0x25] = 0x99,
10778 			[0x26] = 0xff, [0x27] = 0xaa,
10779 		},
10780 		{ {0x40, 0x55bb66cc } },
10781 	},
10782 	{
10783 		"LD_IND word unaligned (addr & 3 == 3)",
10784 		.u.insns = {
10785 			BPF_STMT(BPF_LDX | BPF_IMM, 0x20),
10786 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, -0x1),
10787 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10788 		},
10789 		CLASSIC,
10790 		{
10791 			[0x1c] = 0xaa, [0x1d] = 0x55,
10792 			[0x1e] = 0xbb, [0x1f] = 0x66,
10793 			[0x20] = 0xcc, [0x21] = 0x77,
10794 			[0x22] = 0xdd, [0x23] = 0x88,
10795 			[0x24] = 0xee, [0x25] = 0x99,
10796 			[0x26] = 0xff, [0x27] = 0xaa,
10797 		},
10798 		{ {0x40, 0x66cc77dd } },
10799 	},
10800 	{
10801 		"LD_IND word positive offset, all ff",
10802 		.u.insns = {
10803 			BPF_STMT(BPF_LDX | BPF_IMM, 0x3b),
10804 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, 0x1),
10805 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10806 		},
10807 		CLASSIC,
10808 		{ [0x3c] = 0xff, [0x3d] = 0xff,  [0x3e] = 0xff, [0x3f] = 0xff },
10809 		{ {0x40, 0xffffffff } },
10810 	},
10811 	{
10812 		"LD_IND word positive offset, out of bounds",
10813 		.u.insns = {
10814 			BPF_STMT(BPF_LDX | BPF_IMM, 0x3e),
10815 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, 0x1),
10816 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10817 		},
10818 		CLASSIC,
10819 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10820 		{ {0x3f, 0 }, },
10821 	},
10822 	{
10823 		"LD_IND word negative offset, out of bounds",
10824 		.u.insns = {
10825 			BPF_STMT(BPF_LDX | BPF_IMM, 0x3e),
10826 			BPF_STMT(BPF_LD | BPF_IND | BPF_W, -0x3f),
10827 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10828 		},
10829 		CLASSIC,
10830 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10831 		{ {0x3f, 0 } },
10832 	},
10833 	{
10834 		"LD_ABS byte",
10835 		.u.insns = {
10836 			BPF_STMT(BPF_LD | BPF_ABS | BPF_B, 0x20),
10837 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10838 		},
10839 		CLASSIC,
10840 		{
10841 			[0x1c] = 0xaa, [0x1d] = 0x55,
10842 			[0x1e] = 0xbb, [0x1f] = 0x66,
10843 			[0x20] = 0xcc, [0x21] = 0x77,
10844 			[0x22] = 0xdd, [0x23] = 0x88,
10845 			[0x24] = 0xee, [0x25] = 0x99,
10846 			[0x26] = 0xff, [0x27] = 0xaa,
10847 		},
10848 		{ {0x40, 0xcc } },
10849 	},
10850 	{
10851 		"LD_ABS byte positive offset, all ff",
10852 		.u.insns = {
10853 			BPF_STMT(BPF_LD | BPF_ABS | BPF_B, 0x3f),
10854 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10855 		},
10856 		CLASSIC,
10857 		{ [0x3c] = 0xff, [0x3d] = 0xff,  [0x3e] = 0xff, [0x3f] = 0xff },
10858 		{ {0x40, 0xff } },
10859 	},
10860 	{
10861 		"LD_ABS byte positive offset, out of bounds",
10862 		.u.insns = {
10863 			BPF_STMT(BPF_LD | BPF_ABS | BPF_B, 0x3f),
10864 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10865 		},
10866 		CLASSIC,
10867 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10868 		{ {0x3f, 0 }, },
10869 	},
10870 	{
10871 		"LD_ABS byte negative offset, out of bounds load",
10872 		.u.insns = {
10873 			BPF_STMT(BPF_LD | BPF_ABS | BPF_B, -1),
10874 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10875 		},
10876 		CLASSIC | FLAG_EXPECTED_FAIL,
10877 		.expected_errcode = -EINVAL,
10878 	},
10879 	{
10880 		"LD_ABS byte negative offset, in bounds",
10881 		.u.insns = {
10882 			BPF_STMT(BPF_LD | BPF_ABS | BPF_B, SKF_LL_OFF + 0x3f),
10883 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10884 		},
10885 		CLASSIC,
10886 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10887 		{ {0x40, 0x82 }, },
10888 	},
10889 	{
10890 		"LD_ABS byte negative offset, out of bounds",
10891 		.u.insns = {
10892 			BPF_STMT(BPF_LD | BPF_ABS | BPF_B, SKF_LL_OFF + 0x3f),
10893 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10894 		},
10895 		CLASSIC,
10896 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10897 		{ {0x3f, 0 }, },
10898 	},
10899 	{
10900 		"LD_ABS byte negative offset, multiple calls",
10901 		.u.insns = {
10902 			BPF_STMT(BPF_LD | BPF_ABS | BPF_B, SKF_LL_OFF + 0x3c),
10903 			BPF_STMT(BPF_LD | BPF_ABS | BPF_B, SKF_LL_OFF + 0x3d),
10904 			BPF_STMT(BPF_LD | BPF_ABS | BPF_B, SKF_LL_OFF + 0x3e),
10905 			BPF_STMT(BPF_LD | BPF_ABS | BPF_B, SKF_LL_OFF + 0x3f),
10906 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10907 		},
10908 		CLASSIC,
10909 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10910 		{ {0x40, 0x82 }, },
10911 	},
10912 	{
10913 		"LD_ABS halfword",
10914 		.u.insns = {
10915 			BPF_STMT(BPF_LD | BPF_ABS | BPF_H, 0x22),
10916 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10917 		},
10918 		CLASSIC,
10919 		{
10920 			[0x1c] = 0xaa, [0x1d] = 0x55,
10921 			[0x1e] = 0xbb, [0x1f] = 0x66,
10922 			[0x20] = 0xcc, [0x21] = 0x77,
10923 			[0x22] = 0xdd, [0x23] = 0x88,
10924 			[0x24] = 0xee, [0x25] = 0x99,
10925 			[0x26] = 0xff, [0x27] = 0xaa,
10926 		},
10927 		{ {0x40, 0xdd88 } },
10928 	},
10929 	{
10930 		"LD_ABS halfword unaligned",
10931 		.u.insns = {
10932 			BPF_STMT(BPF_LD | BPF_ABS | BPF_H, 0x25),
10933 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10934 		},
10935 		CLASSIC,
10936 		{
10937 			[0x1c] = 0xaa, [0x1d] = 0x55,
10938 			[0x1e] = 0xbb, [0x1f] = 0x66,
10939 			[0x20] = 0xcc, [0x21] = 0x77,
10940 			[0x22] = 0xdd, [0x23] = 0x88,
10941 			[0x24] = 0xee, [0x25] = 0x99,
10942 			[0x26] = 0xff, [0x27] = 0xaa,
10943 		},
10944 		{ {0x40, 0x99ff } },
10945 	},
10946 	{
10947 		"LD_ABS halfword positive offset, all ff",
10948 		.u.insns = {
10949 			BPF_STMT(BPF_LD | BPF_ABS | BPF_H, 0x3e),
10950 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10951 		},
10952 		CLASSIC,
10953 		{ [0x3c] = 0xff, [0x3d] = 0xff,  [0x3e] = 0xff, [0x3f] = 0xff },
10954 		{ {0x40, 0xffff } },
10955 	},
10956 	{
10957 		"LD_ABS halfword positive offset, out of bounds",
10958 		.u.insns = {
10959 			BPF_STMT(BPF_LD | BPF_ABS | BPF_H, 0x3f),
10960 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10961 		},
10962 		CLASSIC,
10963 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10964 		{ {0x3f, 0 }, },
10965 	},
10966 	{
10967 		"LD_ABS halfword negative offset, out of bounds load",
10968 		.u.insns = {
10969 			BPF_STMT(BPF_LD | BPF_ABS | BPF_H, -1),
10970 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10971 		},
10972 		CLASSIC | FLAG_EXPECTED_FAIL,
10973 		.expected_errcode = -EINVAL,
10974 	},
10975 	{
10976 		"LD_ABS halfword negative offset, in bounds",
10977 		.u.insns = {
10978 			BPF_STMT(BPF_LD | BPF_ABS | BPF_H, SKF_LL_OFF + 0x3e),
10979 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10980 		},
10981 		CLASSIC,
10982 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10983 		{ {0x40, 0x1982 }, },
10984 	},
10985 	{
10986 		"LD_ABS halfword negative offset, out of bounds",
10987 		.u.insns = {
10988 			BPF_STMT(BPF_LD | BPF_ABS | BPF_H, SKF_LL_OFF + 0x3e),
10989 			BPF_STMT(BPF_RET | BPF_A, 0x0),
10990 		},
10991 		CLASSIC,
10992 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
10993 		{ {0x3f, 0 }, },
10994 	},
10995 	{
10996 		"LD_ABS word",
10997 		.u.insns = {
10998 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, 0x1c),
10999 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11000 		},
11001 		CLASSIC,
11002 		{
11003 			[0x1c] = 0xaa, [0x1d] = 0x55,
11004 			[0x1e] = 0xbb, [0x1f] = 0x66,
11005 			[0x20] = 0xcc, [0x21] = 0x77,
11006 			[0x22] = 0xdd, [0x23] = 0x88,
11007 			[0x24] = 0xee, [0x25] = 0x99,
11008 			[0x26] = 0xff, [0x27] = 0xaa,
11009 		},
11010 		{ {0x40, 0xaa55bb66 } },
11011 	},
11012 	{
11013 		"LD_ABS word unaligned (addr & 3 == 2)",
11014 		.u.insns = {
11015 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, 0x22),
11016 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11017 		},
11018 		CLASSIC,
11019 		{
11020 			[0x1c] = 0xaa, [0x1d] = 0x55,
11021 			[0x1e] = 0xbb, [0x1f] = 0x66,
11022 			[0x20] = 0xcc, [0x21] = 0x77,
11023 			[0x22] = 0xdd, [0x23] = 0x88,
11024 			[0x24] = 0xee, [0x25] = 0x99,
11025 			[0x26] = 0xff, [0x27] = 0xaa,
11026 		},
11027 		{ {0x40, 0xdd88ee99 } },
11028 	},
11029 	{
11030 		"LD_ABS word unaligned (addr & 3 == 1)",
11031 		.u.insns = {
11032 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, 0x21),
11033 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11034 		},
11035 		CLASSIC,
11036 		{
11037 			[0x1c] = 0xaa, [0x1d] = 0x55,
11038 			[0x1e] = 0xbb, [0x1f] = 0x66,
11039 			[0x20] = 0xcc, [0x21] = 0x77,
11040 			[0x22] = 0xdd, [0x23] = 0x88,
11041 			[0x24] = 0xee, [0x25] = 0x99,
11042 			[0x26] = 0xff, [0x27] = 0xaa,
11043 		},
11044 		{ {0x40, 0x77dd88ee } },
11045 	},
11046 	{
11047 		"LD_ABS word unaligned (addr & 3 == 3)",
11048 		.u.insns = {
11049 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, 0x23),
11050 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11051 		},
11052 		CLASSIC,
11053 		{
11054 			[0x1c] = 0xaa, [0x1d] = 0x55,
11055 			[0x1e] = 0xbb, [0x1f] = 0x66,
11056 			[0x20] = 0xcc, [0x21] = 0x77,
11057 			[0x22] = 0xdd, [0x23] = 0x88,
11058 			[0x24] = 0xee, [0x25] = 0x99,
11059 			[0x26] = 0xff, [0x27] = 0xaa,
11060 		},
11061 		{ {0x40, 0x88ee99ff } },
11062 	},
11063 	{
11064 		"LD_ABS word positive offset, all ff",
11065 		.u.insns = {
11066 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, 0x3c),
11067 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11068 		},
11069 		CLASSIC,
11070 		{ [0x3c] = 0xff, [0x3d] = 0xff,  [0x3e] = 0xff, [0x3f] = 0xff },
11071 		{ {0x40, 0xffffffff } },
11072 	},
11073 	{
11074 		"LD_ABS word positive offset, out of bounds",
11075 		.u.insns = {
11076 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, 0x3f),
11077 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11078 		},
11079 		CLASSIC,
11080 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
11081 		{ {0x3f, 0 }, },
11082 	},
11083 	{
11084 		"LD_ABS word negative offset, out of bounds load",
11085 		.u.insns = {
11086 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, -1),
11087 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11088 		},
11089 		CLASSIC | FLAG_EXPECTED_FAIL,
11090 		.expected_errcode = -EINVAL,
11091 	},
11092 	{
11093 		"LD_ABS word negative offset, in bounds",
11094 		.u.insns = {
11095 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, SKF_LL_OFF + 0x3c),
11096 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11097 		},
11098 		CLASSIC,
11099 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
11100 		{ {0x40, 0x25051982 }, },
11101 	},
11102 	{
11103 		"LD_ABS word negative offset, out of bounds",
11104 		.u.insns = {
11105 			BPF_STMT(BPF_LD | BPF_ABS | BPF_W, SKF_LL_OFF + 0x3c),
11106 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11107 		},
11108 		CLASSIC,
11109 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
11110 		{ {0x3f, 0 }, },
11111 	},
11112 	{
11113 		"LDX_MSH standalone, preserved A",
11114 		.u.insns = {
11115 			BPF_STMT(BPF_LD | BPF_IMM, 0xffeebbaa),
11116 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 0x3c),
11117 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11118 		},
11119 		CLASSIC,
11120 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
11121 		{ {0x40, 0xffeebbaa }, },
11122 	},
11123 	{
11124 		"LDX_MSH standalone, preserved A 2",
11125 		.u.insns = {
11126 			BPF_STMT(BPF_LD | BPF_IMM, 0x175e9d63),
11127 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 0x3c),
11128 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 0x3d),
11129 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 0x3e),
11130 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 0x3f),
11131 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11132 		},
11133 		CLASSIC,
11134 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
11135 		{ {0x40, 0x175e9d63 }, },
11136 	},
11137 	{
11138 		"LDX_MSH standalone, test result 1",
11139 		.u.insns = {
11140 			BPF_STMT(BPF_LD | BPF_IMM, 0xffeebbaa),
11141 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 0x3c),
11142 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
11143 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11144 		},
11145 		CLASSIC,
11146 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
11147 		{ {0x40, 0x14 }, },
11148 	},
11149 	{
11150 		"LDX_MSH standalone, test result 2",
11151 		.u.insns = {
11152 			BPF_STMT(BPF_LD | BPF_IMM, 0xffeebbaa),
11153 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 0x3e),
11154 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
11155 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11156 		},
11157 		CLASSIC,
11158 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
11159 		{ {0x40, 0x24 }, },
11160 	},
11161 	{
11162 		"LDX_MSH standalone, negative offset",
11163 		.u.insns = {
11164 			BPF_STMT(BPF_LD | BPF_IMM, 0xffeebbaa),
11165 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, -1),
11166 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
11167 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11168 		},
11169 		CLASSIC,
11170 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
11171 		{ {0x40, 0 }, },
11172 	},
11173 	{
11174 		"LDX_MSH standalone, negative offset 2",
11175 		.u.insns = {
11176 			BPF_STMT(BPF_LD | BPF_IMM, 0xffeebbaa),
11177 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, SKF_LL_OFF + 0x3e),
11178 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
11179 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11180 		},
11181 		CLASSIC,
11182 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
11183 		{ {0x40, 0x24 }, },
11184 	},
11185 	{
11186 		"LDX_MSH standalone, out of bounds",
11187 		.u.insns = {
11188 			BPF_STMT(BPF_LD | BPF_IMM, 0xffeebbaa),
11189 			BPF_STMT(BPF_LDX | BPF_B | BPF_MSH, 0x40),
11190 			BPF_STMT(BPF_MISC | BPF_TXA, 0),
11191 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11192 		},
11193 		CLASSIC,
11194 		{ [0x3c] = 0x25, [0x3d] = 0x05,  [0x3e] = 0x19, [0x3f] = 0x82 },
11195 		{ {0x40, 0 }, },
11196 	},
11197 	/*
11198 	 * verify that the interpreter or JIT correctly sets A and X
11199 	 * to 0.
11200 	 */
11201 	{
11202 		"ADD default X",
11203 		.u.insns = {
11204 			/*
11205 			 * A = 0x42
11206 			 * A = A + X
11207 			 * ret A
11208 			 */
11209 			BPF_STMT(BPF_LD | BPF_IMM, 0x42),
11210 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_X, 0),
11211 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11212 		},
11213 		CLASSIC | FLAG_NO_DATA,
11214 		{},
11215 		{ {0x1, 0x42 } },
11216 	},
11217 	{
11218 		"ADD default A",
11219 		.u.insns = {
11220 			/*
11221 			 * A = A + 0x42
11222 			 * ret A
11223 			 */
11224 			BPF_STMT(BPF_ALU | BPF_ADD | BPF_K, 0x42),
11225 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11226 		},
11227 		CLASSIC | FLAG_NO_DATA,
11228 		{},
11229 		{ {0x1, 0x42 } },
11230 	},
11231 	{
11232 		"SUB default X",
11233 		.u.insns = {
11234 			/*
11235 			 * A = 0x66
11236 			 * A = A - X
11237 			 * ret A
11238 			 */
11239 			BPF_STMT(BPF_LD | BPF_IMM, 0x66),
11240 			BPF_STMT(BPF_ALU | BPF_SUB | BPF_X, 0),
11241 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11242 		},
11243 		CLASSIC | FLAG_NO_DATA,
11244 		{},
11245 		{ {0x1, 0x66 } },
11246 	},
11247 	{
11248 		"SUB default A",
11249 		.u.insns = {
11250 			/*
11251 			 * A = A - -0x66
11252 			 * ret A
11253 			 */
11254 			BPF_STMT(BPF_ALU | BPF_SUB | BPF_K, -0x66),
11255 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11256 		},
11257 		CLASSIC | FLAG_NO_DATA,
11258 		{},
11259 		{ {0x1, 0x66 } },
11260 	},
11261 	{
11262 		"MUL default X",
11263 		.u.insns = {
11264 			/*
11265 			 * A = 0x42
11266 			 * A = A * X
11267 			 * ret A
11268 			 */
11269 			BPF_STMT(BPF_LD | BPF_IMM, 0x42),
11270 			BPF_STMT(BPF_ALU | BPF_MUL | BPF_X, 0),
11271 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11272 		},
11273 		CLASSIC | FLAG_NO_DATA,
11274 		{},
11275 		{ {0x1, 0x0 } },
11276 	},
11277 	{
11278 		"MUL default A",
11279 		.u.insns = {
11280 			/*
11281 			 * A = A * 0x66
11282 			 * ret A
11283 			 */
11284 			BPF_STMT(BPF_ALU | BPF_MUL | BPF_K, 0x66),
11285 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11286 		},
11287 		CLASSIC | FLAG_NO_DATA,
11288 		{},
11289 		{ {0x1, 0x0 } },
11290 	},
11291 	{
11292 		"DIV default X",
11293 		.u.insns = {
11294 			/*
11295 			 * A = 0x42
11296 			 * A = A / X ; this halt the filter execution if X is 0
11297 			 * ret 0x42
11298 			 */
11299 			BPF_STMT(BPF_LD | BPF_IMM, 0x42),
11300 			BPF_STMT(BPF_ALU | BPF_DIV | BPF_X, 0),
11301 			BPF_STMT(BPF_RET | BPF_K, 0x42),
11302 		},
11303 		CLASSIC | FLAG_NO_DATA,
11304 		{},
11305 		{ {0x1, 0x0 } },
11306 	},
11307 	{
11308 		"DIV default A",
11309 		.u.insns = {
11310 			/*
11311 			 * A = A / 1
11312 			 * ret A
11313 			 */
11314 			BPF_STMT(BPF_ALU | BPF_DIV | BPF_K, 0x1),
11315 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11316 		},
11317 		CLASSIC | FLAG_NO_DATA,
11318 		{},
11319 		{ {0x1, 0x0 } },
11320 	},
11321 	{
11322 		"MOD default X",
11323 		.u.insns = {
11324 			/*
11325 			 * A = 0x42
11326 			 * A = A mod X ; this halt the filter execution if X is 0
11327 			 * ret 0x42
11328 			 */
11329 			BPF_STMT(BPF_LD | BPF_IMM, 0x42),
11330 			BPF_STMT(BPF_ALU | BPF_MOD | BPF_X, 0),
11331 			BPF_STMT(BPF_RET | BPF_K, 0x42),
11332 		},
11333 		CLASSIC | FLAG_NO_DATA,
11334 		{},
11335 		{ {0x1, 0x0 } },
11336 	},
11337 	{
11338 		"MOD default A",
11339 		.u.insns = {
11340 			/*
11341 			 * A = A mod 1
11342 			 * ret A
11343 			 */
11344 			BPF_STMT(BPF_ALU | BPF_MOD | BPF_K, 0x1),
11345 			BPF_STMT(BPF_RET | BPF_A, 0x0),
11346 		},
11347 		CLASSIC | FLAG_NO_DATA,
11348 		{},
11349 		{ {0x1, 0x0 } },
11350 	},
11351 	{
11352 		"JMP EQ default A",
11353 		.u.insns = {
11354 			/*
11355 			 * cmp A, 0x0, 0, 1
11356 			 * ret 0x42
11357 			 * ret 0x66
11358 			 */
11359 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0x0, 0, 1),
11360 			BPF_STMT(BPF_RET | BPF_K, 0x42),
11361 			BPF_STMT(BPF_RET | BPF_K, 0x66),
11362 		},
11363 		CLASSIC | FLAG_NO_DATA,
11364 		{},
11365 		{ {0x1, 0x42 } },
11366 	},
11367 	{
11368 		"JMP EQ default X",
11369 		.u.insns = {
11370 			/*
11371 			 * A = 0x0
11372 			 * cmp A, X, 0, 1
11373 			 * ret 0x42
11374 			 * ret 0x66
11375 			 */
11376 			BPF_STMT(BPF_LD | BPF_IMM, 0x0),
11377 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_X, 0x0, 0, 1),
11378 			BPF_STMT(BPF_RET | BPF_K, 0x42),
11379 			BPF_STMT(BPF_RET | BPF_K, 0x66),
11380 		},
11381 		CLASSIC | FLAG_NO_DATA,
11382 		{},
11383 		{ {0x1, 0x42 } },
11384 	},
11385 	/* Checking interpreter vs JIT wrt signed extended imms. */
11386 	{
11387 		"JNE signed compare, test 1",
11388 		.u.insns_int = {
11389 			BPF_ALU32_IMM(BPF_MOV, R1, 0xfefbbc12),
11390 			BPF_ALU32_IMM(BPF_MOV, R3, 0xffff0000),
11391 			BPF_MOV64_REG(R2, R1),
11392 			BPF_ALU64_REG(BPF_AND, R2, R3),
11393 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
11394 			BPF_JMP_IMM(BPF_JNE, R2, -17104896, 1),
11395 			BPF_ALU32_IMM(BPF_MOV, R0, 2),
11396 			BPF_EXIT_INSN(),
11397 		},
11398 		INTERNAL,
11399 		{ },
11400 		{ { 0, 1 } },
11401 	},
11402 	{
11403 		"JNE signed compare, test 2",
11404 		.u.insns_int = {
11405 			BPF_ALU32_IMM(BPF_MOV, R1, 0xfefbbc12),
11406 			BPF_ALU32_IMM(BPF_MOV, R3, 0xffff0000),
11407 			BPF_MOV64_REG(R2, R1),
11408 			BPF_ALU64_REG(BPF_AND, R2, R3),
11409 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
11410 			BPF_JMP_IMM(BPF_JNE, R2, 0xfefb0000, 1),
11411 			BPF_ALU32_IMM(BPF_MOV, R0, 2),
11412 			BPF_EXIT_INSN(),
11413 		},
11414 		INTERNAL,
11415 		{ },
11416 		{ { 0, 1 } },
11417 	},
11418 	{
11419 		"JNE signed compare, test 3",
11420 		.u.insns_int = {
11421 			BPF_ALU32_IMM(BPF_MOV, R1, 0xfefbbc12),
11422 			BPF_ALU32_IMM(BPF_MOV, R3, 0xffff0000),
11423 			BPF_ALU32_IMM(BPF_MOV, R4, 0xfefb0000),
11424 			BPF_MOV64_REG(R2, R1),
11425 			BPF_ALU64_REG(BPF_AND, R2, R3),
11426 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
11427 			BPF_JMP_REG(BPF_JNE, R2, R4, 1),
11428 			BPF_ALU32_IMM(BPF_MOV, R0, 2),
11429 			BPF_EXIT_INSN(),
11430 		},
11431 		INTERNAL,
11432 		{ },
11433 		{ { 0, 2 } },
11434 	},
11435 	{
11436 		"JNE signed compare, test 4",
11437 		.u.insns_int = {
11438 			BPF_LD_IMM64(R1, -17104896),
11439 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
11440 			BPF_JMP_IMM(BPF_JNE, R1, -17104896, 1),
11441 			BPF_ALU32_IMM(BPF_MOV, R0, 2),
11442 			BPF_EXIT_INSN(),
11443 		},
11444 		INTERNAL,
11445 		{ },
11446 		{ { 0, 2 } },
11447 	},
11448 	{
11449 		"JNE signed compare, test 5",
11450 		.u.insns_int = {
11451 			BPF_LD_IMM64(R1, 0xfefb0000),
11452 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
11453 			BPF_JMP_IMM(BPF_JNE, R1, 0xfefb0000, 1),
11454 			BPF_ALU32_IMM(BPF_MOV, R0, 2),
11455 			BPF_EXIT_INSN(),
11456 		},
11457 		INTERNAL,
11458 		{ },
11459 		{ { 0, 1 } },
11460 	},
11461 	{
11462 		"JNE signed compare, test 6",
11463 		.u.insns_int = {
11464 			BPF_LD_IMM64(R1, 0x7efb0000),
11465 			BPF_ALU32_IMM(BPF_MOV, R0, 1),
11466 			BPF_JMP_IMM(BPF_JNE, R1, 0x7efb0000, 1),
11467 			BPF_ALU32_IMM(BPF_MOV, R0, 2),
11468 			BPF_EXIT_INSN(),
11469 		},
11470 		INTERNAL,
11471 		{ },
11472 		{ { 0, 2 } },
11473 	},
11474 	{
11475 		"JNE signed compare, test 7",
11476 		.u.insns = {
11477 			BPF_STMT(BPF_LD | BPF_IMM, 0xffff0000),
11478 			BPF_STMT(BPF_MISC | BPF_TAX, 0),
11479 			BPF_STMT(BPF_LD | BPF_IMM, 0xfefbbc12),
11480 			BPF_STMT(BPF_ALU | BPF_AND | BPF_X, 0),
11481 			BPF_JUMP(BPF_JMP | BPF_JEQ | BPF_K, 0xfefb0000, 1, 0),
11482 			BPF_STMT(BPF_RET | BPF_K, 1),
11483 			BPF_STMT(BPF_RET | BPF_K, 2),
11484 		},
11485 		CLASSIC | FLAG_NO_DATA,
11486 		{},
11487 		{ { 0, 2 } },
11488 	},
11489 	/* BPF_LDX_MEM with operand aliasing */
11490 	{
11491 		"LDX_MEM_B: operand register aliasing",
11492 		.u.insns_int = {
11493 			BPF_ST_MEM(BPF_B, R10, -8, 123),
11494 			BPF_MOV64_REG(R0, R10),
11495 			BPF_LDX_MEM(BPF_B, R0, R0, -8),
11496 			BPF_EXIT_INSN(),
11497 		},
11498 		INTERNAL,
11499 		{ },
11500 		{ { 0, 123 } },
11501 		.stack_depth = 8,
11502 	},
11503 	{
11504 		"LDX_MEM_H: operand register aliasing",
11505 		.u.insns_int = {
11506 			BPF_ST_MEM(BPF_H, R10, -8, 12345),
11507 			BPF_MOV64_REG(R0, R10),
11508 			BPF_LDX_MEM(BPF_H, R0, R0, -8),
11509 			BPF_EXIT_INSN(),
11510 		},
11511 		INTERNAL,
11512 		{ },
11513 		{ { 0, 12345 } },
11514 		.stack_depth = 8,
11515 	},
11516 	{
11517 		"LDX_MEM_W: operand register aliasing",
11518 		.u.insns_int = {
11519 			BPF_ST_MEM(BPF_W, R10, -8, 123456789),
11520 			BPF_MOV64_REG(R0, R10),
11521 			BPF_LDX_MEM(BPF_W, R0, R0, -8),
11522 			BPF_EXIT_INSN(),
11523 		},
11524 		INTERNAL,
11525 		{ },
11526 		{ { 0, 123456789 } },
11527 		.stack_depth = 8,
11528 	},
11529 	{
11530 		"LDX_MEM_DW: operand register aliasing",
11531 		.u.insns_int = {
11532 			BPF_LD_IMM64(R1, 0x123456789abcdefULL),
11533 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
11534 			BPF_MOV64_REG(R0, R10),
11535 			BPF_LDX_MEM(BPF_DW, R0, R0, -8),
11536 			BPF_ALU64_REG(BPF_SUB, R0, R1),
11537 			BPF_MOV64_REG(R1, R0),
11538 			BPF_ALU64_IMM(BPF_RSH, R1, 32),
11539 			BPF_ALU64_REG(BPF_OR, R0, R1),
11540 			BPF_EXIT_INSN(),
11541 		},
11542 		INTERNAL,
11543 		{ },
11544 		{ { 0, 0 } },
11545 		.stack_depth = 8,
11546 	},
11547 	/*
11548 	 * Register (non-)clobbering tests for the case where a JIT implements
11549 	 * complex ALU or ATOMIC operations via function calls. If so, the
11550 	 * function call must be transparent to the eBPF registers. The JIT
11551 	 * must therefore save and restore relevant registers across the call.
11552 	 * The following tests check that the eBPF registers retain their
11553 	 * values after such an operation. Mainly intended for complex ALU
11554 	 * and atomic operation, but we run it for all. You never know...
11555 	 *
11556 	 * Note that each operations should be tested twice with different
11557 	 * destinations, to check preservation for all registers.
11558 	 */
11559 #define BPF_TEST_CLOBBER_ALU(alu, op, dst, src)			\
11560 	{							\
11561 		#alu "_" #op " to " #dst ": no clobbering",	\
11562 		.u.insns_int = {				\
11563 			BPF_ALU64_IMM(BPF_MOV, R0, R0),		\
11564 			BPF_ALU64_IMM(BPF_MOV, R1, R1),		\
11565 			BPF_ALU64_IMM(BPF_MOV, R2, R2),		\
11566 			BPF_ALU64_IMM(BPF_MOV, R3, R3),		\
11567 			BPF_ALU64_IMM(BPF_MOV, R4, R4),		\
11568 			BPF_ALU64_IMM(BPF_MOV, R5, R5),		\
11569 			BPF_ALU64_IMM(BPF_MOV, R6, R6),		\
11570 			BPF_ALU64_IMM(BPF_MOV, R7, R7),		\
11571 			BPF_ALU64_IMM(BPF_MOV, R8, R8),		\
11572 			BPF_ALU64_IMM(BPF_MOV, R9, R9),		\
11573 			BPF_##alu(BPF_ ##op, dst, src),		\
11574 			BPF_ALU32_IMM(BPF_MOV, dst, dst),	\
11575 			BPF_JMP_IMM(BPF_JNE, R0, R0, 10),	\
11576 			BPF_JMP_IMM(BPF_JNE, R1, R1, 9),	\
11577 			BPF_JMP_IMM(BPF_JNE, R2, R2, 8),	\
11578 			BPF_JMP_IMM(BPF_JNE, R3, R3, 7),	\
11579 			BPF_JMP_IMM(BPF_JNE, R4, R4, 6),	\
11580 			BPF_JMP_IMM(BPF_JNE, R5, R5, 5),	\
11581 			BPF_JMP_IMM(BPF_JNE, R6, R6, 4),	\
11582 			BPF_JMP_IMM(BPF_JNE, R7, R7, 3),	\
11583 			BPF_JMP_IMM(BPF_JNE, R8, R8, 2),	\
11584 			BPF_JMP_IMM(BPF_JNE, R9, R9, 1),	\
11585 			BPF_ALU64_IMM(BPF_MOV, R0, 1),		\
11586 			BPF_EXIT_INSN(),			\
11587 		},						\
11588 		INTERNAL,					\
11589 		{ },						\
11590 		{ { 0, 1 } }					\
11591 	}
11592 	/* ALU64 operations, register clobbering */
11593 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, AND, R8, 123456789),
11594 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, AND, R9, 123456789),
11595 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, OR, R8, 123456789),
11596 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, OR, R9, 123456789),
11597 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, XOR, R8, 123456789),
11598 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, XOR, R9, 123456789),
11599 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, LSH, R8, 12),
11600 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, LSH, R9, 12),
11601 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, RSH, R8, 12),
11602 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, RSH, R9, 12),
11603 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, ARSH, R8, 12),
11604 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, ARSH, R9, 12),
11605 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, ADD, R8, 123456789),
11606 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, ADD, R9, 123456789),
11607 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, SUB, R8, 123456789),
11608 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, SUB, R9, 123456789),
11609 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, MUL, R8, 123456789),
11610 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, MUL, R9, 123456789),
11611 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, DIV, R8, 123456789),
11612 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, DIV, R9, 123456789),
11613 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, MOD, R8, 123456789),
11614 	BPF_TEST_CLOBBER_ALU(ALU64_IMM, MOD, R9, 123456789),
11615 	/* ALU32 immediate operations, register clobbering */
11616 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, AND, R8, 123456789),
11617 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, AND, R9, 123456789),
11618 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, OR, R8, 123456789),
11619 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, OR, R9, 123456789),
11620 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, XOR, R8, 123456789),
11621 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, XOR, R9, 123456789),
11622 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, LSH, R8, 12),
11623 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, LSH, R9, 12),
11624 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, RSH, R8, 12),
11625 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, RSH, R9, 12),
11626 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, ARSH, R8, 12),
11627 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, ARSH, R9, 12),
11628 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, ADD, R8, 123456789),
11629 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, ADD, R9, 123456789),
11630 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, SUB, R8, 123456789),
11631 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, SUB, R9, 123456789),
11632 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, MUL, R8, 123456789),
11633 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, MUL, R9, 123456789),
11634 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, DIV, R8, 123456789),
11635 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, DIV, R9, 123456789),
11636 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, MOD, R8, 123456789),
11637 	BPF_TEST_CLOBBER_ALU(ALU32_IMM, MOD, R9, 123456789),
11638 	/* ALU64 register operations, register clobbering */
11639 	BPF_TEST_CLOBBER_ALU(ALU64_REG, AND, R8, R1),
11640 	BPF_TEST_CLOBBER_ALU(ALU64_REG, AND, R9, R1),
11641 	BPF_TEST_CLOBBER_ALU(ALU64_REG, OR, R8, R1),
11642 	BPF_TEST_CLOBBER_ALU(ALU64_REG, OR, R9, R1),
11643 	BPF_TEST_CLOBBER_ALU(ALU64_REG, XOR, R8, R1),
11644 	BPF_TEST_CLOBBER_ALU(ALU64_REG, XOR, R9, R1),
11645 	BPF_TEST_CLOBBER_ALU(ALU64_REG, LSH, R8, R1),
11646 	BPF_TEST_CLOBBER_ALU(ALU64_REG, LSH, R9, R1),
11647 	BPF_TEST_CLOBBER_ALU(ALU64_REG, RSH, R8, R1),
11648 	BPF_TEST_CLOBBER_ALU(ALU64_REG, RSH, R9, R1),
11649 	BPF_TEST_CLOBBER_ALU(ALU64_REG, ARSH, R8, R1),
11650 	BPF_TEST_CLOBBER_ALU(ALU64_REG, ARSH, R9, R1),
11651 	BPF_TEST_CLOBBER_ALU(ALU64_REG, ADD, R8, R1),
11652 	BPF_TEST_CLOBBER_ALU(ALU64_REG, ADD, R9, R1),
11653 	BPF_TEST_CLOBBER_ALU(ALU64_REG, SUB, R8, R1),
11654 	BPF_TEST_CLOBBER_ALU(ALU64_REG, SUB, R9, R1),
11655 	BPF_TEST_CLOBBER_ALU(ALU64_REG, MUL, R8, R1),
11656 	BPF_TEST_CLOBBER_ALU(ALU64_REG, MUL, R9, R1),
11657 	BPF_TEST_CLOBBER_ALU(ALU64_REG, DIV, R8, R1),
11658 	BPF_TEST_CLOBBER_ALU(ALU64_REG, DIV, R9, R1),
11659 	BPF_TEST_CLOBBER_ALU(ALU64_REG, MOD, R8, R1),
11660 	BPF_TEST_CLOBBER_ALU(ALU64_REG, MOD, R9, R1),
11661 	/* ALU32 register operations, register clobbering */
11662 	BPF_TEST_CLOBBER_ALU(ALU32_REG, AND, R8, R1),
11663 	BPF_TEST_CLOBBER_ALU(ALU32_REG, AND, R9, R1),
11664 	BPF_TEST_CLOBBER_ALU(ALU32_REG, OR, R8, R1),
11665 	BPF_TEST_CLOBBER_ALU(ALU32_REG, OR, R9, R1),
11666 	BPF_TEST_CLOBBER_ALU(ALU32_REG, XOR, R8, R1),
11667 	BPF_TEST_CLOBBER_ALU(ALU32_REG, XOR, R9, R1),
11668 	BPF_TEST_CLOBBER_ALU(ALU32_REG, LSH, R8, R1),
11669 	BPF_TEST_CLOBBER_ALU(ALU32_REG, LSH, R9, R1),
11670 	BPF_TEST_CLOBBER_ALU(ALU32_REG, RSH, R8, R1),
11671 	BPF_TEST_CLOBBER_ALU(ALU32_REG, RSH, R9, R1),
11672 	BPF_TEST_CLOBBER_ALU(ALU32_REG, ARSH, R8, R1),
11673 	BPF_TEST_CLOBBER_ALU(ALU32_REG, ARSH, R9, R1),
11674 	BPF_TEST_CLOBBER_ALU(ALU32_REG, ADD, R8, R1),
11675 	BPF_TEST_CLOBBER_ALU(ALU32_REG, ADD, R9, R1),
11676 	BPF_TEST_CLOBBER_ALU(ALU32_REG, SUB, R8, R1),
11677 	BPF_TEST_CLOBBER_ALU(ALU32_REG, SUB, R9, R1),
11678 	BPF_TEST_CLOBBER_ALU(ALU32_REG, MUL, R8, R1),
11679 	BPF_TEST_CLOBBER_ALU(ALU32_REG, MUL, R9, R1),
11680 	BPF_TEST_CLOBBER_ALU(ALU32_REG, DIV, R8, R1),
11681 	BPF_TEST_CLOBBER_ALU(ALU32_REG, DIV, R9, R1),
11682 	BPF_TEST_CLOBBER_ALU(ALU32_REG, MOD, R8, R1),
11683 	BPF_TEST_CLOBBER_ALU(ALU32_REG, MOD, R9, R1),
11684 #undef BPF_TEST_CLOBBER_ALU
11685 #define BPF_TEST_CLOBBER_ATOMIC(width, op)			\
11686 	{							\
11687 		"Atomic_" #width " " #op ": no clobbering",	\
11688 		.u.insns_int = {				\
11689 			BPF_ALU64_IMM(BPF_MOV, R0, 0),		\
11690 			BPF_ALU64_IMM(BPF_MOV, R1, 1),		\
11691 			BPF_ALU64_IMM(BPF_MOV, R2, 2),		\
11692 			BPF_ALU64_IMM(BPF_MOV, R3, 3),		\
11693 			BPF_ALU64_IMM(BPF_MOV, R4, 4),		\
11694 			BPF_ALU64_IMM(BPF_MOV, R5, 5),		\
11695 			BPF_ALU64_IMM(BPF_MOV, R6, 6),		\
11696 			BPF_ALU64_IMM(BPF_MOV, R7, 7),		\
11697 			BPF_ALU64_IMM(BPF_MOV, R8, 8),		\
11698 			BPF_ALU64_IMM(BPF_MOV, R9, 9),		\
11699 			BPF_ST_MEM(width, R10, -8,		\
11700 				   (op) == BPF_CMPXCHG ? 0 :	\
11701 				   (op) & BPF_FETCH ? 1 : 0),	\
11702 			BPF_ATOMIC_OP(width, op, R10, R1, -8),	\
11703 			BPF_JMP_IMM(BPF_JNE, R0, 0, 10),	\
11704 			BPF_JMP_IMM(BPF_JNE, R1, 1, 9),		\
11705 			BPF_JMP_IMM(BPF_JNE, R2, 2, 8),		\
11706 			BPF_JMP_IMM(BPF_JNE, R3, 3, 7),		\
11707 			BPF_JMP_IMM(BPF_JNE, R4, 4, 6),		\
11708 			BPF_JMP_IMM(BPF_JNE, R5, 5, 5),		\
11709 			BPF_JMP_IMM(BPF_JNE, R6, 6, 4),		\
11710 			BPF_JMP_IMM(BPF_JNE, R7, 7, 3),		\
11711 			BPF_JMP_IMM(BPF_JNE, R8, 8, 2),		\
11712 			BPF_JMP_IMM(BPF_JNE, R9, 9, 1),		\
11713 			BPF_ALU64_IMM(BPF_MOV, R0, 1),		\
11714 			BPF_EXIT_INSN(),			\
11715 		},						\
11716 		INTERNAL,					\
11717 		{ },						\
11718 		{ { 0, 1 } },					\
11719 		.stack_depth = 8,				\
11720 	}
11721 	/* 64-bit atomic operations, register clobbering */
11722 	BPF_TEST_CLOBBER_ATOMIC(BPF_DW, BPF_ADD),
11723 	BPF_TEST_CLOBBER_ATOMIC(BPF_DW, BPF_AND),
11724 	BPF_TEST_CLOBBER_ATOMIC(BPF_DW, BPF_OR),
11725 	BPF_TEST_CLOBBER_ATOMIC(BPF_DW, BPF_XOR),
11726 	BPF_TEST_CLOBBER_ATOMIC(BPF_DW, BPF_ADD | BPF_FETCH),
11727 	BPF_TEST_CLOBBER_ATOMIC(BPF_DW, BPF_AND | BPF_FETCH),
11728 	BPF_TEST_CLOBBER_ATOMIC(BPF_DW, BPF_OR | BPF_FETCH),
11729 	BPF_TEST_CLOBBER_ATOMIC(BPF_DW, BPF_XOR | BPF_FETCH),
11730 	BPF_TEST_CLOBBER_ATOMIC(BPF_DW, BPF_XCHG),
11731 	BPF_TEST_CLOBBER_ATOMIC(BPF_DW, BPF_CMPXCHG),
11732 	/* 32-bit atomic operations, register clobbering */
11733 	BPF_TEST_CLOBBER_ATOMIC(BPF_W, BPF_ADD),
11734 	BPF_TEST_CLOBBER_ATOMIC(BPF_W, BPF_AND),
11735 	BPF_TEST_CLOBBER_ATOMIC(BPF_W, BPF_OR),
11736 	BPF_TEST_CLOBBER_ATOMIC(BPF_W, BPF_XOR),
11737 	BPF_TEST_CLOBBER_ATOMIC(BPF_W, BPF_ADD | BPF_FETCH),
11738 	BPF_TEST_CLOBBER_ATOMIC(BPF_W, BPF_AND | BPF_FETCH),
11739 	BPF_TEST_CLOBBER_ATOMIC(BPF_W, BPF_OR | BPF_FETCH),
11740 	BPF_TEST_CLOBBER_ATOMIC(BPF_W, BPF_XOR | BPF_FETCH),
11741 	BPF_TEST_CLOBBER_ATOMIC(BPF_W, BPF_XCHG),
11742 	BPF_TEST_CLOBBER_ATOMIC(BPF_W, BPF_CMPXCHG),
11743 #undef BPF_TEST_CLOBBER_ATOMIC
11744 	/* Checking that ALU32 src is not zero extended in place */
11745 #define BPF_ALU32_SRC_ZEXT(op)					\
11746 	{							\
11747 		"ALU32_" #op "_X: src preserved in zext",	\
11748 		.u.insns_int = {				\
11749 			BPF_LD_IMM64(R1, 0x0123456789acbdefULL),\
11750 			BPF_LD_IMM64(R2, 0xfedcba9876543210ULL),\
11751 			BPF_ALU64_REG(BPF_MOV, R0, R1),		\
11752 			BPF_ALU32_REG(BPF_##op, R2, R1),	\
11753 			BPF_ALU64_REG(BPF_SUB, R0, R1),		\
11754 			BPF_ALU64_REG(BPF_MOV, R1, R0),		\
11755 			BPF_ALU64_IMM(BPF_RSH, R1, 32),		\
11756 			BPF_ALU64_REG(BPF_OR, R0, R1),		\
11757 			BPF_EXIT_INSN(),			\
11758 		},						\
11759 		INTERNAL,					\
11760 		{ },						\
11761 		{ { 0, 0 } },					\
11762 	}
11763 	BPF_ALU32_SRC_ZEXT(MOV),
11764 	BPF_ALU32_SRC_ZEXT(AND),
11765 	BPF_ALU32_SRC_ZEXT(OR),
11766 	BPF_ALU32_SRC_ZEXT(XOR),
11767 	BPF_ALU32_SRC_ZEXT(ADD),
11768 	BPF_ALU32_SRC_ZEXT(SUB),
11769 	BPF_ALU32_SRC_ZEXT(MUL),
11770 	BPF_ALU32_SRC_ZEXT(DIV),
11771 	BPF_ALU32_SRC_ZEXT(MOD),
11772 #undef BPF_ALU32_SRC_ZEXT
11773 	/* Checking that ATOMIC32 src is not zero extended in place */
11774 #define BPF_ATOMIC32_SRC_ZEXT(op)					\
11775 	{								\
11776 		"ATOMIC_W_" #op ": src preserved in zext",		\
11777 		.u.insns_int = {					\
11778 			BPF_LD_IMM64(R0, 0x0123456789acbdefULL),	\
11779 			BPF_ALU64_REG(BPF_MOV, R1, R0),			\
11780 			BPF_ST_MEM(BPF_W, R10, -4, 0),			\
11781 			BPF_ATOMIC_OP(BPF_W, BPF_##op, R10, R1, -4),	\
11782 			BPF_ALU64_REG(BPF_SUB, R0, R1),			\
11783 			BPF_ALU64_REG(BPF_MOV, R1, R0),			\
11784 			BPF_ALU64_IMM(BPF_RSH, R1, 32),			\
11785 			BPF_ALU64_REG(BPF_OR, R0, R1),			\
11786 			BPF_EXIT_INSN(),				\
11787 		},							\
11788 		INTERNAL,						\
11789 		{ },							\
11790 		{ { 0, 0 } },						\
11791 		.stack_depth = 8,					\
11792 	}
11793 	BPF_ATOMIC32_SRC_ZEXT(ADD),
11794 	BPF_ATOMIC32_SRC_ZEXT(AND),
11795 	BPF_ATOMIC32_SRC_ZEXT(OR),
11796 	BPF_ATOMIC32_SRC_ZEXT(XOR),
11797 #undef BPF_ATOMIC32_SRC_ZEXT
11798 	/* Checking that CMPXCHG32 src is not zero extended in place */
11799 	{
11800 		"ATOMIC_W_CMPXCHG: src preserved in zext",
11801 		.u.insns_int = {
11802 			BPF_LD_IMM64(R1, 0x0123456789acbdefULL),
11803 			BPF_ALU64_REG(BPF_MOV, R2, R1),
11804 			BPF_ALU64_REG(BPF_MOV, R0, 0),
11805 			BPF_ST_MEM(BPF_W, R10, -4, 0),
11806 			BPF_ATOMIC_OP(BPF_W, BPF_CMPXCHG, R10, R1, -4),
11807 			BPF_ALU64_REG(BPF_SUB, R1, R2),
11808 			BPF_ALU64_REG(BPF_MOV, R2, R1),
11809 			BPF_ALU64_IMM(BPF_RSH, R2, 32),
11810 			BPF_ALU64_REG(BPF_OR, R1, R2),
11811 			BPF_ALU64_REG(BPF_MOV, R0, R1),
11812 			BPF_EXIT_INSN(),
11813 		},
11814 		INTERNAL,
11815 		{ },
11816 		{ { 0, 0 } },
11817 		.stack_depth = 8,
11818 	},
11819 	/* Checking that JMP32 immediate src is not zero extended in place */
11820 #define BPF_JMP32_IMM_ZEXT(op)					\
11821 	{							\
11822 		"JMP32_" #op "_K: operand preserved in zext",	\
11823 		.u.insns_int = {				\
11824 			BPF_LD_IMM64(R0, 0x0123456789acbdefULL),\
11825 			BPF_ALU64_REG(BPF_MOV, R1, R0),		\
11826 			BPF_JMP32_IMM(BPF_##op, R0, 1234, 1),	\
11827 			BPF_JMP_A(0), /* Nop */			\
11828 			BPF_ALU64_REG(BPF_SUB, R0, R1),		\
11829 			BPF_ALU64_REG(BPF_MOV, R1, R0),		\
11830 			BPF_ALU64_IMM(BPF_RSH, R1, 32),		\
11831 			BPF_ALU64_REG(BPF_OR, R0, R1),		\
11832 			BPF_EXIT_INSN(),			\
11833 		},						\
11834 		INTERNAL,					\
11835 		{ },						\
11836 		{ { 0, 0 } },					\
11837 	}
11838 	BPF_JMP32_IMM_ZEXT(JEQ),
11839 	BPF_JMP32_IMM_ZEXT(JNE),
11840 	BPF_JMP32_IMM_ZEXT(JSET),
11841 	BPF_JMP32_IMM_ZEXT(JGT),
11842 	BPF_JMP32_IMM_ZEXT(JGE),
11843 	BPF_JMP32_IMM_ZEXT(JLT),
11844 	BPF_JMP32_IMM_ZEXT(JLE),
11845 	BPF_JMP32_IMM_ZEXT(JSGT),
11846 	BPF_JMP32_IMM_ZEXT(JSGE),
11847 	BPF_JMP32_IMM_ZEXT(JSGT),
11848 	BPF_JMP32_IMM_ZEXT(JSLT),
11849 	BPF_JMP32_IMM_ZEXT(JSLE),
11850 #undef BPF_JMP2_IMM_ZEXT
11851 	/* Checking that JMP32 dst & src are not zero extended in place */
11852 #define BPF_JMP32_REG_ZEXT(op)					\
11853 	{							\
11854 		"JMP32_" #op "_X: operands preserved in zext",	\
11855 		.u.insns_int = {				\
11856 			BPF_LD_IMM64(R0, 0x0123456789acbdefULL),\
11857 			BPF_LD_IMM64(R1, 0xfedcba9876543210ULL),\
11858 			BPF_ALU64_REG(BPF_MOV, R2, R0),		\
11859 			BPF_ALU64_REG(BPF_MOV, R3, R1),		\
11860 			BPF_JMP32_IMM(BPF_##op, R0, R1, 1),	\
11861 			BPF_JMP_A(0), /* Nop */			\
11862 			BPF_ALU64_REG(BPF_SUB, R0, R2),		\
11863 			BPF_ALU64_REG(BPF_SUB, R1, R3),		\
11864 			BPF_ALU64_REG(BPF_OR, R0, R1),		\
11865 			BPF_ALU64_REG(BPF_MOV, R1, R0),		\
11866 			BPF_ALU64_IMM(BPF_RSH, R1, 32),		\
11867 			BPF_ALU64_REG(BPF_OR, R0, R1),		\
11868 			BPF_EXIT_INSN(),			\
11869 		},						\
11870 		INTERNAL,					\
11871 		{ },						\
11872 		{ { 0, 0 } },					\
11873 	}
11874 	BPF_JMP32_REG_ZEXT(JEQ),
11875 	BPF_JMP32_REG_ZEXT(JNE),
11876 	BPF_JMP32_REG_ZEXT(JSET),
11877 	BPF_JMP32_REG_ZEXT(JGT),
11878 	BPF_JMP32_REG_ZEXT(JGE),
11879 	BPF_JMP32_REG_ZEXT(JLT),
11880 	BPF_JMP32_REG_ZEXT(JLE),
11881 	BPF_JMP32_REG_ZEXT(JSGT),
11882 	BPF_JMP32_REG_ZEXT(JSGE),
11883 	BPF_JMP32_REG_ZEXT(JSGT),
11884 	BPF_JMP32_REG_ZEXT(JSLT),
11885 	BPF_JMP32_REG_ZEXT(JSLE),
11886 #undef BPF_JMP2_REG_ZEXT
11887 	/* ALU64 K register combinations */
11888 	{
11889 		"ALU64_MOV_K: registers",
11890 		{ },
11891 		INTERNAL,
11892 		{ },
11893 		{ { 0, 1 } },
11894 		.fill_helper = bpf_fill_alu64_mov_imm_regs,
11895 	},
11896 	{
11897 		"ALU64_AND_K: registers",
11898 		{ },
11899 		INTERNAL,
11900 		{ },
11901 		{ { 0, 1 } },
11902 		.fill_helper = bpf_fill_alu64_and_imm_regs,
11903 	},
11904 	{
11905 		"ALU64_OR_K: registers",
11906 		{ },
11907 		INTERNAL,
11908 		{ },
11909 		{ { 0, 1 } },
11910 		.fill_helper = bpf_fill_alu64_or_imm_regs,
11911 	},
11912 	{
11913 		"ALU64_XOR_K: registers",
11914 		{ },
11915 		INTERNAL,
11916 		{ },
11917 		{ { 0, 1 } },
11918 		.fill_helper = bpf_fill_alu64_xor_imm_regs,
11919 	},
11920 	{
11921 		"ALU64_LSH_K: registers",
11922 		{ },
11923 		INTERNAL,
11924 		{ },
11925 		{ { 0, 1 } },
11926 		.fill_helper = bpf_fill_alu64_lsh_imm_regs,
11927 	},
11928 	{
11929 		"ALU64_RSH_K: registers",
11930 		{ },
11931 		INTERNAL,
11932 		{ },
11933 		{ { 0, 1 } },
11934 		.fill_helper = bpf_fill_alu64_rsh_imm_regs,
11935 	},
11936 	{
11937 		"ALU64_ARSH_K: registers",
11938 		{ },
11939 		INTERNAL,
11940 		{ },
11941 		{ { 0, 1 } },
11942 		.fill_helper = bpf_fill_alu64_arsh_imm_regs,
11943 	},
11944 	{
11945 		"ALU64_ADD_K: registers",
11946 		{ },
11947 		INTERNAL,
11948 		{ },
11949 		{ { 0, 1 } },
11950 		.fill_helper = bpf_fill_alu64_add_imm_regs,
11951 	},
11952 	{
11953 		"ALU64_SUB_K: registers",
11954 		{ },
11955 		INTERNAL,
11956 		{ },
11957 		{ { 0, 1 } },
11958 		.fill_helper = bpf_fill_alu64_sub_imm_regs,
11959 	},
11960 	{
11961 		"ALU64_MUL_K: registers",
11962 		{ },
11963 		INTERNAL,
11964 		{ },
11965 		{ { 0, 1 } },
11966 		.fill_helper = bpf_fill_alu64_mul_imm_regs,
11967 	},
11968 	{
11969 		"ALU64_DIV_K: registers",
11970 		{ },
11971 		INTERNAL,
11972 		{ },
11973 		{ { 0, 1 } },
11974 		.fill_helper = bpf_fill_alu64_div_imm_regs,
11975 	},
11976 	{
11977 		"ALU64_MOD_K: registers",
11978 		{ },
11979 		INTERNAL,
11980 		{ },
11981 		{ { 0, 1 } },
11982 		.fill_helper = bpf_fill_alu64_mod_imm_regs,
11983 	},
11984 	/* ALU32 K registers */
11985 	{
11986 		"ALU32_MOV_K: registers",
11987 		{ },
11988 		INTERNAL,
11989 		{ },
11990 		{ { 0, 1 } },
11991 		.fill_helper = bpf_fill_alu32_mov_imm_regs,
11992 	},
11993 	{
11994 		"ALU32_AND_K: registers",
11995 		{ },
11996 		INTERNAL,
11997 		{ },
11998 		{ { 0, 1 } },
11999 		.fill_helper = bpf_fill_alu32_and_imm_regs,
12000 	},
12001 	{
12002 		"ALU32_OR_K: registers",
12003 		{ },
12004 		INTERNAL,
12005 		{ },
12006 		{ { 0, 1 } },
12007 		.fill_helper = bpf_fill_alu32_or_imm_regs,
12008 	},
12009 	{
12010 		"ALU32_XOR_K: registers",
12011 		{ },
12012 		INTERNAL,
12013 		{ },
12014 		{ { 0, 1 } },
12015 		.fill_helper = bpf_fill_alu32_xor_imm_regs,
12016 	},
12017 	{
12018 		"ALU32_LSH_K: registers",
12019 		{ },
12020 		INTERNAL,
12021 		{ },
12022 		{ { 0, 1 } },
12023 		.fill_helper = bpf_fill_alu32_lsh_imm_regs,
12024 	},
12025 	{
12026 		"ALU32_RSH_K: registers",
12027 		{ },
12028 		INTERNAL,
12029 		{ },
12030 		{ { 0, 1 } },
12031 		.fill_helper = bpf_fill_alu32_rsh_imm_regs,
12032 	},
12033 	{
12034 		"ALU32_ARSH_K: registers",
12035 		{ },
12036 		INTERNAL,
12037 		{ },
12038 		{ { 0, 1 } },
12039 		.fill_helper = bpf_fill_alu32_arsh_imm_regs,
12040 	},
12041 	{
12042 		"ALU32_ADD_K: registers",
12043 		{ },
12044 		INTERNAL,
12045 		{ },
12046 		{ { 0, 1 } },
12047 		.fill_helper = bpf_fill_alu32_add_imm_regs,
12048 	},
12049 	{
12050 		"ALU32_SUB_K: registers",
12051 		{ },
12052 		INTERNAL,
12053 		{ },
12054 		{ { 0, 1 } },
12055 		.fill_helper = bpf_fill_alu32_sub_imm_regs,
12056 	},
12057 	{
12058 		"ALU32_MUL_K: registers",
12059 		{ },
12060 		INTERNAL,
12061 		{ },
12062 		{ { 0, 1 } },
12063 		.fill_helper = bpf_fill_alu32_mul_imm_regs,
12064 	},
12065 	{
12066 		"ALU32_DIV_K: registers",
12067 		{ },
12068 		INTERNAL,
12069 		{ },
12070 		{ { 0, 1 } },
12071 		.fill_helper = bpf_fill_alu32_div_imm_regs,
12072 	},
12073 	{
12074 		"ALU32_MOD_K: registers",
12075 		{ },
12076 		INTERNAL,
12077 		{ },
12078 		{ { 0, 1 } },
12079 		.fill_helper = bpf_fill_alu32_mod_imm_regs,
12080 	},
12081 	/* ALU64 X register combinations */
12082 	{
12083 		"ALU64_MOV_X: register combinations",
12084 		{ },
12085 		INTERNAL,
12086 		{ },
12087 		{ { 0, 1 } },
12088 		.fill_helper = bpf_fill_alu64_mov_reg_pairs,
12089 	},
12090 	{
12091 		"ALU64_AND_X: register combinations",
12092 		{ },
12093 		INTERNAL,
12094 		{ },
12095 		{ { 0, 1 } },
12096 		.fill_helper = bpf_fill_alu64_and_reg_pairs,
12097 	},
12098 	{
12099 		"ALU64_OR_X: register combinations",
12100 		{ },
12101 		INTERNAL,
12102 		{ },
12103 		{ { 0, 1 } },
12104 		.fill_helper = bpf_fill_alu64_or_reg_pairs,
12105 	},
12106 	{
12107 		"ALU64_XOR_X: register combinations",
12108 		{ },
12109 		INTERNAL,
12110 		{ },
12111 		{ { 0, 1 } },
12112 		.fill_helper = bpf_fill_alu64_xor_reg_pairs,
12113 	},
12114 	{
12115 		"ALU64_LSH_X: register combinations",
12116 		{ },
12117 		INTERNAL,
12118 		{ },
12119 		{ { 0, 1 } },
12120 		.fill_helper = bpf_fill_alu64_lsh_reg_pairs,
12121 	},
12122 	{
12123 		"ALU64_RSH_X: register combinations",
12124 		{ },
12125 		INTERNAL,
12126 		{ },
12127 		{ { 0, 1 } },
12128 		.fill_helper = bpf_fill_alu64_rsh_reg_pairs,
12129 	},
12130 	{
12131 		"ALU64_ARSH_X: register combinations",
12132 		{ },
12133 		INTERNAL,
12134 		{ },
12135 		{ { 0, 1 } },
12136 		.fill_helper = bpf_fill_alu64_arsh_reg_pairs,
12137 	},
12138 	{
12139 		"ALU64_ADD_X: register combinations",
12140 		{ },
12141 		INTERNAL,
12142 		{ },
12143 		{ { 0, 1 } },
12144 		.fill_helper = bpf_fill_alu64_add_reg_pairs,
12145 	},
12146 	{
12147 		"ALU64_SUB_X: register combinations",
12148 		{ },
12149 		INTERNAL,
12150 		{ },
12151 		{ { 0, 1 } },
12152 		.fill_helper = bpf_fill_alu64_sub_reg_pairs,
12153 	},
12154 	{
12155 		"ALU64_MUL_X: register combinations",
12156 		{ },
12157 		INTERNAL,
12158 		{ },
12159 		{ { 0, 1 } },
12160 		.fill_helper = bpf_fill_alu64_mul_reg_pairs,
12161 	},
12162 	{
12163 		"ALU64_DIV_X: register combinations",
12164 		{ },
12165 		INTERNAL,
12166 		{ },
12167 		{ { 0, 1 } },
12168 		.fill_helper = bpf_fill_alu64_div_reg_pairs,
12169 	},
12170 	{
12171 		"ALU64_MOD_X: register combinations",
12172 		{ },
12173 		INTERNAL,
12174 		{ },
12175 		{ { 0, 1 } },
12176 		.fill_helper = bpf_fill_alu64_mod_reg_pairs,
12177 	},
12178 	/* ALU32 X register combinations */
12179 	{
12180 		"ALU32_MOV_X: register combinations",
12181 		{ },
12182 		INTERNAL,
12183 		{ },
12184 		{ { 0, 1 } },
12185 		.fill_helper = bpf_fill_alu32_mov_reg_pairs,
12186 	},
12187 	{
12188 		"ALU32_AND_X: register combinations",
12189 		{ },
12190 		INTERNAL,
12191 		{ },
12192 		{ { 0, 1 } },
12193 		.fill_helper = bpf_fill_alu32_and_reg_pairs,
12194 	},
12195 	{
12196 		"ALU32_OR_X: register combinations",
12197 		{ },
12198 		INTERNAL,
12199 		{ },
12200 		{ { 0, 1 } },
12201 		.fill_helper = bpf_fill_alu32_or_reg_pairs,
12202 	},
12203 	{
12204 		"ALU32_XOR_X: register combinations",
12205 		{ },
12206 		INTERNAL,
12207 		{ },
12208 		{ { 0, 1 } },
12209 		.fill_helper = bpf_fill_alu32_xor_reg_pairs,
12210 	},
12211 	{
12212 		"ALU32_LSH_X: register combinations",
12213 		{ },
12214 		INTERNAL,
12215 		{ },
12216 		{ { 0, 1 } },
12217 		.fill_helper = bpf_fill_alu32_lsh_reg_pairs,
12218 	},
12219 	{
12220 		"ALU32_RSH_X: register combinations",
12221 		{ },
12222 		INTERNAL,
12223 		{ },
12224 		{ { 0, 1 } },
12225 		.fill_helper = bpf_fill_alu32_rsh_reg_pairs,
12226 	},
12227 	{
12228 		"ALU32_ARSH_X: register combinations",
12229 		{ },
12230 		INTERNAL,
12231 		{ },
12232 		{ { 0, 1 } },
12233 		.fill_helper = bpf_fill_alu32_arsh_reg_pairs,
12234 	},
12235 	{
12236 		"ALU32_ADD_X: register combinations",
12237 		{ },
12238 		INTERNAL,
12239 		{ },
12240 		{ { 0, 1 } },
12241 		.fill_helper = bpf_fill_alu32_add_reg_pairs,
12242 	},
12243 	{
12244 		"ALU32_SUB_X: register combinations",
12245 		{ },
12246 		INTERNAL,
12247 		{ },
12248 		{ { 0, 1 } },
12249 		.fill_helper = bpf_fill_alu32_sub_reg_pairs,
12250 	},
12251 	{
12252 		"ALU32_MUL_X: register combinations",
12253 		{ },
12254 		INTERNAL,
12255 		{ },
12256 		{ { 0, 1 } },
12257 		.fill_helper = bpf_fill_alu32_mul_reg_pairs,
12258 	},
12259 	{
12260 		"ALU32_DIV_X: register combinations",
12261 		{ },
12262 		INTERNAL,
12263 		{ },
12264 		{ { 0, 1 } },
12265 		.fill_helper = bpf_fill_alu32_div_reg_pairs,
12266 	},
12267 	{
12268 		"ALU32_MOD_X register combinations",
12269 		{ },
12270 		INTERNAL,
12271 		{ },
12272 		{ { 0, 1 } },
12273 		.fill_helper = bpf_fill_alu32_mod_reg_pairs,
12274 	},
12275 	/* Exhaustive test of ALU64 shift operations */
12276 	{
12277 		"ALU64_LSH_K: all shift values",
12278 		{ },
12279 		INTERNAL | FLAG_NO_DATA,
12280 		{ },
12281 		{ { 0, 1 } },
12282 		.fill_helper = bpf_fill_alu64_lsh_imm,
12283 	},
12284 	{
12285 		"ALU64_RSH_K: all shift values",
12286 		{ },
12287 		INTERNAL | FLAG_NO_DATA,
12288 		{ },
12289 		{ { 0, 1 } },
12290 		.fill_helper = bpf_fill_alu64_rsh_imm,
12291 	},
12292 	{
12293 		"ALU64_ARSH_K: all shift values",
12294 		{ },
12295 		INTERNAL | FLAG_NO_DATA,
12296 		{ },
12297 		{ { 0, 1 } },
12298 		.fill_helper = bpf_fill_alu64_arsh_imm,
12299 	},
12300 	{
12301 		"ALU64_LSH_X: all shift values",
12302 		{ },
12303 		INTERNAL | FLAG_NO_DATA,
12304 		{ },
12305 		{ { 0, 1 } },
12306 		.fill_helper = bpf_fill_alu64_lsh_reg,
12307 	},
12308 	{
12309 		"ALU64_RSH_X: all shift values",
12310 		{ },
12311 		INTERNAL | FLAG_NO_DATA,
12312 		{ },
12313 		{ { 0, 1 } },
12314 		.fill_helper = bpf_fill_alu64_rsh_reg,
12315 	},
12316 	{
12317 		"ALU64_ARSH_X: all shift values",
12318 		{ },
12319 		INTERNAL | FLAG_NO_DATA,
12320 		{ },
12321 		{ { 0, 1 } },
12322 		.fill_helper = bpf_fill_alu64_arsh_reg,
12323 	},
12324 	/* Exhaustive test of ALU32 shift operations */
12325 	{
12326 		"ALU32_LSH_K: all shift values",
12327 		{ },
12328 		INTERNAL | FLAG_NO_DATA,
12329 		{ },
12330 		{ { 0, 1 } },
12331 		.fill_helper = bpf_fill_alu32_lsh_imm,
12332 	},
12333 	{
12334 		"ALU32_RSH_K: all shift values",
12335 		{ },
12336 		INTERNAL | FLAG_NO_DATA,
12337 		{ },
12338 		{ { 0, 1 } },
12339 		.fill_helper = bpf_fill_alu32_rsh_imm,
12340 	},
12341 	{
12342 		"ALU32_ARSH_K: all shift values",
12343 		{ },
12344 		INTERNAL | FLAG_NO_DATA,
12345 		{ },
12346 		{ { 0, 1 } },
12347 		.fill_helper = bpf_fill_alu32_arsh_imm,
12348 	},
12349 	{
12350 		"ALU32_LSH_X: all shift values",
12351 		{ },
12352 		INTERNAL | FLAG_NO_DATA,
12353 		{ },
12354 		{ { 0, 1 } },
12355 		.fill_helper = bpf_fill_alu32_lsh_reg,
12356 	},
12357 	{
12358 		"ALU32_RSH_X: all shift values",
12359 		{ },
12360 		INTERNAL | FLAG_NO_DATA,
12361 		{ },
12362 		{ { 0, 1 } },
12363 		.fill_helper = bpf_fill_alu32_rsh_reg,
12364 	},
12365 	{
12366 		"ALU32_ARSH_X: all shift values",
12367 		{ },
12368 		INTERNAL | FLAG_NO_DATA,
12369 		{ },
12370 		{ { 0, 1 } },
12371 		.fill_helper = bpf_fill_alu32_arsh_reg,
12372 	},
12373 	/*
12374 	 * Exhaustive test of ALU64 shift operations when
12375 	 * source and destination register are the same.
12376 	 */
12377 	{
12378 		"ALU64_LSH_X: all shift values with the same register",
12379 		{ },
12380 		INTERNAL | FLAG_NO_DATA,
12381 		{ },
12382 		{ { 0, 1 } },
12383 		.fill_helper = bpf_fill_alu64_lsh_same_reg,
12384 	},
12385 	{
12386 		"ALU64_RSH_X: all shift values with the same register",
12387 		{ },
12388 		INTERNAL | FLAG_NO_DATA,
12389 		{ },
12390 		{ { 0, 1 } },
12391 		.fill_helper = bpf_fill_alu64_rsh_same_reg,
12392 	},
12393 	{
12394 		"ALU64_ARSH_X: all shift values with the same register",
12395 		{ },
12396 		INTERNAL | FLAG_NO_DATA,
12397 		{ },
12398 		{ { 0, 1 } },
12399 		.fill_helper = bpf_fill_alu64_arsh_same_reg,
12400 	},
12401 	/*
12402 	 * Exhaustive test of ALU32 shift operations when
12403 	 * source and destination register are the same.
12404 	 */
12405 	{
12406 		"ALU32_LSH_X: all shift values with the same register",
12407 		{ },
12408 		INTERNAL | FLAG_NO_DATA,
12409 		{ },
12410 		{ { 0, 1 } },
12411 		.fill_helper = bpf_fill_alu32_lsh_same_reg,
12412 	},
12413 	{
12414 		"ALU32_RSH_X: all shift values with the same register",
12415 		{ },
12416 		INTERNAL | FLAG_NO_DATA,
12417 		{ },
12418 		{ { 0, 1 } },
12419 		.fill_helper = bpf_fill_alu32_rsh_same_reg,
12420 	},
12421 	{
12422 		"ALU32_ARSH_X: all shift values with the same register",
12423 		{ },
12424 		INTERNAL | FLAG_NO_DATA,
12425 		{ },
12426 		{ { 0, 1 } },
12427 		.fill_helper = bpf_fill_alu32_arsh_same_reg,
12428 	},
12429 	/* ALU64 immediate magnitudes */
12430 	{
12431 		"ALU64_MOV_K: all immediate value magnitudes",
12432 		{ },
12433 		INTERNAL | FLAG_NO_DATA,
12434 		{ },
12435 		{ { 0, 1 } },
12436 		.fill_helper = bpf_fill_alu64_mov_imm,
12437 		.nr_testruns = NR_PATTERN_RUNS,
12438 	},
12439 	{
12440 		"ALU64_AND_K: all immediate value magnitudes",
12441 		{ },
12442 		INTERNAL | FLAG_NO_DATA,
12443 		{ },
12444 		{ { 0, 1 } },
12445 		.fill_helper = bpf_fill_alu64_and_imm,
12446 		.nr_testruns = NR_PATTERN_RUNS,
12447 	},
12448 	{
12449 		"ALU64_OR_K: all immediate value magnitudes",
12450 		{ },
12451 		INTERNAL | FLAG_NO_DATA,
12452 		{ },
12453 		{ { 0, 1 } },
12454 		.fill_helper = bpf_fill_alu64_or_imm,
12455 		.nr_testruns = NR_PATTERN_RUNS,
12456 	},
12457 	{
12458 		"ALU64_XOR_K: all immediate value magnitudes",
12459 		{ },
12460 		INTERNAL | FLAG_NO_DATA,
12461 		{ },
12462 		{ { 0, 1 } },
12463 		.fill_helper = bpf_fill_alu64_xor_imm,
12464 		.nr_testruns = NR_PATTERN_RUNS,
12465 	},
12466 	{
12467 		"ALU64_ADD_K: all immediate value magnitudes",
12468 		{ },
12469 		INTERNAL | FLAG_NO_DATA,
12470 		{ },
12471 		{ { 0, 1 } },
12472 		.fill_helper = bpf_fill_alu64_add_imm,
12473 		.nr_testruns = NR_PATTERN_RUNS,
12474 	},
12475 	{
12476 		"ALU64_SUB_K: all immediate value magnitudes",
12477 		{ },
12478 		INTERNAL | FLAG_NO_DATA,
12479 		{ },
12480 		{ { 0, 1 } },
12481 		.fill_helper = bpf_fill_alu64_sub_imm,
12482 		.nr_testruns = NR_PATTERN_RUNS,
12483 	},
12484 	{
12485 		"ALU64_MUL_K: all immediate value magnitudes",
12486 		{ },
12487 		INTERNAL | FLAG_NO_DATA,
12488 		{ },
12489 		{ { 0, 1 } },
12490 		.fill_helper = bpf_fill_alu64_mul_imm,
12491 		.nr_testruns = NR_PATTERN_RUNS,
12492 	},
12493 	{
12494 		"ALU64_DIV_K: all immediate value magnitudes",
12495 		{ },
12496 		INTERNAL | FLAG_NO_DATA,
12497 		{ },
12498 		{ { 0, 1 } },
12499 		.fill_helper = bpf_fill_alu64_div_imm,
12500 		.nr_testruns = NR_PATTERN_RUNS,
12501 	},
12502 	{
12503 		"ALU64_MOD_K: all immediate value magnitudes",
12504 		{ },
12505 		INTERNAL | FLAG_NO_DATA,
12506 		{ },
12507 		{ { 0, 1 } },
12508 		.fill_helper = bpf_fill_alu64_mod_imm,
12509 		.nr_testruns = NR_PATTERN_RUNS,
12510 	},
12511 	/* ALU32 immediate magnitudes */
12512 	{
12513 		"ALU32_MOV_K: all immediate value magnitudes",
12514 		{ },
12515 		INTERNAL | FLAG_NO_DATA,
12516 		{ },
12517 		{ { 0, 1 } },
12518 		.fill_helper = bpf_fill_alu32_mov_imm,
12519 		.nr_testruns = NR_PATTERN_RUNS,
12520 	},
12521 	{
12522 		"ALU32_AND_K: all immediate value magnitudes",
12523 		{ },
12524 		INTERNAL | FLAG_NO_DATA,
12525 		{ },
12526 		{ { 0, 1 } },
12527 		.fill_helper = bpf_fill_alu32_and_imm,
12528 		.nr_testruns = NR_PATTERN_RUNS,
12529 	},
12530 	{
12531 		"ALU32_OR_K: all immediate value magnitudes",
12532 		{ },
12533 		INTERNAL | FLAG_NO_DATA,
12534 		{ },
12535 		{ { 0, 1 } },
12536 		.fill_helper = bpf_fill_alu32_or_imm,
12537 		.nr_testruns = NR_PATTERN_RUNS,
12538 	},
12539 	{
12540 		"ALU32_XOR_K: all immediate value magnitudes",
12541 		{ },
12542 		INTERNAL | FLAG_NO_DATA,
12543 		{ },
12544 		{ { 0, 1 } },
12545 		.fill_helper = bpf_fill_alu32_xor_imm,
12546 		.nr_testruns = NR_PATTERN_RUNS,
12547 	},
12548 	{
12549 		"ALU32_ADD_K: all immediate value magnitudes",
12550 		{ },
12551 		INTERNAL | FLAG_NO_DATA,
12552 		{ },
12553 		{ { 0, 1 } },
12554 		.fill_helper = bpf_fill_alu32_add_imm,
12555 		.nr_testruns = NR_PATTERN_RUNS,
12556 	},
12557 	{
12558 		"ALU32_SUB_K: all immediate value magnitudes",
12559 		{ },
12560 		INTERNAL | FLAG_NO_DATA,
12561 		{ },
12562 		{ { 0, 1 } },
12563 		.fill_helper = bpf_fill_alu32_sub_imm,
12564 		.nr_testruns = NR_PATTERN_RUNS,
12565 	},
12566 	{
12567 		"ALU32_MUL_K: all immediate value magnitudes",
12568 		{ },
12569 		INTERNAL | FLAG_NO_DATA,
12570 		{ },
12571 		{ { 0, 1 } },
12572 		.fill_helper = bpf_fill_alu32_mul_imm,
12573 		.nr_testruns = NR_PATTERN_RUNS,
12574 	},
12575 	{
12576 		"ALU32_DIV_K: all immediate value magnitudes",
12577 		{ },
12578 		INTERNAL | FLAG_NO_DATA,
12579 		{ },
12580 		{ { 0, 1 } },
12581 		.fill_helper = bpf_fill_alu32_div_imm,
12582 		.nr_testruns = NR_PATTERN_RUNS,
12583 	},
12584 	{
12585 		"ALU32_MOD_K: all immediate value magnitudes",
12586 		{ },
12587 		INTERNAL | FLAG_NO_DATA,
12588 		{ },
12589 		{ { 0, 1 } },
12590 		.fill_helper = bpf_fill_alu32_mod_imm,
12591 		.nr_testruns = NR_PATTERN_RUNS,
12592 	},
12593 	/* ALU64 register magnitudes */
12594 	{
12595 		"ALU64_MOV_X: all register value magnitudes",
12596 		{ },
12597 		INTERNAL | FLAG_NO_DATA,
12598 		{ },
12599 		{ { 0, 1 } },
12600 		.fill_helper = bpf_fill_alu64_mov_reg,
12601 		.nr_testruns = NR_PATTERN_RUNS,
12602 	},
12603 	{
12604 		"ALU64_AND_X: all register value magnitudes",
12605 		{ },
12606 		INTERNAL | FLAG_NO_DATA,
12607 		{ },
12608 		{ { 0, 1 } },
12609 		.fill_helper = bpf_fill_alu64_and_reg,
12610 		.nr_testruns = NR_PATTERN_RUNS,
12611 	},
12612 	{
12613 		"ALU64_OR_X: all register value magnitudes",
12614 		{ },
12615 		INTERNAL | FLAG_NO_DATA,
12616 		{ },
12617 		{ { 0, 1 } },
12618 		.fill_helper = bpf_fill_alu64_or_reg,
12619 		.nr_testruns = NR_PATTERN_RUNS,
12620 	},
12621 	{
12622 		"ALU64_XOR_X: all register value magnitudes",
12623 		{ },
12624 		INTERNAL | FLAG_NO_DATA,
12625 		{ },
12626 		{ { 0, 1 } },
12627 		.fill_helper = bpf_fill_alu64_xor_reg,
12628 		.nr_testruns = NR_PATTERN_RUNS,
12629 	},
12630 	{
12631 		"ALU64_ADD_X: all register value magnitudes",
12632 		{ },
12633 		INTERNAL | FLAG_NO_DATA,
12634 		{ },
12635 		{ { 0, 1 } },
12636 		.fill_helper = bpf_fill_alu64_add_reg,
12637 		.nr_testruns = NR_PATTERN_RUNS,
12638 	},
12639 	{
12640 		"ALU64_SUB_X: all register value magnitudes",
12641 		{ },
12642 		INTERNAL | FLAG_NO_DATA,
12643 		{ },
12644 		{ { 0, 1 } },
12645 		.fill_helper = bpf_fill_alu64_sub_reg,
12646 		.nr_testruns = NR_PATTERN_RUNS,
12647 	},
12648 	{
12649 		"ALU64_MUL_X: all register value magnitudes",
12650 		{ },
12651 		INTERNAL | FLAG_NO_DATA,
12652 		{ },
12653 		{ { 0, 1 } },
12654 		.fill_helper = bpf_fill_alu64_mul_reg,
12655 		.nr_testruns = NR_PATTERN_RUNS,
12656 	},
12657 	{
12658 		"ALU64_DIV_X: all register value magnitudes",
12659 		{ },
12660 		INTERNAL | FLAG_NO_DATA,
12661 		{ },
12662 		{ { 0, 1 } },
12663 		.fill_helper = bpf_fill_alu64_div_reg,
12664 		.nr_testruns = NR_PATTERN_RUNS,
12665 	},
12666 	{
12667 		"ALU64_MOD_X: all register value magnitudes",
12668 		{ },
12669 		INTERNAL | FLAG_NO_DATA,
12670 		{ },
12671 		{ { 0, 1 } },
12672 		.fill_helper = bpf_fill_alu64_mod_reg,
12673 		.nr_testruns = NR_PATTERN_RUNS,
12674 	},
12675 	/* ALU32 register magnitudes */
12676 	{
12677 		"ALU32_MOV_X: all register value magnitudes",
12678 		{ },
12679 		INTERNAL | FLAG_NO_DATA,
12680 		{ },
12681 		{ { 0, 1 } },
12682 		.fill_helper = bpf_fill_alu32_mov_reg,
12683 		.nr_testruns = NR_PATTERN_RUNS,
12684 	},
12685 	{
12686 		"ALU32_AND_X: all register value magnitudes",
12687 		{ },
12688 		INTERNAL | FLAG_NO_DATA,
12689 		{ },
12690 		{ { 0, 1 } },
12691 		.fill_helper = bpf_fill_alu32_and_reg,
12692 		.nr_testruns = NR_PATTERN_RUNS,
12693 	},
12694 	{
12695 		"ALU32_OR_X: all register value magnitudes",
12696 		{ },
12697 		INTERNAL | FLAG_NO_DATA,
12698 		{ },
12699 		{ { 0, 1 } },
12700 		.fill_helper = bpf_fill_alu32_or_reg,
12701 		.nr_testruns = NR_PATTERN_RUNS,
12702 	},
12703 	{
12704 		"ALU32_XOR_X: all register value magnitudes",
12705 		{ },
12706 		INTERNAL | FLAG_NO_DATA,
12707 		{ },
12708 		{ { 0, 1 } },
12709 		.fill_helper = bpf_fill_alu32_xor_reg,
12710 		.nr_testruns = NR_PATTERN_RUNS,
12711 	},
12712 	{
12713 		"ALU32_ADD_X: all register value magnitudes",
12714 		{ },
12715 		INTERNAL | FLAG_NO_DATA,
12716 		{ },
12717 		{ { 0, 1 } },
12718 		.fill_helper = bpf_fill_alu32_add_reg,
12719 		.nr_testruns = NR_PATTERN_RUNS,
12720 	},
12721 	{
12722 		"ALU32_SUB_X: all register value magnitudes",
12723 		{ },
12724 		INTERNAL | FLAG_NO_DATA,
12725 		{ },
12726 		{ { 0, 1 } },
12727 		.fill_helper = bpf_fill_alu32_sub_reg,
12728 		.nr_testruns = NR_PATTERN_RUNS,
12729 	},
12730 	{
12731 		"ALU32_MUL_X: all register value magnitudes",
12732 		{ },
12733 		INTERNAL | FLAG_NO_DATA,
12734 		{ },
12735 		{ { 0, 1 } },
12736 		.fill_helper = bpf_fill_alu32_mul_reg,
12737 		.nr_testruns = NR_PATTERN_RUNS,
12738 	},
12739 	{
12740 		"ALU32_DIV_X: all register value magnitudes",
12741 		{ },
12742 		INTERNAL | FLAG_NO_DATA,
12743 		{ },
12744 		{ { 0, 1 } },
12745 		.fill_helper = bpf_fill_alu32_div_reg,
12746 		.nr_testruns = NR_PATTERN_RUNS,
12747 	},
12748 	{
12749 		"ALU32_MOD_X: all register value magnitudes",
12750 		{ },
12751 		INTERNAL | FLAG_NO_DATA,
12752 		{ },
12753 		{ { 0, 1 } },
12754 		.fill_helper = bpf_fill_alu32_mod_reg,
12755 		.nr_testruns = NR_PATTERN_RUNS,
12756 	},
12757 	/* LD_IMM64 immediate magnitudes and byte patterns */
12758 	{
12759 		"LD_IMM64: all immediate value magnitudes",
12760 		{ },
12761 		INTERNAL | FLAG_NO_DATA,
12762 		{ },
12763 		{ { 0, 1 } },
12764 		.fill_helper = bpf_fill_ld_imm64_magn,
12765 	},
12766 	{
12767 		"LD_IMM64: checker byte patterns",
12768 		{ },
12769 		INTERNAL | FLAG_NO_DATA,
12770 		{ },
12771 		{ { 0, 1 } },
12772 		.fill_helper = bpf_fill_ld_imm64_checker,
12773 	},
12774 	{
12775 		"LD_IMM64: random positive and zero byte patterns",
12776 		{ },
12777 		INTERNAL | FLAG_NO_DATA,
12778 		{ },
12779 		{ { 0, 1 } },
12780 		.fill_helper = bpf_fill_ld_imm64_pos_zero,
12781 	},
12782 	{
12783 		"LD_IMM64: random negative and zero byte patterns",
12784 		{ },
12785 		INTERNAL | FLAG_NO_DATA,
12786 		{ },
12787 		{ { 0, 1 } },
12788 		.fill_helper = bpf_fill_ld_imm64_neg_zero,
12789 	},
12790 	{
12791 		"LD_IMM64: random positive and negative byte patterns",
12792 		{ },
12793 		INTERNAL | FLAG_NO_DATA,
12794 		{ },
12795 		{ { 0, 1 } },
12796 		.fill_helper = bpf_fill_ld_imm64_pos_neg,
12797 	},
12798 	/* 64-bit ATOMIC register combinations */
12799 	{
12800 		"ATOMIC_DW_ADD: register combinations",
12801 		{ },
12802 		INTERNAL,
12803 		{ },
12804 		{ { 0, 1 } },
12805 		.fill_helper = bpf_fill_atomic64_add_reg_pairs,
12806 		.stack_depth = 8,
12807 	},
12808 	{
12809 		"ATOMIC_DW_AND: register combinations",
12810 		{ },
12811 		INTERNAL,
12812 		{ },
12813 		{ { 0, 1 } },
12814 		.fill_helper = bpf_fill_atomic64_and_reg_pairs,
12815 		.stack_depth = 8,
12816 	},
12817 	{
12818 		"ATOMIC_DW_OR: register combinations",
12819 		{ },
12820 		INTERNAL,
12821 		{ },
12822 		{ { 0, 1 } },
12823 		.fill_helper = bpf_fill_atomic64_or_reg_pairs,
12824 		.stack_depth = 8,
12825 	},
12826 	{
12827 		"ATOMIC_DW_XOR: register combinations",
12828 		{ },
12829 		INTERNAL,
12830 		{ },
12831 		{ { 0, 1 } },
12832 		.fill_helper = bpf_fill_atomic64_xor_reg_pairs,
12833 		.stack_depth = 8,
12834 	},
12835 	{
12836 		"ATOMIC_DW_ADD_FETCH: register combinations",
12837 		{ },
12838 		INTERNAL,
12839 		{ },
12840 		{ { 0, 1 } },
12841 		.fill_helper = bpf_fill_atomic64_add_fetch_reg_pairs,
12842 		.stack_depth = 8,
12843 	},
12844 	{
12845 		"ATOMIC_DW_AND_FETCH: register combinations",
12846 		{ },
12847 		INTERNAL,
12848 		{ },
12849 		{ { 0, 1 } },
12850 		.fill_helper = bpf_fill_atomic64_and_fetch_reg_pairs,
12851 		.stack_depth = 8,
12852 	},
12853 	{
12854 		"ATOMIC_DW_OR_FETCH: register combinations",
12855 		{ },
12856 		INTERNAL,
12857 		{ },
12858 		{ { 0, 1 } },
12859 		.fill_helper = bpf_fill_atomic64_or_fetch_reg_pairs,
12860 		.stack_depth = 8,
12861 	},
12862 	{
12863 		"ATOMIC_DW_XOR_FETCH: register combinations",
12864 		{ },
12865 		INTERNAL,
12866 		{ },
12867 		{ { 0, 1 } },
12868 		.fill_helper = bpf_fill_atomic64_xor_fetch_reg_pairs,
12869 		.stack_depth = 8,
12870 	},
12871 	{
12872 		"ATOMIC_DW_XCHG: register combinations",
12873 		{ },
12874 		INTERNAL,
12875 		{ },
12876 		{ { 0, 1 } },
12877 		.fill_helper = bpf_fill_atomic64_xchg_reg_pairs,
12878 		.stack_depth = 8,
12879 	},
12880 	{
12881 		"ATOMIC_DW_CMPXCHG: register combinations",
12882 		{ },
12883 		INTERNAL,
12884 		{ },
12885 		{ { 0, 1 } },
12886 		.fill_helper = bpf_fill_atomic64_cmpxchg_reg_pairs,
12887 		.stack_depth = 8,
12888 	},
12889 	/* 32-bit ATOMIC register combinations */
12890 	{
12891 		"ATOMIC_W_ADD: register combinations",
12892 		{ },
12893 		INTERNAL,
12894 		{ },
12895 		{ { 0, 1 } },
12896 		.fill_helper = bpf_fill_atomic32_add_reg_pairs,
12897 		.stack_depth = 8,
12898 	},
12899 	{
12900 		"ATOMIC_W_AND: register combinations",
12901 		{ },
12902 		INTERNAL,
12903 		{ },
12904 		{ { 0, 1 } },
12905 		.fill_helper = bpf_fill_atomic32_and_reg_pairs,
12906 		.stack_depth = 8,
12907 	},
12908 	{
12909 		"ATOMIC_W_OR: register combinations",
12910 		{ },
12911 		INTERNAL,
12912 		{ },
12913 		{ { 0, 1 } },
12914 		.fill_helper = bpf_fill_atomic32_or_reg_pairs,
12915 		.stack_depth = 8,
12916 	},
12917 	{
12918 		"ATOMIC_W_XOR: register combinations",
12919 		{ },
12920 		INTERNAL,
12921 		{ },
12922 		{ { 0, 1 } },
12923 		.fill_helper = bpf_fill_atomic32_xor_reg_pairs,
12924 		.stack_depth = 8,
12925 	},
12926 	{
12927 		"ATOMIC_W_ADD_FETCH: register combinations",
12928 		{ },
12929 		INTERNAL,
12930 		{ },
12931 		{ { 0, 1 } },
12932 		.fill_helper = bpf_fill_atomic32_add_fetch_reg_pairs,
12933 		.stack_depth = 8,
12934 	},
12935 	{
12936 		"ATOMIC_W_AND_FETCH: register combinations",
12937 		{ },
12938 		INTERNAL,
12939 		{ },
12940 		{ { 0, 1 } },
12941 		.fill_helper = bpf_fill_atomic32_and_fetch_reg_pairs,
12942 		.stack_depth = 8,
12943 	},
12944 	{
12945 		"ATOMIC_W_OR_FETCH: register combinations",
12946 		{ },
12947 		INTERNAL,
12948 		{ },
12949 		{ { 0, 1 } },
12950 		.fill_helper = bpf_fill_atomic32_or_fetch_reg_pairs,
12951 		.stack_depth = 8,
12952 	},
12953 	{
12954 		"ATOMIC_W_XOR_FETCH: register combinations",
12955 		{ },
12956 		INTERNAL,
12957 		{ },
12958 		{ { 0, 1 } },
12959 		.fill_helper = bpf_fill_atomic32_xor_fetch_reg_pairs,
12960 		.stack_depth = 8,
12961 	},
12962 	{
12963 		"ATOMIC_W_XCHG: register combinations",
12964 		{ },
12965 		INTERNAL,
12966 		{ },
12967 		{ { 0, 1 } },
12968 		.fill_helper = bpf_fill_atomic32_xchg_reg_pairs,
12969 		.stack_depth = 8,
12970 	},
12971 	{
12972 		"ATOMIC_W_CMPXCHG: register combinations",
12973 		{ },
12974 		INTERNAL,
12975 		{ },
12976 		{ { 0, 1 } },
12977 		.fill_helper = bpf_fill_atomic32_cmpxchg_reg_pairs,
12978 		.stack_depth = 8,
12979 	},
12980 	/* 64-bit ATOMIC magnitudes */
12981 	{
12982 		"ATOMIC_DW_ADD: all operand magnitudes",
12983 		{ },
12984 		INTERNAL | FLAG_NO_DATA,
12985 		{ },
12986 		{ { 0, 1 } },
12987 		.fill_helper = bpf_fill_atomic64_add,
12988 		.stack_depth = 8,
12989 		.nr_testruns = NR_PATTERN_RUNS,
12990 	},
12991 	{
12992 		"ATOMIC_DW_AND: all operand magnitudes",
12993 		{ },
12994 		INTERNAL | FLAG_NO_DATA,
12995 		{ },
12996 		{ { 0, 1 } },
12997 		.fill_helper = bpf_fill_atomic64_and,
12998 		.stack_depth = 8,
12999 		.nr_testruns = NR_PATTERN_RUNS,
13000 	},
13001 	{
13002 		"ATOMIC_DW_OR: all operand magnitudes",
13003 		{ },
13004 		INTERNAL | FLAG_NO_DATA,
13005 		{ },
13006 		{ { 0, 1 } },
13007 		.fill_helper = bpf_fill_atomic64_or,
13008 		.stack_depth = 8,
13009 		.nr_testruns = NR_PATTERN_RUNS,
13010 	},
13011 	{
13012 		"ATOMIC_DW_XOR: all operand magnitudes",
13013 		{ },
13014 		INTERNAL | FLAG_NO_DATA,
13015 		{ },
13016 		{ { 0, 1 } },
13017 		.fill_helper = bpf_fill_atomic64_xor,
13018 		.stack_depth = 8,
13019 		.nr_testruns = NR_PATTERN_RUNS,
13020 	},
13021 	{
13022 		"ATOMIC_DW_ADD_FETCH: all operand magnitudes",
13023 		{ },
13024 		INTERNAL | FLAG_NO_DATA,
13025 		{ },
13026 		{ { 0, 1 } },
13027 		.fill_helper = bpf_fill_atomic64_add_fetch,
13028 		.stack_depth = 8,
13029 		.nr_testruns = NR_PATTERN_RUNS,
13030 	},
13031 	{
13032 		"ATOMIC_DW_AND_FETCH: all operand magnitudes",
13033 		{ },
13034 		INTERNAL | FLAG_NO_DATA,
13035 		{ },
13036 		{ { 0, 1 } },
13037 		.fill_helper = bpf_fill_atomic64_and_fetch,
13038 		.stack_depth = 8,
13039 		.nr_testruns = NR_PATTERN_RUNS,
13040 	},
13041 	{
13042 		"ATOMIC_DW_OR_FETCH: all operand magnitudes",
13043 		{ },
13044 		INTERNAL | FLAG_NO_DATA,
13045 		{ },
13046 		{ { 0, 1 } },
13047 		.fill_helper = bpf_fill_atomic64_or_fetch,
13048 		.stack_depth = 8,
13049 		.nr_testruns = NR_PATTERN_RUNS,
13050 	},
13051 	{
13052 		"ATOMIC_DW_XOR_FETCH: all operand magnitudes",
13053 		{ },
13054 		INTERNAL | FLAG_NO_DATA,
13055 		{ },
13056 		{ { 0, 1 } },
13057 		.fill_helper = bpf_fill_atomic64_xor_fetch,
13058 		.stack_depth = 8,
13059 		.nr_testruns = NR_PATTERN_RUNS,
13060 	},
13061 	{
13062 		"ATOMIC_DW_XCHG: all operand magnitudes",
13063 		{ },
13064 		INTERNAL | FLAG_NO_DATA,
13065 		{ },
13066 		{ { 0, 1 } },
13067 		.fill_helper = bpf_fill_atomic64_xchg,
13068 		.stack_depth = 8,
13069 		.nr_testruns = NR_PATTERN_RUNS,
13070 	},
13071 	{
13072 		"ATOMIC_DW_CMPXCHG: all operand magnitudes",
13073 		{ },
13074 		INTERNAL | FLAG_NO_DATA,
13075 		{ },
13076 		{ { 0, 1 } },
13077 		.fill_helper = bpf_fill_cmpxchg64,
13078 		.stack_depth = 8,
13079 		.nr_testruns = NR_PATTERN_RUNS,
13080 	},
13081 	/* 64-bit atomic magnitudes */
13082 	{
13083 		"ATOMIC_W_ADD: all operand magnitudes",
13084 		{ },
13085 		INTERNAL | FLAG_NO_DATA,
13086 		{ },
13087 		{ { 0, 1 } },
13088 		.fill_helper = bpf_fill_atomic32_add,
13089 		.stack_depth = 8,
13090 		.nr_testruns = NR_PATTERN_RUNS,
13091 	},
13092 	{
13093 		"ATOMIC_W_AND: all operand magnitudes",
13094 		{ },
13095 		INTERNAL | FLAG_NO_DATA,
13096 		{ },
13097 		{ { 0, 1 } },
13098 		.fill_helper = bpf_fill_atomic32_and,
13099 		.stack_depth = 8,
13100 		.nr_testruns = NR_PATTERN_RUNS,
13101 	},
13102 	{
13103 		"ATOMIC_W_OR: all operand magnitudes",
13104 		{ },
13105 		INTERNAL | FLAG_NO_DATA,
13106 		{ },
13107 		{ { 0, 1 } },
13108 		.fill_helper = bpf_fill_atomic32_or,
13109 		.stack_depth = 8,
13110 		.nr_testruns = NR_PATTERN_RUNS,
13111 	},
13112 	{
13113 		"ATOMIC_W_XOR: all operand magnitudes",
13114 		{ },
13115 		INTERNAL | FLAG_NO_DATA,
13116 		{ },
13117 		{ { 0, 1 } },
13118 		.fill_helper = bpf_fill_atomic32_xor,
13119 		.stack_depth = 8,
13120 		.nr_testruns = NR_PATTERN_RUNS,
13121 	},
13122 	{
13123 		"ATOMIC_W_ADD_FETCH: all operand magnitudes",
13124 		{ },
13125 		INTERNAL | FLAG_NO_DATA,
13126 		{ },
13127 		{ { 0, 1 } },
13128 		.fill_helper = bpf_fill_atomic32_add_fetch,
13129 		.stack_depth = 8,
13130 		.nr_testruns = NR_PATTERN_RUNS,
13131 	},
13132 	{
13133 		"ATOMIC_W_AND_FETCH: all operand magnitudes",
13134 		{ },
13135 		INTERNAL | FLAG_NO_DATA,
13136 		{ },
13137 		{ { 0, 1 } },
13138 		.fill_helper = bpf_fill_atomic32_and_fetch,
13139 		.stack_depth = 8,
13140 		.nr_testruns = NR_PATTERN_RUNS,
13141 	},
13142 	{
13143 		"ATOMIC_W_OR_FETCH: all operand magnitudes",
13144 		{ },
13145 		INTERNAL | FLAG_NO_DATA,
13146 		{ },
13147 		{ { 0, 1 } },
13148 		.fill_helper = bpf_fill_atomic32_or_fetch,
13149 		.stack_depth = 8,
13150 		.nr_testruns = NR_PATTERN_RUNS,
13151 	},
13152 	{
13153 		"ATOMIC_W_XOR_FETCH: all operand magnitudes",
13154 		{ },
13155 		INTERNAL | FLAG_NO_DATA,
13156 		{ },
13157 		{ { 0, 1 } },
13158 		.fill_helper = bpf_fill_atomic32_xor_fetch,
13159 		.stack_depth = 8,
13160 		.nr_testruns = NR_PATTERN_RUNS,
13161 	},
13162 	{
13163 		"ATOMIC_W_XCHG: all operand magnitudes",
13164 		{ },
13165 		INTERNAL | FLAG_NO_DATA,
13166 		{ },
13167 		{ { 0, 1 } },
13168 		.fill_helper = bpf_fill_atomic32_xchg,
13169 		.stack_depth = 8,
13170 		.nr_testruns = NR_PATTERN_RUNS,
13171 	},
13172 	{
13173 		"ATOMIC_W_CMPXCHG: all operand magnitudes",
13174 		{ },
13175 		INTERNAL | FLAG_NO_DATA,
13176 		{ },
13177 		{ { 0, 1 } },
13178 		.fill_helper = bpf_fill_cmpxchg32,
13179 		.stack_depth = 8,
13180 		.nr_testruns = NR_PATTERN_RUNS,
13181 	},
13182 	/* JMP immediate magnitudes */
13183 	{
13184 		"JMP_JSET_K: all immediate value magnitudes",
13185 		{ },
13186 		INTERNAL | FLAG_NO_DATA,
13187 		{ },
13188 		{ { 0, 1 } },
13189 		.fill_helper = bpf_fill_jmp_jset_imm,
13190 		.nr_testruns = NR_PATTERN_RUNS,
13191 	},
13192 	{
13193 		"JMP_JEQ_K: all immediate value magnitudes",
13194 		{ },
13195 		INTERNAL | FLAG_NO_DATA,
13196 		{ },
13197 		{ { 0, 1 } },
13198 		.fill_helper = bpf_fill_jmp_jeq_imm,
13199 		.nr_testruns = NR_PATTERN_RUNS,
13200 	},
13201 	{
13202 		"JMP_JNE_K: all immediate value magnitudes",
13203 		{ },
13204 		INTERNAL | FLAG_NO_DATA,
13205 		{ },
13206 		{ { 0, 1 } },
13207 		.fill_helper = bpf_fill_jmp_jne_imm,
13208 		.nr_testruns = NR_PATTERN_RUNS,
13209 	},
13210 	{
13211 		"JMP_JGT_K: all immediate value magnitudes",
13212 		{ },
13213 		INTERNAL | FLAG_NO_DATA,
13214 		{ },
13215 		{ { 0, 1 } },
13216 		.fill_helper = bpf_fill_jmp_jgt_imm,
13217 		.nr_testruns = NR_PATTERN_RUNS,
13218 	},
13219 	{
13220 		"JMP_JGE_K: all immediate value magnitudes",
13221 		{ },
13222 		INTERNAL | FLAG_NO_DATA,
13223 		{ },
13224 		{ { 0, 1 } },
13225 		.fill_helper = bpf_fill_jmp_jge_imm,
13226 		.nr_testruns = NR_PATTERN_RUNS,
13227 	},
13228 	{
13229 		"JMP_JLT_K: all immediate value magnitudes",
13230 		{ },
13231 		INTERNAL | FLAG_NO_DATA,
13232 		{ },
13233 		{ { 0, 1 } },
13234 		.fill_helper = bpf_fill_jmp_jlt_imm,
13235 		.nr_testruns = NR_PATTERN_RUNS,
13236 	},
13237 	{
13238 		"JMP_JLE_K: all immediate value magnitudes",
13239 		{ },
13240 		INTERNAL | FLAG_NO_DATA,
13241 		{ },
13242 		{ { 0, 1 } },
13243 		.fill_helper = bpf_fill_jmp_jle_imm,
13244 		.nr_testruns = NR_PATTERN_RUNS,
13245 	},
13246 	{
13247 		"JMP_JSGT_K: all immediate value magnitudes",
13248 		{ },
13249 		INTERNAL | FLAG_NO_DATA,
13250 		{ },
13251 		{ { 0, 1 } },
13252 		.fill_helper = bpf_fill_jmp_jsgt_imm,
13253 		.nr_testruns = NR_PATTERN_RUNS,
13254 	},
13255 	{
13256 		"JMP_JSGE_K: all immediate value magnitudes",
13257 		{ },
13258 		INTERNAL | FLAG_NO_DATA,
13259 		{ },
13260 		{ { 0, 1 } },
13261 		.fill_helper = bpf_fill_jmp_jsge_imm,
13262 		.nr_testruns = NR_PATTERN_RUNS,
13263 	},
13264 	{
13265 		"JMP_JSLT_K: all immediate value magnitudes",
13266 		{ },
13267 		INTERNAL | FLAG_NO_DATA,
13268 		{ },
13269 		{ { 0, 1 } },
13270 		.fill_helper = bpf_fill_jmp_jslt_imm,
13271 		.nr_testruns = NR_PATTERN_RUNS,
13272 	},
13273 	{
13274 		"JMP_JSLE_K: all immediate value magnitudes",
13275 		{ },
13276 		INTERNAL | FLAG_NO_DATA,
13277 		{ },
13278 		{ { 0, 1 } },
13279 		.fill_helper = bpf_fill_jmp_jsle_imm,
13280 		.nr_testruns = NR_PATTERN_RUNS,
13281 	},
13282 	/* JMP register magnitudes */
13283 	{
13284 		"JMP_JSET_X: all register value magnitudes",
13285 		{ },
13286 		INTERNAL | FLAG_NO_DATA,
13287 		{ },
13288 		{ { 0, 1 } },
13289 		.fill_helper = bpf_fill_jmp_jset_reg,
13290 		.nr_testruns = NR_PATTERN_RUNS,
13291 	},
13292 	{
13293 		"JMP_JEQ_X: all register value magnitudes",
13294 		{ },
13295 		INTERNAL | FLAG_NO_DATA,
13296 		{ },
13297 		{ { 0, 1 } },
13298 		.fill_helper = bpf_fill_jmp_jeq_reg,
13299 		.nr_testruns = NR_PATTERN_RUNS,
13300 	},
13301 	{
13302 		"JMP_JNE_X: all register value magnitudes",
13303 		{ },
13304 		INTERNAL | FLAG_NO_DATA,
13305 		{ },
13306 		{ { 0, 1 } },
13307 		.fill_helper = bpf_fill_jmp_jne_reg,
13308 		.nr_testruns = NR_PATTERN_RUNS,
13309 	},
13310 	{
13311 		"JMP_JGT_X: all register value magnitudes",
13312 		{ },
13313 		INTERNAL | FLAG_NO_DATA,
13314 		{ },
13315 		{ { 0, 1 } },
13316 		.fill_helper = bpf_fill_jmp_jgt_reg,
13317 		.nr_testruns = NR_PATTERN_RUNS,
13318 	},
13319 	{
13320 		"JMP_JGE_X: all register value magnitudes",
13321 		{ },
13322 		INTERNAL | FLAG_NO_DATA,
13323 		{ },
13324 		{ { 0, 1 } },
13325 		.fill_helper = bpf_fill_jmp_jge_reg,
13326 		.nr_testruns = NR_PATTERN_RUNS,
13327 	},
13328 	{
13329 		"JMP_JLT_X: all register value magnitudes",
13330 		{ },
13331 		INTERNAL | FLAG_NO_DATA,
13332 		{ },
13333 		{ { 0, 1 } },
13334 		.fill_helper = bpf_fill_jmp_jlt_reg,
13335 		.nr_testruns = NR_PATTERN_RUNS,
13336 	},
13337 	{
13338 		"JMP_JLE_X: all register value magnitudes",
13339 		{ },
13340 		INTERNAL | FLAG_NO_DATA,
13341 		{ },
13342 		{ { 0, 1 } },
13343 		.fill_helper = bpf_fill_jmp_jle_reg,
13344 		.nr_testruns = NR_PATTERN_RUNS,
13345 	},
13346 	{
13347 		"JMP_JSGT_X: all register value magnitudes",
13348 		{ },
13349 		INTERNAL | FLAG_NO_DATA,
13350 		{ },
13351 		{ { 0, 1 } },
13352 		.fill_helper = bpf_fill_jmp_jsgt_reg,
13353 		.nr_testruns = NR_PATTERN_RUNS,
13354 	},
13355 	{
13356 		"JMP_JSGE_X: all register value magnitudes",
13357 		{ },
13358 		INTERNAL | FLAG_NO_DATA,
13359 		{ },
13360 		{ { 0, 1 } },
13361 		.fill_helper = bpf_fill_jmp_jsge_reg,
13362 		.nr_testruns = NR_PATTERN_RUNS,
13363 	},
13364 	{
13365 		"JMP_JSLT_X: all register value magnitudes",
13366 		{ },
13367 		INTERNAL | FLAG_NO_DATA,
13368 		{ },
13369 		{ { 0, 1 } },
13370 		.fill_helper = bpf_fill_jmp_jslt_reg,
13371 		.nr_testruns = NR_PATTERN_RUNS,
13372 	},
13373 	{
13374 		"JMP_JSLE_X: all register value magnitudes",
13375 		{ },
13376 		INTERNAL | FLAG_NO_DATA,
13377 		{ },
13378 		{ { 0, 1 } },
13379 		.fill_helper = bpf_fill_jmp_jsle_reg,
13380 		.nr_testruns = NR_PATTERN_RUNS,
13381 	},
13382 	/* JMP32 immediate magnitudes */
13383 	{
13384 		"JMP32_JSET_K: all immediate value magnitudes",
13385 		{ },
13386 		INTERNAL | FLAG_NO_DATA,
13387 		{ },
13388 		{ { 0, 1 } },
13389 		.fill_helper = bpf_fill_jmp32_jset_imm,
13390 		.nr_testruns = NR_PATTERN_RUNS,
13391 	},
13392 	{
13393 		"JMP32_JEQ_K: all immediate value magnitudes",
13394 		{ },
13395 		INTERNAL | FLAG_NO_DATA,
13396 		{ },
13397 		{ { 0, 1 } },
13398 		.fill_helper = bpf_fill_jmp32_jeq_imm,
13399 		.nr_testruns = NR_PATTERN_RUNS,
13400 	},
13401 	{
13402 		"JMP32_JNE_K: all immediate value magnitudes",
13403 		{ },
13404 		INTERNAL | FLAG_NO_DATA,
13405 		{ },
13406 		{ { 0, 1 } },
13407 		.fill_helper = bpf_fill_jmp32_jne_imm,
13408 		.nr_testruns = NR_PATTERN_RUNS,
13409 	},
13410 	{
13411 		"JMP32_JGT_K: all immediate value magnitudes",
13412 		{ },
13413 		INTERNAL | FLAG_NO_DATA,
13414 		{ },
13415 		{ { 0, 1 } },
13416 		.fill_helper = bpf_fill_jmp32_jgt_imm,
13417 		.nr_testruns = NR_PATTERN_RUNS,
13418 	},
13419 	{
13420 		"JMP32_JGE_K: all immediate value magnitudes",
13421 		{ },
13422 		INTERNAL | FLAG_NO_DATA,
13423 		{ },
13424 		{ { 0, 1 } },
13425 		.fill_helper = bpf_fill_jmp32_jge_imm,
13426 		.nr_testruns = NR_PATTERN_RUNS,
13427 	},
13428 	{
13429 		"JMP32_JLT_K: all immediate value magnitudes",
13430 		{ },
13431 		INTERNAL | FLAG_NO_DATA,
13432 		{ },
13433 		{ { 0, 1 } },
13434 		.fill_helper = bpf_fill_jmp32_jlt_imm,
13435 		.nr_testruns = NR_PATTERN_RUNS,
13436 	},
13437 	{
13438 		"JMP32_JLE_K: all immediate value magnitudes",
13439 		{ },
13440 		INTERNAL | FLAG_NO_DATA,
13441 		{ },
13442 		{ { 0, 1 } },
13443 		.fill_helper = bpf_fill_jmp32_jle_imm,
13444 		.nr_testruns = NR_PATTERN_RUNS,
13445 	},
13446 	{
13447 		"JMP32_JSGT_K: all immediate value magnitudes",
13448 		{ },
13449 		INTERNAL | FLAG_NO_DATA,
13450 		{ },
13451 		{ { 0, 1 } },
13452 		.fill_helper = bpf_fill_jmp32_jsgt_imm,
13453 		.nr_testruns = NR_PATTERN_RUNS,
13454 	},
13455 	{
13456 		"JMP32_JSGE_K: all immediate value magnitudes",
13457 		{ },
13458 		INTERNAL | FLAG_NO_DATA,
13459 		{ },
13460 		{ { 0, 1 } },
13461 		.fill_helper = bpf_fill_jmp32_jsge_imm,
13462 		.nr_testruns = NR_PATTERN_RUNS,
13463 	},
13464 	{
13465 		"JMP32_JSLT_K: all immediate value magnitudes",
13466 		{ },
13467 		INTERNAL | FLAG_NO_DATA,
13468 		{ },
13469 		{ { 0, 1 } },
13470 		.fill_helper = bpf_fill_jmp32_jslt_imm,
13471 		.nr_testruns = NR_PATTERN_RUNS,
13472 	},
13473 	{
13474 		"JMP32_JSLE_K: all immediate value magnitudes",
13475 		{ },
13476 		INTERNAL | FLAG_NO_DATA,
13477 		{ },
13478 		{ { 0, 1 } },
13479 		.fill_helper = bpf_fill_jmp32_jsle_imm,
13480 		.nr_testruns = NR_PATTERN_RUNS,
13481 	},
13482 	/* JMP32 register magnitudes */
13483 	{
13484 		"JMP32_JSET_X: all register value magnitudes",
13485 		{ },
13486 		INTERNAL | FLAG_NO_DATA,
13487 		{ },
13488 		{ { 0, 1 } },
13489 		.fill_helper = bpf_fill_jmp32_jset_reg,
13490 		.nr_testruns = NR_PATTERN_RUNS,
13491 	},
13492 	{
13493 		"JMP32_JEQ_X: all register value magnitudes",
13494 		{ },
13495 		INTERNAL | FLAG_NO_DATA,
13496 		{ },
13497 		{ { 0, 1 } },
13498 		.fill_helper = bpf_fill_jmp32_jeq_reg,
13499 		.nr_testruns = NR_PATTERN_RUNS,
13500 	},
13501 	{
13502 		"JMP32_JNE_X: all register value magnitudes",
13503 		{ },
13504 		INTERNAL | FLAG_NO_DATA,
13505 		{ },
13506 		{ { 0, 1 } },
13507 		.fill_helper = bpf_fill_jmp32_jne_reg,
13508 		.nr_testruns = NR_PATTERN_RUNS,
13509 	},
13510 	{
13511 		"JMP32_JGT_X: all register value magnitudes",
13512 		{ },
13513 		INTERNAL | FLAG_NO_DATA,
13514 		{ },
13515 		{ { 0, 1 } },
13516 		.fill_helper = bpf_fill_jmp32_jgt_reg,
13517 		.nr_testruns = NR_PATTERN_RUNS,
13518 	},
13519 	{
13520 		"JMP32_JGE_X: all register value magnitudes",
13521 		{ },
13522 		INTERNAL | FLAG_NO_DATA,
13523 		{ },
13524 		{ { 0, 1 } },
13525 		.fill_helper = bpf_fill_jmp32_jge_reg,
13526 		.nr_testruns = NR_PATTERN_RUNS,
13527 	},
13528 	{
13529 		"JMP32_JLT_X: all register value magnitudes",
13530 		{ },
13531 		INTERNAL | FLAG_NO_DATA,
13532 		{ },
13533 		{ { 0, 1 } },
13534 		.fill_helper = bpf_fill_jmp32_jlt_reg,
13535 		.nr_testruns = NR_PATTERN_RUNS,
13536 	},
13537 	{
13538 		"JMP32_JLE_X: all register value magnitudes",
13539 		{ },
13540 		INTERNAL | FLAG_NO_DATA,
13541 		{ },
13542 		{ { 0, 1 } },
13543 		.fill_helper = bpf_fill_jmp32_jle_reg,
13544 		.nr_testruns = NR_PATTERN_RUNS,
13545 	},
13546 	{
13547 		"JMP32_JSGT_X: all register value magnitudes",
13548 		{ },
13549 		INTERNAL | FLAG_NO_DATA,
13550 		{ },
13551 		{ { 0, 1 } },
13552 		.fill_helper = bpf_fill_jmp32_jsgt_reg,
13553 		.nr_testruns = NR_PATTERN_RUNS,
13554 	},
13555 	{
13556 		"JMP32_JSGE_X: all register value magnitudes",
13557 		{ },
13558 		INTERNAL | FLAG_NO_DATA,
13559 		{ },
13560 		{ { 0, 1 } },
13561 		.fill_helper = bpf_fill_jmp32_jsge_reg,
13562 		.nr_testruns = NR_PATTERN_RUNS,
13563 	},
13564 	{
13565 		"JMP32_JSLT_X: all register value magnitudes",
13566 		{ },
13567 		INTERNAL | FLAG_NO_DATA,
13568 		{ },
13569 		{ { 0, 1 } },
13570 		.fill_helper = bpf_fill_jmp32_jslt_reg,
13571 		.nr_testruns = NR_PATTERN_RUNS,
13572 	},
13573 	{
13574 		"JMP32_JSLE_X: all register value magnitudes",
13575 		{ },
13576 		INTERNAL | FLAG_NO_DATA,
13577 		{ },
13578 		{ { 0, 1 } },
13579 		.fill_helper = bpf_fill_jmp32_jsle_reg,
13580 		.nr_testruns = NR_PATTERN_RUNS,
13581 	},
13582 	/* Conditional jumps with constant decision */
13583 	{
13584 		"JMP_JSET_K: imm = 0 -> never taken",
13585 		.u.insns_int = {
13586 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13587 			BPF_JMP_IMM(BPF_JSET, R1, 0, 1),
13588 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13589 			BPF_EXIT_INSN(),
13590 		},
13591 		INTERNAL | FLAG_NO_DATA,
13592 		{ },
13593 		{ { 0, 0 } },
13594 	},
13595 	{
13596 		"JMP_JLT_K: imm = 0 -> never taken",
13597 		.u.insns_int = {
13598 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13599 			BPF_JMP_IMM(BPF_JLT, R1, 0, 1),
13600 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13601 			BPF_EXIT_INSN(),
13602 		},
13603 		INTERNAL | FLAG_NO_DATA,
13604 		{ },
13605 		{ { 0, 0 } },
13606 	},
13607 	{
13608 		"JMP_JGE_K: imm = 0 -> always taken",
13609 		.u.insns_int = {
13610 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13611 			BPF_JMP_IMM(BPF_JGE, R1, 0, 1),
13612 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13613 			BPF_EXIT_INSN(),
13614 		},
13615 		INTERNAL | FLAG_NO_DATA,
13616 		{ },
13617 		{ { 0, 1 } },
13618 	},
13619 	{
13620 		"JMP_JGT_K: imm = 0xffffffff -> never taken",
13621 		.u.insns_int = {
13622 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13623 			BPF_JMP_IMM(BPF_JGT, R1, U32_MAX, 1),
13624 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13625 			BPF_EXIT_INSN(),
13626 		},
13627 		INTERNAL | FLAG_NO_DATA,
13628 		{ },
13629 		{ { 0, 0 } },
13630 	},
13631 	{
13632 		"JMP_JLE_K: imm = 0xffffffff -> always taken",
13633 		.u.insns_int = {
13634 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13635 			BPF_JMP_IMM(BPF_JLE, R1, U32_MAX, 1),
13636 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13637 			BPF_EXIT_INSN(),
13638 		},
13639 		INTERNAL | FLAG_NO_DATA,
13640 		{ },
13641 		{ { 0, 1 } },
13642 	},
13643 	{
13644 		"JMP32_JSGT_K: imm = 0x7fffffff -> never taken",
13645 		.u.insns_int = {
13646 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13647 			BPF_JMP32_IMM(BPF_JSGT, R1, S32_MAX, 1),
13648 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13649 			BPF_EXIT_INSN(),
13650 		},
13651 		INTERNAL | FLAG_NO_DATA,
13652 		{ },
13653 		{ { 0, 0 } },
13654 	},
13655 	{
13656 		"JMP32_JSGE_K: imm = -0x80000000 -> always taken",
13657 		.u.insns_int = {
13658 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13659 			BPF_JMP32_IMM(BPF_JSGE, R1, S32_MIN, 1),
13660 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13661 			BPF_EXIT_INSN(),
13662 		},
13663 		INTERNAL | FLAG_NO_DATA,
13664 		{ },
13665 		{ { 0, 1 } },
13666 	},
13667 	{
13668 		"JMP32_JSLT_K: imm = -0x80000000 -> never taken",
13669 		.u.insns_int = {
13670 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13671 			BPF_JMP32_IMM(BPF_JSLT, R1, S32_MIN, 1),
13672 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13673 			BPF_EXIT_INSN(),
13674 		},
13675 		INTERNAL | FLAG_NO_DATA,
13676 		{ },
13677 		{ { 0, 0 } },
13678 	},
13679 	{
13680 		"JMP32_JSLE_K: imm = 0x7fffffff -> always taken",
13681 		.u.insns_int = {
13682 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13683 			BPF_JMP32_IMM(BPF_JSLE, R1, S32_MAX, 1),
13684 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13685 			BPF_EXIT_INSN(),
13686 		},
13687 		INTERNAL | FLAG_NO_DATA,
13688 		{ },
13689 		{ { 0, 1 } },
13690 	},
13691 	{
13692 		"JMP_JEQ_X: dst = src -> always taken",
13693 		.u.insns_int = {
13694 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13695 			BPF_JMP_REG(BPF_JEQ, R1, R1, 1),
13696 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13697 			BPF_EXIT_INSN(),
13698 		},
13699 		INTERNAL | FLAG_NO_DATA,
13700 		{ },
13701 		{ { 0, 1 } },
13702 	},
13703 	{
13704 		"JMP_JGE_X: dst = src -> always taken",
13705 		.u.insns_int = {
13706 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13707 			BPF_JMP_REG(BPF_JGE, R1, R1, 1),
13708 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13709 			BPF_EXIT_INSN(),
13710 		},
13711 		INTERNAL | FLAG_NO_DATA,
13712 		{ },
13713 		{ { 0, 1 } },
13714 	},
13715 	{
13716 		"JMP_JLE_X: dst = src -> always taken",
13717 		.u.insns_int = {
13718 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13719 			BPF_JMP_REG(BPF_JLE, R1, R1, 1),
13720 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13721 			BPF_EXIT_INSN(),
13722 		},
13723 		INTERNAL | FLAG_NO_DATA,
13724 		{ },
13725 		{ { 0, 1 } },
13726 	},
13727 	{
13728 		"JMP_JSGE_X: dst = src -> always taken",
13729 		.u.insns_int = {
13730 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13731 			BPF_JMP_REG(BPF_JSGE, R1, R1, 1),
13732 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13733 			BPF_EXIT_INSN(),
13734 		},
13735 		INTERNAL | FLAG_NO_DATA,
13736 		{ },
13737 		{ { 0, 1 } },
13738 	},
13739 	{
13740 		"JMP_JSLE_X: dst = src -> always taken",
13741 		.u.insns_int = {
13742 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13743 			BPF_JMP_REG(BPF_JSLE, R1, R1, 1),
13744 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13745 			BPF_EXIT_INSN(),
13746 		},
13747 		INTERNAL | FLAG_NO_DATA,
13748 		{ },
13749 		{ { 0, 1 } },
13750 	},
13751 	{
13752 		"JMP_JNE_X: dst = src -> never taken",
13753 		.u.insns_int = {
13754 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13755 			BPF_JMP_REG(BPF_JNE, R1, R1, 1),
13756 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13757 			BPF_EXIT_INSN(),
13758 		},
13759 		INTERNAL | FLAG_NO_DATA,
13760 		{ },
13761 		{ { 0, 0 } },
13762 	},
13763 	{
13764 		"JMP_JGT_X: dst = src -> never taken",
13765 		.u.insns_int = {
13766 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13767 			BPF_JMP_REG(BPF_JGT, R1, R1, 1),
13768 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13769 			BPF_EXIT_INSN(),
13770 		},
13771 		INTERNAL | FLAG_NO_DATA,
13772 		{ },
13773 		{ { 0, 0 } },
13774 	},
13775 	{
13776 		"JMP_JLT_X: dst = src -> never taken",
13777 		.u.insns_int = {
13778 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13779 			BPF_JMP_REG(BPF_JLT, R1, R1, 1),
13780 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13781 			BPF_EXIT_INSN(),
13782 		},
13783 		INTERNAL | FLAG_NO_DATA,
13784 		{ },
13785 		{ { 0, 0 } },
13786 	},
13787 	{
13788 		"JMP_JSGT_X: dst = src -> never taken",
13789 		.u.insns_int = {
13790 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13791 			BPF_JMP_REG(BPF_JSGT, R1, R1, 1),
13792 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13793 			BPF_EXIT_INSN(),
13794 		},
13795 		INTERNAL | FLAG_NO_DATA,
13796 		{ },
13797 		{ { 0, 0 } },
13798 	},
13799 	{
13800 		"JMP_JSLT_X: dst = src -> never taken",
13801 		.u.insns_int = {
13802 			BPF_ALU64_IMM(BPF_MOV, R0, 1),
13803 			BPF_JMP_REG(BPF_JSLT, R1, R1, 1),
13804 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13805 			BPF_EXIT_INSN(),
13806 		},
13807 		INTERNAL | FLAG_NO_DATA,
13808 		{ },
13809 		{ { 0, 0 } },
13810 	},
13811 	/* Short relative jumps */
13812 	{
13813 		"Short relative jump: offset=0",
13814 		.u.insns_int = {
13815 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13816 			BPF_JMP_IMM(BPF_JEQ, R0, 0, 0),
13817 			BPF_EXIT_INSN(),
13818 			BPF_ALU32_IMM(BPF_MOV, R0, -1),
13819 		},
13820 		INTERNAL | FLAG_NO_DATA | FLAG_VERIFIER_ZEXT,
13821 		{ },
13822 		{ { 0, 0 } },
13823 	},
13824 	{
13825 		"Short relative jump: offset=1",
13826 		.u.insns_int = {
13827 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13828 			BPF_JMP_IMM(BPF_JEQ, R0, 0, 1),
13829 			BPF_ALU32_IMM(BPF_ADD, R0, 1),
13830 			BPF_EXIT_INSN(),
13831 			BPF_ALU32_IMM(BPF_MOV, R0, -1),
13832 		},
13833 		INTERNAL | FLAG_NO_DATA | FLAG_VERIFIER_ZEXT,
13834 		{ },
13835 		{ { 0, 0 } },
13836 	},
13837 	{
13838 		"Short relative jump: offset=2",
13839 		.u.insns_int = {
13840 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13841 			BPF_JMP_IMM(BPF_JEQ, R0, 0, 2),
13842 			BPF_ALU32_IMM(BPF_ADD, R0, 1),
13843 			BPF_ALU32_IMM(BPF_ADD, R0, 1),
13844 			BPF_EXIT_INSN(),
13845 			BPF_ALU32_IMM(BPF_MOV, R0, -1),
13846 		},
13847 		INTERNAL | FLAG_NO_DATA | FLAG_VERIFIER_ZEXT,
13848 		{ },
13849 		{ { 0, 0 } },
13850 	},
13851 	{
13852 		"Short relative jump: offset=3",
13853 		.u.insns_int = {
13854 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13855 			BPF_JMP_IMM(BPF_JEQ, R0, 0, 3),
13856 			BPF_ALU32_IMM(BPF_ADD, R0, 1),
13857 			BPF_ALU32_IMM(BPF_ADD, R0, 1),
13858 			BPF_ALU32_IMM(BPF_ADD, R0, 1),
13859 			BPF_EXIT_INSN(),
13860 			BPF_ALU32_IMM(BPF_MOV, R0, -1),
13861 		},
13862 		INTERNAL | FLAG_NO_DATA | FLAG_VERIFIER_ZEXT,
13863 		{ },
13864 		{ { 0, 0 } },
13865 	},
13866 	{
13867 		"Short relative jump: offset=4",
13868 		.u.insns_int = {
13869 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
13870 			BPF_JMP_IMM(BPF_JEQ, R0, 0, 4),
13871 			BPF_ALU32_IMM(BPF_ADD, R0, 1),
13872 			BPF_ALU32_IMM(BPF_ADD, R0, 1),
13873 			BPF_ALU32_IMM(BPF_ADD, R0, 1),
13874 			BPF_ALU32_IMM(BPF_ADD, R0, 1),
13875 			BPF_EXIT_INSN(),
13876 			BPF_ALU32_IMM(BPF_MOV, R0, -1),
13877 		},
13878 		INTERNAL | FLAG_NO_DATA | FLAG_VERIFIER_ZEXT,
13879 		{ },
13880 		{ { 0, 0 } },
13881 	},
13882 	/* Conditional branch conversions */
13883 	{
13884 		"Long conditional jump: taken at runtime",
13885 		{ },
13886 		INTERNAL | FLAG_NO_DATA,
13887 		{ },
13888 		{ { 0, 1 } },
13889 		.fill_helper = bpf_fill_max_jmp_taken,
13890 	},
13891 	{
13892 		"Long conditional jump: not taken at runtime",
13893 		{ },
13894 		INTERNAL | FLAG_NO_DATA,
13895 		{ },
13896 		{ { 0, 2 } },
13897 		.fill_helper = bpf_fill_max_jmp_not_taken,
13898 	},
13899 	{
13900 		"Long conditional jump: always taken, known at JIT time",
13901 		{ },
13902 		INTERNAL | FLAG_NO_DATA,
13903 		{ },
13904 		{ { 0, 1 } },
13905 		.fill_helper = bpf_fill_max_jmp_always_taken,
13906 	},
13907 	{
13908 		"Long conditional jump: never taken, known at JIT time",
13909 		{ },
13910 		INTERNAL | FLAG_NO_DATA,
13911 		{ },
13912 		{ { 0, 2 } },
13913 		.fill_helper = bpf_fill_max_jmp_never_taken,
13914 	},
13915 	/* Staggered jump sequences, immediate */
13916 	{
13917 		"Staggered jumps: JMP_JA",
13918 		{ },
13919 		INTERNAL | FLAG_NO_DATA,
13920 		{ },
13921 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
13922 		.fill_helper = bpf_fill_staggered_ja,
13923 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
13924 	},
13925 	{
13926 		"Staggered jumps: JMP_JEQ_K",
13927 		{ },
13928 		INTERNAL | FLAG_NO_DATA,
13929 		{ },
13930 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
13931 		.fill_helper = bpf_fill_staggered_jeq_imm,
13932 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
13933 	},
13934 	{
13935 		"Staggered jumps: JMP_JNE_K",
13936 		{ },
13937 		INTERNAL | FLAG_NO_DATA,
13938 		{ },
13939 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
13940 		.fill_helper = bpf_fill_staggered_jne_imm,
13941 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
13942 	},
13943 	{
13944 		"Staggered jumps: JMP_JSET_K",
13945 		{ },
13946 		INTERNAL | FLAG_NO_DATA,
13947 		{ },
13948 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
13949 		.fill_helper = bpf_fill_staggered_jset_imm,
13950 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
13951 	},
13952 	{
13953 		"Staggered jumps: JMP_JGT_K",
13954 		{ },
13955 		INTERNAL | FLAG_NO_DATA,
13956 		{ },
13957 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
13958 		.fill_helper = bpf_fill_staggered_jgt_imm,
13959 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
13960 	},
13961 	{
13962 		"Staggered jumps: JMP_JGE_K",
13963 		{ },
13964 		INTERNAL | FLAG_NO_DATA,
13965 		{ },
13966 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
13967 		.fill_helper = bpf_fill_staggered_jge_imm,
13968 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
13969 	},
13970 	{
13971 		"Staggered jumps: JMP_JLT_K",
13972 		{ },
13973 		INTERNAL | FLAG_NO_DATA,
13974 		{ },
13975 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
13976 		.fill_helper = bpf_fill_staggered_jlt_imm,
13977 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
13978 	},
13979 	{
13980 		"Staggered jumps: JMP_JLE_K",
13981 		{ },
13982 		INTERNAL | FLAG_NO_DATA,
13983 		{ },
13984 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
13985 		.fill_helper = bpf_fill_staggered_jle_imm,
13986 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
13987 	},
13988 	{
13989 		"Staggered jumps: JMP_JSGT_K",
13990 		{ },
13991 		INTERNAL | FLAG_NO_DATA,
13992 		{ },
13993 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
13994 		.fill_helper = bpf_fill_staggered_jsgt_imm,
13995 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
13996 	},
13997 	{
13998 		"Staggered jumps: JMP_JSGE_K",
13999 		{ },
14000 		INTERNAL | FLAG_NO_DATA,
14001 		{ },
14002 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14003 		.fill_helper = bpf_fill_staggered_jsge_imm,
14004 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14005 	},
14006 	{
14007 		"Staggered jumps: JMP_JSLT_K",
14008 		{ },
14009 		INTERNAL | FLAG_NO_DATA,
14010 		{ },
14011 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14012 		.fill_helper = bpf_fill_staggered_jslt_imm,
14013 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14014 	},
14015 	{
14016 		"Staggered jumps: JMP_JSLE_K",
14017 		{ },
14018 		INTERNAL | FLAG_NO_DATA,
14019 		{ },
14020 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14021 		.fill_helper = bpf_fill_staggered_jsle_imm,
14022 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14023 	},
14024 	/* Staggered jump sequences, register */
14025 	{
14026 		"Staggered jumps: JMP_JEQ_X",
14027 		{ },
14028 		INTERNAL | FLAG_NO_DATA,
14029 		{ },
14030 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14031 		.fill_helper = bpf_fill_staggered_jeq_reg,
14032 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14033 	},
14034 	{
14035 		"Staggered jumps: JMP_JNE_X",
14036 		{ },
14037 		INTERNAL | FLAG_NO_DATA,
14038 		{ },
14039 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14040 		.fill_helper = bpf_fill_staggered_jne_reg,
14041 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14042 	},
14043 	{
14044 		"Staggered jumps: JMP_JSET_X",
14045 		{ },
14046 		INTERNAL | FLAG_NO_DATA,
14047 		{ },
14048 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14049 		.fill_helper = bpf_fill_staggered_jset_reg,
14050 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14051 	},
14052 	{
14053 		"Staggered jumps: JMP_JGT_X",
14054 		{ },
14055 		INTERNAL | FLAG_NO_DATA,
14056 		{ },
14057 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14058 		.fill_helper = bpf_fill_staggered_jgt_reg,
14059 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14060 	},
14061 	{
14062 		"Staggered jumps: JMP_JGE_X",
14063 		{ },
14064 		INTERNAL | FLAG_NO_DATA,
14065 		{ },
14066 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14067 		.fill_helper = bpf_fill_staggered_jge_reg,
14068 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14069 	},
14070 	{
14071 		"Staggered jumps: JMP_JLT_X",
14072 		{ },
14073 		INTERNAL | FLAG_NO_DATA,
14074 		{ },
14075 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14076 		.fill_helper = bpf_fill_staggered_jlt_reg,
14077 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14078 	},
14079 	{
14080 		"Staggered jumps: JMP_JLE_X",
14081 		{ },
14082 		INTERNAL | FLAG_NO_DATA,
14083 		{ },
14084 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14085 		.fill_helper = bpf_fill_staggered_jle_reg,
14086 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14087 	},
14088 	{
14089 		"Staggered jumps: JMP_JSGT_X",
14090 		{ },
14091 		INTERNAL | FLAG_NO_DATA,
14092 		{ },
14093 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14094 		.fill_helper = bpf_fill_staggered_jsgt_reg,
14095 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14096 	},
14097 	{
14098 		"Staggered jumps: JMP_JSGE_X",
14099 		{ },
14100 		INTERNAL | FLAG_NO_DATA,
14101 		{ },
14102 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14103 		.fill_helper = bpf_fill_staggered_jsge_reg,
14104 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14105 	},
14106 	{
14107 		"Staggered jumps: JMP_JSLT_X",
14108 		{ },
14109 		INTERNAL | FLAG_NO_DATA,
14110 		{ },
14111 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14112 		.fill_helper = bpf_fill_staggered_jslt_reg,
14113 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14114 	},
14115 	{
14116 		"Staggered jumps: JMP_JSLE_X",
14117 		{ },
14118 		INTERNAL | FLAG_NO_DATA,
14119 		{ },
14120 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14121 		.fill_helper = bpf_fill_staggered_jsle_reg,
14122 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14123 	},
14124 	/* Staggered jump sequences, JMP32 immediate */
14125 	{
14126 		"Staggered jumps: JMP32_JEQ_K",
14127 		{ },
14128 		INTERNAL | FLAG_NO_DATA,
14129 		{ },
14130 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14131 		.fill_helper = bpf_fill_staggered_jeq32_imm,
14132 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14133 	},
14134 	{
14135 		"Staggered jumps: JMP32_JNE_K",
14136 		{ },
14137 		INTERNAL | FLAG_NO_DATA,
14138 		{ },
14139 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14140 		.fill_helper = bpf_fill_staggered_jne32_imm,
14141 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14142 	},
14143 	{
14144 		"Staggered jumps: JMP32_JSET_K",
14145 		{ },
14146 		INTERNAL | FLAG_NO_DATA,
14147 		{ },
14148 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14149 		.fill_helper = bpf_fill_staggered_jset32_imm,
14150 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14151 	},
14152 	{
14153 		"Staggered jumps: JMP32_JGT_K",
14154 		{ },
14155 		INTERNAL | FLAG_NO_DATA,
14156 		{ },
14157 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14158 		.fill_helper = bpf_fill_staggered_jgt32_imm,
14159 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14160 	},
14161 	{
14162 		"Staggered jumps: JMP32_JGE_K",
14163 		{ },
14164 		INTERNAL | FLAG_NO_DATA,
14165 		{ },
14166 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14167 		.fill_helper = bpf_fill_staggered_jge32_imm,
14168 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14169 	},
14170 	{
14171 		"Staggered jumps: JMP32_JLT_K",
14172 		{ },
14173 		INTERNAL | FLAG_NO_DATA,
14174 		{ },
14175 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14176 		.fill_helper = bpf_fill_staggered_jlt32_imm,
14177 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14178 	},
14179 	{
14180 		"Staggered jumps: JMP32_JLE_K",
14181 		{ },
14182 		INTERNAL | FLAG_NO_DATA,
14183 		{ },
14184 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14185 		.fill_helper = bpf_fill_staggered_jle32_imm,
14186 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14187 	},
14188 	{
14189 		"Staggered jumps: JMP32_JSGT_K",
14190 		{ },
14191 		INTERNAL | FLAG_NO_DATA,
14192 		{ },
14193 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14194 		.fill_helper = bpf_fill_staggered_jsgt32_imm,
14195 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14196 	},
14197 	{
14198 		"Staggered jumps: JMP32_JSGE_K",
14199 		{ },
14200 		INTERNAL | FLAG_NO_DATA,
14201 		{ },
14202 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14203 		.fill_helper = bpf_fill_staggered_jsge32_imm,
14204 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14205 	},
14206 	{
14207 		"Staggered jumps: JMP32_JSLT_K",
14208 		{ },
14209 		INTERNAL | FLAG_NO_DATA,
14210 		{ },
14211 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14212 		.fill_helper = bpf_fill_staggered_jslt32_imm,
14213 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14214 	},
14215 	{
14216 		"Staggered jumps: JMP32_JSLE_K",
14217 		{ },
14218 		INTERNAL | FLAG_NO_DATA,
14219 		{ },
14220 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14221 		.fill_helper = bpf_fill_staggered_jsle32_imm,
14222 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14223 	},
14224 	/* Staggered jump sequences, JMP32 register */
14225 	{
14226 		"Staggered jumps: JMP32_JEQ_X",
14227 		{ },
14228 		INTERNAL | FLAG_NO_DATA,
14229 		{ },
14230 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14231 		.fill_helper = bpf_fill_staggered_jeq32_reg,
14232 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14233 	},
14234 	{
14235 		"Staggered jumps: JMP32_JNE_X",
14236 		{ },
14237 		INTERNAL | FLAG_NO_DATA,
14238 		{ },
14239 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14240 		.fill_helper = bpf_fill_staggered_jne32_reg,
14241 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14242 	},
14243 	{
14244 		"Staggered jumps: JMP32_JSET_X",
14245 		{ },
14246 		INTERNAL | FLAG_NO_DATA,
14247 		{ },
14248 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14249 		.fill_helper = bpf_fill_staggered_jset32_reg,
14250 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14251 	},
14252 	{
14253 		"Staggered jumps: JMP32_JGT_X",
14254 		{ },
14255 		INTERNAL | FLAG_NO_DATA,
14256 		{ },
14257 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14258 		.fill_helper = bpf_fill_staggered_jgt32_reg,
14259 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14260 	},
14261 	{
14262 		"Staggered jumps: JMP32_JGE_X",
14263 		{ },
14264 		INTERNAL | FLAG_NO_DATA,
14265 		{ },
14266 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14267 		.fill_helper = bpf_fill_staggered_jge32_reg,
14268 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14269 	},
14270 	{
14271 		"Staggered jumps: JMP32_JLT_X",
14272 		{ },
14273 		INTERNAL | FLAG_NO_DATA,
14274 		{ },
14275 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14276 		.fill_helper = bpf_fill_staggered_jlt32_reg,
14277 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14278 	},
14279 	{
14280 		"Staggered jumps: JMP32_JLE_X",
14281 		{ },
14282 		INTERNAL | FLAG_NO_DATA,
14283 		{ },
14284 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14285 		.fill_helper = bpf_fill_staggered_jle32_reg,
14286 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14287 	},
14288 	{
14289 		"Staggered jumps: JMP32_JSGT_X",
14290 		{ },
14291 		INTERNAL | FLAG_NO_DATA,
14292 		{ },
14293 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14294 		.fill_helper = bpf_fill_staggered_jsgt32_reg,
14295 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14296 	},
14297 	{
14298 		"Staggered jumps: JMP32_JSGE_X",
14299 		{ },
14300 		INTERNAL | FLAG_NO_DATA,
14301 		{ },
14302 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14303 		.fill_helper = bpf_fill_staggered_jsge32_reg,
14304 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14305 	},
14306 	{
14307 		"Staggered jumps: JMP32_JSLT_X",
14308 		{ },
14309 		INTERNAL | FLAG_NO_DATA,
14310 		{ },
14311 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14312 		.fill_helper = bpf_fill_staggered_jslt32_reg,
14313 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14314 	},
14315 	{
14316 		"Staggered jumps: JMP32_JSLE_X",
14317 		{ },
14318 		INTERNAL | FLAG_NO_DATA,
14319 		{ },
14320 		{ { 0, MAX_STAGGERED_JMP_SIZE + 1 } },
14321 		.fill_helper = bpf_fill_staggered_jsle32_reg,
14322 		.nr_testruns = NR_STAGGERED_JMP_RUNS,
14323 	},
14324 };
14325 
14326 static struct net_device dev;
14327 
populate_skb(char * buf,int size)14328 static struct sk_buff *populate_skb(char *buf, int size)
14329 {
14330 	struct sk_buff *skb;
14331 
14332 	if (size >= MAX_DATA)
14333 		return NULL;
14334 
14335 	skb = alloc_skb(MAX_DATA, GFP_KERNEL);
14336 	if (!skb)
14337 		return NULL;
14338 
14339 	__skb_put_data(skb, buf, size);
14340 
14341 	/* Initialize a fake skb with test pattern. */
14342 	skb_reset_mac_header(skb);
14343 	skb->protocol = htons(ETH_P_IP);
14344 	skb->pkt_type = SKB_TYPE;
14345 	skb->mark = SKB_MARK;
14346 	skb->hash = SKB_HASH;
14347 	skb->queue_mapping = SKB_QUEUE_MAP;
14348 	skb->vlan_tci = SKB_VLAN_TCI;
14349 	skb->vlan_proto = htons(ETH_P_IP);
14350 	dev_net_set(&dev, &init_net);
14351 	skb->dev = &dev;
14352 	skb->dev->ifindex = SKB_DEV_IFINDEX;
14353 	skb->dev->type = SKB_DEV_TYPE;
14354 	skb_set_network_header(skb, min(size, ETH_HLEN));
14355 
14356 	return skb;
14357 }
14358 
generate_test_data(struct bpf_test * test,int sub)14359 static void *generate_test_data(struct bpf_test *test, int sub)
14360 {
14361 	struct sk_buff *skb;
14362 	struct page *page;
14363 
14364 	if (test->aux & FLAG_NO_DATA)
14365 		return NULL;
14366 
14367 	if (test->aux & FLAG_LARGE_MEM)
14368 		return kmalloc(test->test[sub].data_size, GFP_KERNEL);
14369 
14370 	/* Test case expects an skb, so populate one. Various
14371 	 * subtests generate skbs of different sizes based on
14372 	 * the same data.
14373 	 */
14374 	skb = populate_skb(test->data, test->test[sub].data_size);
14375 	if (!skb)
14376 		return NULL;
14377 
14378 	if (test->aux & FLAG_SKB_FRAG) {
14379 		/*
14380 		 * when the test requires a fragmented skb, add a
14381 		 * single fragment to the skb, filled with
14382 		 * test->frag_data.
14383 		 */
14384 		page = alloc_page(GFP_KERNEL);
14385 		if (!page)
14386 			goto err_kfree_skb;
14387 
14388 		memcpy(page_address(page), test->frag_data, MAX_DATA);
14389 		skb_add_rx_frag(skb, 0, page, 0, MAX_DATA, MAX_DATA);
14390 	}
14391 
14392 	return skb;
14393 err_kfree_skb:
14394 	kfree_skb(skb);
14395 	return NULL;
14396 }
14397 
release_test_data(const struct bpf_test * test,void * data)14398 static void release_test_data(const struct bpf_test *test, void *data)
14399 {
14400 	if (test->aux & FLAG_NO_DATA)
14401 		return;
14402 
14403 	if (test->aux & FLAG_LARGE_MEM)
14404 		kfree(data);
14405 	else
14406 		kfree_skb(data);
14407 }
14408 
filter_length(int which)14409 static int filter_length(int which)
14410 {
14411 	struct sock_filter *fp;
14412 	int len;
14413 
14414 	if (tests[which].fill_helper)
14415 		return tests[which].u.ptr.len;
14416 
14417 	fp = tests[which].u.insns;
14418 	for (len = MAX_INSNS - 1; len > 0; --len)
14419 		if (fp[len].code != 0 || fp[len].k != 0)
14420 			break;
14421 
14422 	return len + 1;
14423 }
14424 
filter_pointer(int which)14425 static void *filter_pointer(int which)
14426 {
14427 	if (tests[which].fill_helper)
14428 		return tests[which].u.ptr.insns;
14429 	else
14430 		return tests[which].u.insns;
14431 }
14432 
generate_filter(int which,int * err)14433 static struct bpf_prog *generate_filter(int which, int *err)
14434 {
14435 	__u8 test_type = tests[which].aux & TEST_TYPE_MASK;
14436 	unsigned int flen = filter_length(which);
14437 	void *fptr = filter_pointer(which);
14438 	struct sock_fprog_kern fprog;
14439 	struct bpf_prog *fp;
14440 
14441 	switch (test_type) {
14442 	case CLASSIC:
14443 		fprog.filter = fptr;
14444 		fprog.len = flen;
14445 
14446 		*err = bpf_prog_create(&fp, &fprog);
14447 		if (tests[which].aux & FLAG_EXPECTED_FAIL) {
14448 			if (*err == tests[which].expected_errcode) {
14449 				pr_cont("PASS\n");
14450 				/* Verifier rejected filter as expected. */
14451 				*err = 0;
14452 				return NULL;
14453 			} else {
14454 				pr_cont("UNEXPECTED_PASS\n");
14455 				/* Verifier didn't reject the test that's
14456 				 * bad enough, just return!
14457 				 */
14458 				*err = -EINVAL;
14459 				return NULL;
14460 			}
14461 		}
14462 		if (*err) {
14463 			pr_cont("FAIL to prog_create err=%d len=%d\n",
14464 				*err, fprog.len);
14465 			return NULL;
14466 		}
14467 		break;
14468 
14469 	case INTERNAL:
14470 		fp = bpf_prog_alloc(bpf_prog_size(flen), 0);
14471 		if (fp == NULL) {
14472 			pr_cont("UNEXPECTED_FAIL no memory left\n");
14473 			*err = -ENOMEM;
14474 			return NULL;
14475 		}
14476 
14477 		fp->len = flen;
14478 		/* Type doesn't really matter here as long as it's not unspec. */
14479 		fp->type = BPF_PROG_TYPE_SOCKET_FILTER;
14480 		memcpy(fp->insnsi, fptr, fp->len * sizeof(struct bpf_insn));
14481 		fp->aux->stack_depth = tests[which].stack_depth;
14482 		fp->aux->verifier_zext = !!(tests[which].aux &
14483 					    FLAG_VERIFIER_ZEXT);
14484 
14485 		/* We cannot error here as we don't need type compatibility
14486 		 * checks.
14487 		 */
14488 		fp = bpf_prog_select_runtime(fp, err);
14489 		if (*err) {
14490 			pr_cont("FAIL to select_runtime err=%d\n", *err);
14491 			return NULL;
14492 		}
14493 		break;
14494 	}
14495 
14496 	*err = 0;
14497 	return fp;
14498 }
14499 
release_filter(struct bpf_prog * fp,int which)14500 static void release_filter(struct bpf_prog *fp, int which)
14501 {
14502 	__u8 test_type = tests[which].aux & TEST_TYPE_MASK;
14503 
14504 	switch (test_type) {
14505 	case CLASSIC:
14506 		bpf_prog_destroy(fp);
14507 		break;
14508 	case INTERNAL:
14509 		bpf_prog_free(fp);
14510 		break;
14511 	}
14512 }
14513 
__run_one(const struct bpf_prog * fp,const void * data,int runs,u64 * duration)14514 static int __run_one(const struct bpf_prog *fp, const void *data,
14515 		     int runs, u64 *duration)
14516 {
14517 	u64 start, finish;
14518 	int ret = 0, i;
14519 
14520 	migrate_disable();
14521 	start = ktime_get_ns();
14522 
14523 	for (i = 0; i < runs; i++)
14524 		ret = bpf_prog_run(fp, data);
14525 
14526 	finish = ktime_get_ns();
14527 	migrate_enable();
14528 
14529 	*duration = finish - start;
14530 	do_div(*duration, runs);
14531 
14532 	return ret;
14533 }
14534 
run_one(const struct bpf_prog * fp,struct bpf_test * test)14535 static int run_one(const struct bpf_prog *fp, struct bpf_test *test)
14536 {
14537 	int err_cnt = 0, i, runs = MAX_TESTRUNS;
14538 
14539 	if (test->nr_testruns)
14540 		runs = min(test->nr_testruns, MAX_TESTRUNS);
14541 
14542 	for (i = 0; i < MAX_SUBTESTS; i++) {
14543 		void *data;
14544 		u64 duration;
14545 		u32 ret;
14546 
14547 		/*
14548 		 * NOTE: Several sub-tests may be present, in which case
14549 		 * a zero {data_size, result} tuple indicates the end of
14550 		 * the sub-test array. The first test is always run,
14551 		 * even if both data_size and result happen to be zero.
14552 		 */
14553 		if (i > 0 &&
14554 		    test->test[i].data_size == 0 &&
14555 		    test->test[i].result == 0)
14556 			break;
14557 
14558 		data = generate_test_data(test, i);
14559 		if (!data && !(test->aux & FLAG_NO_DATA)) {
14560 			pr_cont("data generation failed ");
14561 			err_cnt++;
14562 			break;
14563 		}
14564 		ret = __run_one(fp, data, runs, &duration);
14565 		release_test_data(test, data);
14566 
14567 		if (ret == test->test[i].result) {
14568 			pr_cont("%lld ", duration);
14569 		} else {
14570 			s32 res = test->test[i].result;
14571 
14572 			pr_cont("ret %d != %d (%#x != %#x)",
14573 				ret, res, ret, res);
14574 			err_cnt++;
14575 		}
14576 	}
14577 
14578 	return err_cnt;
14579 }
14580 
14581 static char test_name[64];
14582 module_param_string(test_name, test_name, sizeof(test_name), 0);
14583 
14584 static int test_id = -1;
14585 module_param(test_id, int, 0);
14586 
14587 static int test_range[2] = { 0, INT_MAX };
14588 module_param_array(test_range, int, NULL, 0);
14589 
exclude_test(int test_id)14590 static bool exclude_test(int test_id)
14591 {
14592 	return test_id < test_range[0] || test_id > test_range[1];
14593 }
14594 
build_test_skb(void)14595 static __init struct sk_buff *build_test_skb(void)
14596 {
14597 	u32 headroom = NET_SKB_PAD + NET_IP_ALIGN + ETH_HLEN;
14598 	struct sk_buff *skb[2];
14599 	struct page *page[2];
14600 	int i, data_size = 8;
14601 
14602 	for (i = 0; i < 2; i++) {
14603 		page[i] = alloc_page(GFP_KERNEL);
14604 		if (!page[i]) {
14605 			if (i == 0)
14606 				goto err_page0;
14607 			else
14608 				goto err_page1;
14609 		}
14610 
14611 		/* this will set skb[i]->head_frag */
14612 		skb[i] = dev_alloc_skb(headroom + data_size);
14613 		if (!skb[i]) {
14614 			if (i == 0)
14615 				goto err_skb0;
14616 			else
14617 				goto err_skb1;
14618 		}
14619 
14620 		skb_reserve(skb[i], headroom);
14621 		skb_put(skb[i], data_size);
14622 		skb[i]->protocol = htons(ETH_P_IP);
14623 		skb_reset_network_header(skb[i]);
14624 		skb_set_mac_header(skb[i], -ETH_HLEN);
14625 
14626 		skb_add_rx_frag(skb[i], 0, page[i], 0, 64, 64);
14627 		// skb_headlen(skb[i]): 8, skb[i]->head_frag = 1
14628 	}
14629 
14630 	/* setup shinfo */
14631 	skb_shinfo(skb[0])->gso_size = 1448;
14632 	skb_shinfo(skb[0])->gso_type = SKB_GSO_TCPV4;
14633 	skb_shinfo(skb[0])->gso_type |= SKB_GSO_DODGY;
14634 	skb_shinfo(skb[0])->gso_segs = 0;
14635 	skb_shinfo(skb[0])->frag_list = skb[1];
14636 	skb_shinfo(skb[0])->hwtstamps.hwtstamp = 1000;
14637 
14638 	/* adjust skb[0]'s len */
14639 	skb[0]->len += skb[1]->len;
14640 	skb[0]->data_len += skb[1]->data_len;
14641 	skb[0]->truesize += skb[1]->truesize;
14642 
14643 	return skb[0];
14644 
14645 err_skb1:
14646 	__free_page(page[1]);
14647 err_page1:
14648 	kfree_skb(skb[0]);
14649 err_skb0:
14650 	__free_page(page[0]);
14651 err_page0:
14652 	return NULL;
14653 }
14654 
build_test_skb_linear_no_head_frag(void)14655 static __init struct sk_buff *build_test_skb_linear_no_head_frag(void)
14656 {
14657 	unsigned int alloc_size = 2000;
14658 	unsigned int headroom = 102, doffset = 72, data_size = 1308;
14659 	struct sk_buff *skb[2];
14660 	int i;
14661 
14662 	/* skbs linked in a frag_list, both with linear data, with head_frag=0
14663 	 * (data allocated by kmalloc), both have tcp data of 1308 bytes
14664 	 * (total payload is 2616 bytes).
14665 	 * Data offset is 72 bytes (40 ipv6 hdr, 32 tcp hdr). Some headroom.
14666 	 */
14667 	for (i = 0; i < 2; i++) {
14668 		skb[i] = alloc_skb(alloc_size, GFP_KERNEL);
14669 		if (!skb[i]) {
14670 			if (i == 0)
14671 				goto err_skb0;
14672 			else
14673 				goto err_skb1;
14674 		}
14675 
14676 		skb[i]->protocol = htons(ETH_P_IPV6);
14677 		skb_reserve(skb[i], headroom);
14678 		skb_put(skb[i], doffset + data_size);
14679 		skb_reset_network_header(skb[i]);
14680 		if (i == 0)
14681 			skb_reset_mac_header(skb[i]);
14682 		else
14683 			skb_set_mac_header(skb[i], -ETH_HLEN);
14684 		__skb_pull(skb[i], doffset);
14685 	}
14686 
14687 	/* setup shinfo.
14688 	 * mimic bpf_skb_proto_4_to_6, which resets gso_segs and assigns a
14689 	 * reduced gso_size.
14690 	 */
14691 	skb_shinfo(skb[0])->gso_size = 1288;
14692 	skb_shinfo(skb[0])->gso_type = SKB_GSO_TCPV6 | SKB_GSO_DODGY;
14693 	skb_shinfo(skb[0])->gso_segs = 0;
14694 	skb_shinfo(skb[0])->frag_list = skb[1];
14695 
14696 	/* adjust skb[0]'s len */
14697 	skb[0]->len += skb[1]->len;
14698 	skb[0]->data_len += skb[1]->len;
14699 	skb[0]->truesize += skb[1]->truesize;
14700 
14701 	return skb[0];
14702 
14703 err_skb1:
14704 	kfree_skb(skb[0]);
14705 err_skb0:
14706 	return NULL;
14707 }
14708 
14709 struct skb_segment_test {
14710 	const char *descr;
14711 	struct sk_buff *(*build_skb)(void);
14712 	netdev_features_t features;
14713 };
14714 
14715 static struct skb_segment_test skb_segment_tests[] __initconst = {
14716 	{
14717 		.descr = "gso_with_rx_frags",
14718 		.build_skb = build_test_skb,
14719 		.features = NETIF_F_SG | NETIF_F_GSO_PARTIAL | NETIF_F_IP_CSUM |
14720 			    NETIF_F_IPV6_CSUM | NETIF_F_RXCSUM
14721 	},
14722 	{
14723 		.descr = "gso_linear_no_head_frag",
14724 		.build_skb = build_test_skb_linear_no_head_frag,
14725 		.features = NETIF_F_SG | NETIF_F_FRAGLIST |
14726 			    NETIF_F_HW_VLAN_CTAG_TX | NETIF_F_GSO |
14727 			    NETIF_F_LLTX | NETIF_F_GRO |
14728 			    NETIF_F_IPV6_CSUM | NETIF_F_RXCSUM |
14729 			    NETIF_F_HW_VLAN_STAG_TX
14730 	}
14731 };
14732 
test_skb_segment_single(const struct skb_segment_test * test)14733 static __init int test_skb_segment_single(const struct skb_segment_test *test)
14734 {
14735 	struct sk_buff *skb, *segs;
14736 	int ret = -1;
14737 
14738 	skb = test->build_skb();
14739 	if (!skb) {
14740 		pr_info("%s: failed to build_test_skb", __func__);
14741 		goto done;
14742 	}
14743 
14744 	segs = skb_segment(skb, test->features);
14745 	if (!IS_ERR(segs)) {
14746 		kfree_skb_list(segs);
14747 		ret = 0;
14748 	}
14749 	kfree_skb(skb);
14750 done:
14751 	return ret;
14752 }
14753 
test_skb_segment(void)14754 static __init int test_skb_segment(void)
14755 {
14756 	int i, err_cnt = 0, pass_cnt = 0;
14757 
14758 	for (i = 0; i < ARRAY_SIZE(skb_segment_tests); i++) {
14759 		const struct skb_segment_test *test = &skb_segment_tests[i];
14760 
14761 		cond_resched();
14762 		if (exclude_test(i))
14763 			continue;
14764 
14765 		pr_info("#%d %s ", i, test->descr);
14766 
14767 		if (test_skb_segment_single(test)) {
14768 			pr_cont("FAIL\n");
14769 			err_cnt++;
14770 		} else {
14771 			pr_cont("PASS\n");
14772 			pass_cnt++;
14773 		}
14774 	}
14775 
14776 	pr_info("%s: Summary: %d PASSED, %d FAILED\n", __func__,
14777 		pass_cnt, err_cnt);
14778 	return err_cnt ? -EINVAL : 0;
14779 }
14780 
test_bpf(void)14781 static __init int test_bpf(void)
14782 {
14783 	int i, err_cnt = 0, pass_cnt = 0;
14784 	int jit_cnt = 0, run_cnt = 0;
14785 
14786 	for (i = 0; i < ARRAY_SIZE(tests); i++) {
14787 		struct bpf_prog *fp;
14788 		int err;
14789 
14790 		cond_resched();
14791 		if (exclude_test(i))
14792 			continue;
14793 
14794 		pr_info("#%d %s ", i, tests[i].descr);
14795 
14796 		if (tests[i].fill_helper &&
14797 		    tests[i].fill_helper(&tests[i]) < 0) {
14798 			pr_cont("FAIL to prog_fill\n");
14799 			continue;
14800 		}
14801 
14802 		fp = generate_filter(i, &err);
14803 
14804 		if (tests[i].fill_helper) {
14805 			kfree(tests[i].u.ptr.insns);
14806 			tests[i].u.ptr.insns = NULL;
14807 		}
14808 
14809 		if (fp == NULL) {
14810 			if (err == 0) {
14811 				pass_cnt++;
14812 				continue;
14813 			}
14814 			err_cnt++;
14815 			continue;
14816 		}
14817 
14818 		pr_cont("jited:%u ", fp->jited);
14819 
14820 		run_cnt++;
14821 		if (fp->jited)
14822 			jit_cnt++;
14823 
14824 		err = run_one(fp, &tests[i]);
14825 		release_filter(fp, i);
14826 
14827 		if (err) {
14828 			pr_cont("FAIL (%d times)\n", err);
14829 			err_cnt++;
14830 		} else {
14831 			pr_cont("PASS\n");
14832 			pass_cnt++;
14833 		}
14834 	}
14835 
14836 	pr_info("Summary: %d PASSED, %d FAILED, [%d/%d JIT'ed]\n",
14837 		pass_cnt, err_cnt, jit_cnt, run_cnt);
14838 
14839 	return err_cnt ? -EINVAL : 0;
14840 }
14841 
14842 struct tail_call_test {
14843 	const char *descr;
14844 	struct bpf_insn insns[MAX_INSNS];
14845 	int flags;
14846 	int result;
14847 	int stack_depth;
14848 };
14849 
14850 /* Flags that can be passed to tail call test cases */
14851 #define FLAG_NEED_STATE		BIT(0)
14852 #define FLAG_RESULT_IN_STATE	BIT(1)
14853 
14854 /*
14855  * Magic marker used in test snippets for tail calls below.
14856  * BPF_LD/MOV to R2 and R2 with this immediate value is replaced
14857  * with the proper values by the test runner.
14858  */
14859 #define TAIL_CALL_MARKER 0x7a11ca11
14860 
14861 /* Special offset to indicate a NULL call target */
14862 #define TAIL_CALL_NULL 0x7fff
14863 
14864 /* Special offset to indicate an out-of-range index */
14865 #define TAIL_CALL_INVALID 0x7ffe
14866 
14867 #define TAIL_CALL(offset)			       \
14868 	BPF_LD_IMM64(R2, TAIL_CALL_MARKER),	       \
14869 	BPF_RAW_INSN(BPF_ALU | BPF_MOV | BPF_K, R3, 0, \
14870 		     offset, TAIL_CALL_MARKER),	       \
14871 	BPF_JMP_IMM(BPF_TAIL_CALL, 0, 0, 0)
14872 
14873 /*
14874  * A test function to be called from a BPF program, clobbering a lot of
14875  * CPU registers in the process. A JITed BPF program calling this function
14876  * must save and restore any caller-saved registers it uses for internal
14877  * state, for example the current tail call count.
14878  */
BPF_CALL_1(bpf_test_func,u64,arg)14879 BPF_CALL_1(bpf_test_func, u64, arg)
14880 {
14881 	char buf[64];
14882 	long a = 0;
14883 	long b = 1;
14884 	long c = 2;
14885 	long d = 3;
14886 	long e = 4;
14887 	long f = 5;
14888 	long g = 6;
14889 	long h = 7;
14890 
14891 	return snprintf(buf, sizeof(buf),
14892 			"%ld %lu %lx %ld %lu %lx %ld %lu %x",
14893 			a, b, c, d, e, f, g, h, (int)arg);
14894 }
14895 #define BPF_FUNC_test_func __BPF_FUNC_MAX_ID
14896 
14897 /*
14898  * Tail call tests. Each test case may call any other test in the table,
14899  * including itself, specified as a relative index offset from the calling
14900  * test. The index TAIL_CALL_NULL can be used to specify a NULL target
14901  * function to test the JIT error path. Similarly, the index TAIL_CALL_INVALID
14902  * results in a target index that is out of range.
14903  */
14904 static struct tail_call_test tail_call_tests[] = {
14905 	{
14906 		"Tail call leaf",
14907 		.insns = {
14908 			BPF_ALU64_REG(BPF_MOV, R0, R1),
14909 			BPF_ALU64_IMM(BPF_ADD, R0, 1),
14910 			BPF_EXIT_INSN(),
14911 		},
14912 		.result = 1,
14913 	},
14914 	{
14915 		"Tail call 2",
14916 		.insns = {
14917 			BPF_ALU64_IMM(BPF_ADD, R1, 2),
14918 			TAIL_CALL(-1),
14919 			BPF_ALU64_IMM(BPF_MOV, R0, -1),
14920 			BPF_EXIT_INSN(),
14921 		},
14922 		.result = 3,
14923 	},
14924 	{
14925 		"Tail call 3",
14926 		.insns = {
14927 			BPF_ALU64_IMM(BPF_ADD, R1, 3),
14928 			TAIL_CALL(-1),
14929 			BPF_ALU64_IMM(BPF_MOV, R0, -1),
14930 			BPF_EXIT_INSN(),
14931 		},
14932 		.result = 6,
14933 	},
14934 	{
14935 		"Tail call 4",
14936 		.insns = {
14937 			BPF_ALU64_IMM(BPF_ADD, R1, 4),
14938 			TAIL_CALL(-1),
14939 			BPF_ALU64_IMM(BPF_MOV, R0, -1),
14940 			BPF_EXIT_INSN(),
14941 		},
14942 		.result = 10,
14943 	},
14944 	{
14945 		"Tail call load/store leaf",
14946 		.insns = {
14947 			BPF_ALU64_IMM(BPF_MOV, R1, 1),
14948 			BPF_ALU64_IMM(BPF_MOV, R2, 2),
14949 			BPF_ALU64_REG(BPF_MOV, R3, BPF_REG_FP),
14950 			BPF_STX_MEM(BPF_DW, R3, R1, -8),
14951 			BPF_STX_MEM(BPF_DW, R3, R2, -16),
14952 			BPF_LDX_MEM(BPF_DW, R0, BPF_REG_FP, -8),
14953 			BPF_JMP_REG(BPF_JNE, R0, R1, 3),
14954 			BPF_LDX_MEM(BPF_DW, R0, BPF_REG_FP, -16),
14955 			BPF_JMP_REG(BPF_JNE, R0, R2, 1),
14956 			BPF_ALU64_IMM(BPF_MOV, R0, 0),
14957 			BPF_EXIT_INSN(),
14958 		},
14959 		.result = 0,
14960 		.stack_depth = 32,
14961 	},
14962 	{
14963 		"Tail call load/store",
14964 		.insns = {
14965 			BPF_ALU64_IMM(BPF_MOV, R0, 3),
14966 			BPF_STX_MEM(BPF_DW, BPF_REG_FP, R0, -8),
14967 			TAIL_CALL(-1),
14968 			BPF_ALU64_IMM(BPF_MOV, R0, -1),
14969 			BPF_EXIT_INSN(),
14970 		},
14971 		.result = 0,
14972 		.stack_depth = 16,
14973 	},
14974 	{
14975 		"Tail call error path, max count reached",
14976 		.insns = {
14977 			BPF_LDX_MEM(BPF_W, R2, R1, 0),
14978 			BPF_ALU64_IMM(BPF_ADD, R2, 1),
14979 			BPF_STX_MEM(BPF_W, R1, R2, 0),
14980 			TAIL_CALL(0),
14981 			BPF_EXIT_INSN(),
14982 		},
14983 		.flags = FLAG_NEED_STATE | FLAG_RESULT_IN_STATE,
14984 		.result = (MAX_TAIL_CALL_CNT + 1) * MAX_TESTRUNS,
14985 	},
14986 	{
14987 		"Tail call count preserved across function calls",
14988 		.insns = {
14989 			BPF_LDX_MEM(BPF_W, R2, R1, 0),
14990 			BPF_ALU64_IMM(BPF_ADD, R2, 1),
14991 			BPF_STX_MEM(BPF_W, R1, R2, 0),
14992 			BPF_STX_MEM(BPF_DW, R10, R1, -8),
14993 			BPF_CALL_REL(BPF_FUNC_get_numa_node_id),
14994 			BPF_CALL_REL(BPF_FUNC_ktime_get_ns),
14995 			BPF_CALL_REL(BPF_FUNC_ktime_get_boot_ns),
14996 			BPF_CALL_REL(BPF_FUNC_ktime_get_coarse_ns),
14997 			BPF_CALL_REL(BPF_FUNC_jiffies64),
14998 			BPF_CALL_REL(BPF_FUNC_test_func),
14999 			BPF_LDX_MEM(BPF_DW, R1, R10, -8),
15000 			BPF_ALU32_REG(BPF_MOV, R0, R1),
15001 			TAIL_CALL(0),
15002 			BPF_EXIT_INSN(),
15003 		},
15004 		.stack_depth = 8,
15005 		.flags = FLAG_NEED_STATE | FLAG_RESULT_IN_STATE,
15006 		.result = (MAX_TAIL_CALL_CNT + 1) * MAX_TESTRUNS,
15007 	},
15008 	{
15009 		"Tail call error path, NULL target",
15010 		.insns = {
15011 			BPF_LDX_MEM(BPF_W, R2, R1, 0),
15012 			BPF_ALU64_IMM(BPF_ADD, R2, 1),
15013 			BPF_STX_MEM(BPF_W, R1, R2, 0),
15014 			TAIL_CALL(TAIL_CALL_NULL),
15015 			BPF_EXIT_INSN(),
15016 		},
15017 		.flags = FLAG_NEED_STATE | FLAG_RESULT_IN_STATE,
15018 		.result = MAX_TESTRUNS,
15019 	},
15020 	{
15021 		"Tail call error path, index out of range",
15022 		.insns = {
15023 			BPF_LDX_MEM(BPF_W, R2, R1, 0),
15024 			BPF_ALU64_IMM(BPF_ADD, R2, 1),
15025 			BPF_STX_MEM(BPF_W, R1, R2, 0),
15026 			TAIL_CALL(TAIL_CALL_INVALID),
15027 			BPF_EXIT_INSN(),
15028 		},
15029 		.flags = FLAG_NEED_STATE | FLAG_RESULT_IN_STATE,
15030 		.result = MAX_TESTRUNS,
15031 	},
15032 };
15033 
destroy_tail_call_tests(struct bpf_array * progs)15034 static void __init destroy_tail_call_tests(struct bpf_array *progs)
15035 {
15036 	int i;
15037 
15038 	for (i = 0; i < ARRAY_SIZE(tail_call_tests); i++)
15039 		if (progs->ptrs[i])
15040 			bpf_prog_free(progs->ptrs[i]);
15041 	kfree(progs);
15042 }
15043 
prepare_tail_call_tests(struct bpf_array ** pprogs)15044 static __init int prepare_tail_call_tests(struct bpf_array **pprogs)
15045 {
15046 	int ntests = ARRAY_SIZE(tail_call_tests);
15047 	struct bpf_array *progs;
15048 	int which, err;
15049 
15050 	/* Allocate the table of programs to be used for tail calls */
15051 	progs = kzalloc(struct_size(progs, ptrs, ntests + 1), GFP_KERNEL);
15052 	if (!progs)
15053 		goto out_nomem;
15054 
15055 	/* Create all eBPF programs and populate the table */
15056 	for (which = 0; which < ntests; which++) {
15057 		struct tail_call_test *test = &tail_call_tests[which];
15058 		struct bpf_prog *fp;
15059 		int len, i;
15060 
15061 		/* Compute the number of program instructions */
15062 		for (len = 0; len < MAX_INSNS; len++) {
15063 			struct bpf_insn *insn = &test->insns[len];
15064 
15065 			if (len < MAX_INSNS - 1 &&
15066 			    insn->code == (BPF_LD | BPF_DW | BPF_IMM))
15067 				len++;
15068 			if (insn->code == 0)
15069 				break;
15070 		}
15071 
15072 		/* Allocate and initialize the program */
15073 		fp = bpf_prog_alloc(bpf_prog_size(len), 0);
15074 		if (!fp)
15075 			goto out_nomem;
15076 
15077 		fp->len = len;
15078 		fp->type = BPF_PROG_TYPE_SOCKET_FILTER;
15079 		fp->aux->stack_depth = test->stack_depth;
15080 		memcpy(fp->insnsi, test->insns, len * sizeof(struct bpf_insn));
15081 
15082 		/* Relocate runtime tail call offsets and addresses */
15083 		for (i = 0; i < len; i++) {
15084 			struct bpf_insn *insn = &fp->insnsi[i];
15085 			long addr = 0;
15086 
15087 			switch (insn->code) {
15088 			case BPF_LD | BPF_DW | BPF_IMM:
15089 				if (insn->imm != TAIL_CALL_MARKER)
15090 					break;
15091 				insn[0].imm = (u32)(long)progs;
15092 				insn[1].imm = ((u64)(long)progs) >> 32;
15093 				break;
15094 
15095 			case BPF_ALU | BPF_MOV | BPF_K:
15096 				if (insn->imm != TAIL_CALL_MARKER)
15097 					break;
15098 				if (insn->off == TAIL_CALL_NULL)
15099 					insn->imm = ntests;
15100 				else if (insn->off == TAIL_CALL_INVALID)
15101 					insn->imm = ntests + 1;
15102 				else
15103 					insn->imm = which + insn->off;
15104 				insn->off = 0;
15105 				break;
15106 
15107 			case BPF_JMP | BPF_CALL:
15108 				if (insn->src_reg != BPF_PSEUDO_CALL)
15109 					break;
15110 				switch (insn->imm) {
15111 				case BPF_FUNC_get_numa_node_id:
15112 					addr = (long)&numa_node_id;
15113 					break;
15114 				case BPF_FUNC_ktime_get_ns:
15115 					addr = (long)&ktime_get_ns;
15116 					break;
15117 				case BPF_FUNC_ktime_get_boot_ns:
15118 					addr = (long)&ktime_get_boot_fast_ns;
15119 					break;
15120 				case BPF_FUNC_ktime_get_coarse_ns:
15121 					addr = (long)&ktime_get_coarse_ns;
15122 					break;
15123 				case BPF_FUNC_jiffies64:
15124 					addr = (long)&get_jiffies_64;
15125 					break;
15126 				case BPF_FUNC_test_func:
15127 					addr = (long)&bpf_test_func;
15128 					break;
15129 				default:
15130 					err = -EFAULT;
15131 					goto out_err;
15132 				}
15133 				*insn = BPF_EMIT_CALL(addr);
15134 				if ((long)__bpf_call_base + insn->imm != addr)
15135 					*insn = BPF_JMP_A(0); /* Skip: NOP */
15136 				break;
15137 			}
15138 		}
15139 
15140 		fp = bpf_prog_select_runtime(fp, &err);
15141 		if (err)
15142 			goto out_err;
15143 
15144 		progs->ptrs[which] = fp;
15145 	}
15146 
15147 	/* The last entry contains a NULL program pointer */
15148 	progs->map.max_entries = ntests + 1;
15149 	*pprogs = progs;
15150 	return 0;
15151 
15152 out_nomem:
15153 	err = -ENOMEM;
15154 
15155 out_err:
15156 	if (progs)
15157 		destroy_tail_call_tests(progs);
15158 	return err;
15159 }
15160 
test_tail_calls(struct bpf_array * progs)15161 static __init int test_tail_calls(struct bpf_array *progs)
15162 {
15163 	int i, err_cnt = 0, pass_cnt = 0;
15164 	int jit_cnt = 0, run_cnt = 0;
15165 
15166 	for (i = 0; i < ARRAY_SIZE(tail_call_tests); i++) {
15167 		struct tail_call_test *test = &tail_call_tests[i];
15168 		struct bpf_prog *fp = progs->ptrs[i];
15169 		int *data = NULL;
15170 		int state = 0;
15171 		u64 duration;
15172 		int ret;
15173 
15174 		cond_resched();
15175 		if (exclude_test(i))
15176 			continue;
15177 
15178 		pr_info("#%d %s ", i, test->descr);
15179 		if (!fp) {
15180 			err_cnt++;
15181 			continue;
15182 		}
15183 		pr_cont("jited:%u ", fp->jited);
15184 
15185 		run_cnt++;
15186 		if (fp->jited)
15187 			jit_cnt++;
15188 
15189 		if (test->flags & FLAG_NEED_STATE)
15190 			data = &state;
15191 		ret = __run_one(fp, data, MAX_TESTRUNS, &duration);
15192 		if (test->flags & FLAG_RESULT_IN_STATE)
15193 			ret = state;
15194 		if (ret == test->result) {
15195 			pr_cont("%lld PASS", duration);
15196 			pass_cnt++;
15197 		} else {
15198 			pr_cont("ret %d != %d FAIL", ret, test->result);
15199 			err_cnt++;
15200 		}
15201 	}
15202 
15203 	pr_info("%s: Summary: %d PASSED, %d FAILED, [%d/%d JIT'ed]\n",
15204 		__func__, pass_cnt, err_cnt, jit_cnt, run_cnt);
15205 
15206 	return err_cnt ? -EINVAL : 0;
15207 }
15208 
15209 static char test_suite[32];
15210 module_param_string(test_suite, test_suite, sizeof(test_suite), 0);
15211 
find_test_index(const char * test_name)15212 static __init int find_test_index(const char *test_name)
15213 {
15214 	int i;
15215 
15216 	if (!strcmp(test_suite, "test_bpf")) {
15217 		for (i = 0; i < ARRAY_SIZE(tests); i++) {
15218 			if (!strcmp(tests[i].descr, test_name))
15219 				return i;
15220 		}
15221 	}
15222 
15223 	if (!strcmp(test_suite, "test_tail_calls")) {
15224 		for (i = 0; i < ARRAY_SIZE(tail_call_tests); i++) {
15225 			if (!strcmp(tail_call_tests[i].descr, test_name))
15226 				return i;
15227 		}
15228 	}
15229 
15230 	if (!strcmp(test_suite, "test_skb_segment")) {
15231 		for (i = 0; i < ARRAY_SIZE(skb_segment_tests); i++) {
15232 			if (!strcmp(skb_segment_tests[i].descr, test_name))
15233 				return i;
15234 		}
15235 	}
15236 
15237 	return -1;
15238 }
15239 
prepare_test_range(void)15240 static __init int prepare_test_range(void)
15241 {
15242 	int valid_range;
15243 
15244 	if (!strcmp(test_suite, "test_bpf"))
15245 		valid_range = ARRAY_SIZE(tests);
15246 	else if (!strcmp(test_suite, "test_tail_calls"))
15247 		valid_range = ARRAY_SIZE(tail_call_tests);
15248 	else if (!strcmp(test_suite, "test_skb_segment"))
15249 		valid_range = ARRAY_SIZE(skb_segment_tests);
15250 	else
15251 		return 0;
15252 
15253 	if (test_id >= 0) {
15254 		/*
15255 		 * if a test_id was specified, use test_range to
15256 		 * cover only that test.
15257 		 */
15258 		if (test_id >= valid_range) {
15259 			pr_err("test_bpf: invalid test_id specified for '%s' suite.\n",
15260 			       test_suite);
15261 			return -EINVAL;
15262 		}
15263 
15264 		test_range[0] = test_id;
15265 		test_range[1] = test_id;
15266 	} else if (*test_name) {
15267 		/*
15268 		 * if a test_name was specified, find it and setup
15269 		 * test_range to cover only that test.
15270 		 */
15271 		int idx = find_test_index(test_name);
15272 
15273 		if (idx < 0) {
15274 			pr_err("test_bpf: no test named '%s' found for '%s' suite.\n",
15275 			       test_name, test_suite);
15276 			return -EINVAL;
15277 		}
15278 		test_range[0] = idx;
15279 		test_range[1] = idx;
15280 	} else if (test_range[0] != 0 || test_range[1] != INT_MAX) {
15281 		/*
15282 		 * check that the supplied test_range is valid.
15283 		 */
15284 		if (test_range[0] < 0 || test_range[1] >= valid_range) {
15285 			pr_err("test_bpf: test_range is out of bound for '%s' suite.\n",
15286 			       test_suite);
15287 			return -EINVAL;
15288 		}
15289 
15290 		if (test_range[1] < test_range[0]) {
15291 			pr_err("test_bpf: test_range is ending before it starts.\n");
15292 			return -EINVAL;
15293 		}
15294 	}
15295 
15296 	return 0;
15297 }
15298 
test_bpf_init(void)15299 static int __init test_bpf_init(void)
15300 {
15301 	struct bpf_array *progs = NULL;
15302 	int ret;
15303 
15304 	if (strlen(test_suite) &&
15305 	    strcmp(test_suite, "test_bpf") &&
15306 	    strcmp(test_suite, "test_tail_calls") &&
15307 	    strcmp(test_suite, "test_skb_segment")) {
15308 		pr_err("test_bpf: invalid test_suite '%s' specified.\n", test_suite);
15309 		return -EINVAL;
15310 	}
15311 
15312 	/*
15313 	 * if test_suite is not specified, but test_id, test_name or test_range
15314 	 * is specified, set 'test_bpf' as the default test suite.
15315 	 */
15316 	if (!strlen(test_suite) &&
15317 	    (test_id != -1 || strlen(test_name) ||
15318 	    (test_range[0] != 0 || test_range[1] != INT_MAX))) {
15319 		pr_info("test_bpf: set 'test_bpf' as the default test_suite.\n");
15320 		strscpy(test_suite, "test_bpf", sizeof(test_suite));
15321 	}
15322 
15323 	ret = prepare_test_range();
15324 	if (ret < 0)
15325 		return ret;
15326 
15327 	if (!strlen(test_suite) || !strcmp(test_suite, "test_bpf")) {
15328 		ret = test_bpf();
15329 		if (ret)
15330 			return ret;
15331 	}
15332 
15333 	if (!strlen(test_suite) || !strcmp(test_suite, "test_tail_calls")) {
15334 		ret = prepare_tail_call_tests(&progs);
15335 		if (ret)
15336 			return ret;
15337 		ret = test_tail_calls(progs);
15338 		destroy_tail_call_tests(progs);
15339 		if (ret)
15340 			return ret;
15341 	}
15342 
15343 	if (!strlen(test_suite) || !strcmp(test_suite, "test_skb_segment"))
15344 		return test_skb_segment();
15345 
15346 	return 0;
15347 }
15348 
test_bpf_exit(void)15349 static void __exit test_bpf_exit(void)
15350 {
15351 }
15352 
15353 module_init(test_bpf_init);
15354 module_exit(test_bpf_exit);
15355 
15356 MODULE_LICENSE("GPL");
15357