OSDN Git Service

bpf: Allow local kptrs to be exchanged via bpf_kptr_xchg
authorDave Marchevsky <davemarchevsky@fb.com>
Fri, 10 Mar 2023 23:07:42 +0000 (15:07 -0800)
committerAlexei Starovoitov <ast@kernel.org>
Sat, 11 Mar 2023 00:38:05 +0000 (16:38 -0800)
commit738c96d5e2e3700b370f02ac84a9dc159ca81f25
tree8da5ca672f2f3e602ba1606a2d930b07aa537aa6
parentc8e18754091479fac3f5b6c053c6bc4be0b7fb11
bpf: Allow local kptrs to be exchanged via bpf_kptr_xchg

The previous patch added necessary plumbing for verifier and runtime to
know what to do with non-kernel PTR_TO_BTF_IDs in map values, but didn't
provide any way to get such local kptrs into a map value. This patch
modifies verifier handling of bpf_kptr_xchg to allow MEM_ALLOC kptr
types.

check_reg_type is modified accept MEM_ALLOC-flagged input to
bpf_kptr_xchg despite such types not being in btf_ptr_types. This could
have been done with a MAYBE_MEM_ALLOC equivalent to MAYBE_NULL, but
bpf_kptr_xchg is the only helper that I can forsee using
MAYBE_MEM_ALLOC, so keep it special-cased for now.

The verifier tags bpf_kptr_xchg retval MEM_ALLOC if and only if the BTF
associated with the retval is not kernel BTF.

Signed-off-by: Dave Marchevsky <davemarchevsky@fb.com>
Link: https://lore.kernel.org/r/20230310230743.2320707-3-davemarchevsky@fb.com
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
kernel/bpf/verifier.c