diff options
| author | Ingo Molnar <mingo@kernel.org> | 2020-05-28 07:58:12 +0200 | 
|---|---|---|
| committer | Ingo Molnar <mingo@kernel.org> | 2020-05-28 07:58:12 +0200 | 
| commit | 0bffedbce90818228f554651baf8d7c75f2876d8 (patch) | |
| tree | 96101208e0200c70c6688737ac6596bdd0ed2950 /tools/testing/selftests/bpf/verifier/stack_ptr.c | |
| parent | c50c75e9b87946499a62bffc021e95c87a1d57cd (diff) | |
| parent | 9cb1fd0efd195590b828b9b865421ad345a4a145 (diff) | |
Merge tag 'v5.7-rc7' into perf/core, to pick up fixes
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'tools/testing/selftests/bpf/verifier/stack_ptr.c')
| -rw-r--r-- | tools/testing/selftests/bpf/verifier/stack_ptr.c | 40 | 
1 files changed, 40 insertions, 0 deletions
| diff --git a/tools/testing/selftests/bpf/verifier/stack_ptr.c b/tools/testing/selftests/bpf/verifier/stack_ptr.c index 7276620ef242..8bfeb77c60bd 100644 --- a/tools/testing/selftests/bpf/verifier/stack_ptr.c +++ b/tools/testing/selftests/bpf/verifier/stack_ptr.c @@ -315,3 +315,43 @@  	},  	.result = ACCEPT,  }, +{ +	"store PTR_TO_STACK in R10 to array map using BPF_B", +	.insns = { +	/* Load pointer to map. */ +	BPF_MOV64_REG(BPF_REG_2, BPF_REG_10), +	BPF_ALU64_IMM(BPF_ADD, BPF_REG_2, -8), +	BPF_ST_MEM(BPF_DW, BPF_REG_2, 0, 0), +	BPF_LD_MAP_FD(BPF_REG_1, 0), +	BPF_EMIT_CALL(BPF_FUNC_map_lookup_elem), +	BPF_JMP_IMM(BPF_JNE, BPF_REG_0, 0, 2), +	BPF_MOV64_IMM(BPF_REG_0, 2), +	BPF_EXIT_INSN(), +	BPF_MOV64_REG(BPF_REG_1, BPF_REG_0), +	/* Copy R10 to R9. */ +	BPF_MOV64_REG(BPF_REG_9, BPF_REG_10), +	/* Pollute other registers with unaligned values. */ +	BPF_MOV64_IMM(BPF_REG_2, -1), +	BPF_MOV64_IMM(BPF_REG_3, -1), +	BPF_MOV64_IMM(BPF_REG_4, -1), +	BPF_MOV64_IMM(BPF_REG_5, -1), +	BPF_MOV64_IMM(BPF_REG_6, -1), +	BPF_MOV64_IMM(BPF_REG_7, -1), +	BPF_MOV64_IMM(BPF_REG_8, -1), +	/* Store both R9 and R10 with BPF_B and read back. */ +	BPF_STX_MEM(BPF_B, BPF_REG_1, BPF_REG_10, 0), +	BPF_LDX_MEM(BPF_B, BPF_REG_2, BPF_REG_1, 0), +	BPF_STX_MEM(BPF_B, BPF_REG_1, BPF_REG_9, 0), +	BPF_LDX_MEM(BPF_B, BPF_REG_3, BPF_REG_1, 0), +	/* Should read back as same value. */ +	BPF_JMP_REG(BPF_JEQ, BPF_REG_2, BPF_REG_3, 2), +	BPF_MOV64_IMM(BPF_REG_0, 1), +	BPF_EXIT_INSN(), +	BPF_MOV64_IMM(BPF_REG_0, 42), +	BPF_EXIT_INSN(), +	}, +	.fixup_map_array_48b = { 3 }, +	.result = ACCEPT, +	.retval = 42, +	.prog_type = BPF_PROG_TYPE_SCHED_CLS, +}, | 
