treewide: remove redundant IS_ERR() before error code check
[linux/fpc-iii.git] / tools / testing / selftests / bpf / verifier / and.c
blobe0fad1548737212824cf683ce06a0073c51d02df
2 "invalid and of negative number",
3 .insns = {
4 BPF_ST_MEM(BPF_DW, BPF_REG_10, -8, 0),
5 BPF_MOV64_REG(BPF_REG_2, BPF_REG_10),
6 BPF_ALU64_IMM(BPF_ADD, BPF_REG_2, -8),
7 BPF_LD_MAP_FD(BPF_REG_1, 0),
8 BPF_RAW_INSN(BPF_JMP | BPF_CALL, 0, 0, 0, BPF_FUNC_map_lookup_elem),
9 BPF_JMP_IMM(BPF_JEQ, BPF_REG_0, 0, 4),
10 BPF_LDX_MEM(BPF_B, BPF_REG_1, BPF_REG_0, 0),
11 BPF_ALU64_IMM(BPF_AND, BPF_REG_1, -4),
12 BPF_ALU64_IMM(BPF_LSH, BPF_REG_1, 2),
13 BPF_ALU64_REG(BPF_ADD, BPF_REG_0, BPF_REG_1),
14 BPF_ST_MEM(BPF_DW, BPF_REG_0, 0, offsetof(struct test_val, foo)),
15 BPF_EXIT_INSN(),
17 .fixup_map_hash_48b = { 3 },
18 .errstr = "R0 max value is outside of the array range",
19 .result = REJECT,
20 .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
23 "invalid range check",
24 .insns = {
25 BPF_ST_MEM(BPF_DW, BPF_REG_10, -8, 0),
26 BPF_MOV64_REG(BPF_REG_2, BPF_REG_10),
27 BPF_ALU64_IMM(BPF_ADD, BPF_REG_2, -8),
28 BPF_LD_MAP_FD(BPF_REG_1, 0),
29 BPF_RAW_INSN(BPF_JMP | BPF_CALL, 0, 0, 0, BPF_FUNC_map_lookup_elem),
30 BPF_JMP_IMM(BPF_JEQ, BPF_REG_0, 0, 12),
31 BPF_LDX_MEM(BPF_W, BPF_REG_1, BPF_REG_0, 0),
32 BPF_MOV64_IMM(BPF_REG_9, 1),
33 BPF_ALU32_IMM(BPF_MOD, BPF_REG_1, 2),
34 BPF_ALU32_IMM(BPF_ADD, BPF_REG_1, 1),
35 BPF_ALU32_REG(BPF_AND, BPF_REG_9, BPF_REG_1),
36 BPF_ALU32_IMM(BPF_ADD, BPF_REG_9, 1),
37 BPF_ALU32_IMM(BPF_RSH, BPF_REG_9, 1),
38 BPF_MOV32_IMM(BPF_REG_3, 1),
39 BPF_ALU32_REG(BPF_SUB, BPF_REG_3, BPF_REG_9),
40 BPF_ALU32_IMM(BPF_MUL, BPF_REG_3, 0x10000000),
41 BPF_ALU64_REG(BPF_ADD, BPF_REG_0, BPF_REG_3),
42 BPF_STX_MEM(BPF_W, BPF_REG_0, BPF_REG_3, 0),
43 BPF_MOV64_REG(BPF_REG_0, 0),
44 BPF_EXIT_INSN(),
46 .fixup_map_hash_48b = { 3 },
47 .errstr = "R0 max value is outside of the array range",
48 .result = REJECT,
49 .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,