diff options
author | Jakub Sitnicki <[email protected]> | 2020-06-25 16:13:55 +0200 |
---|---|---|
committer | Alexei Starovoitov <[email protected]> | 2020-06-30 10:45:08 -0700 |
commit | 695c12147a40181fe9221d321c3f2de33c9574ed (patch) | |
tree | fddc7f1a11f4d32deb9a45cb3e5a604ece6f2cb2 /tools/testing/selftests/bpf/prog_tests | |
parent | 3b7016996c4c44db5d499d98759b82fb714bb912 (diff) |
bpf, netns: Keep attached programs in bpf_prog_array
Prepare for having multi-prog attachments for new netns attach types by
storing programs to run in a bpf_prog_array, which is well suited for
iterating over programs and running them in sequence.
After this change bpf(PROG_QUERY) may block to allocate memory in
bpf_prog_array_copy_to_user() for collected program IDs. This forces a
change in how we protect access to the attached program in the query
callback. Because bpf_prog_array_copy_to_user() can sleep, we switch from
an RCU read lock to holding a mutex that serializes updaters.
Because we allow only one BPF flow_dissector program to be attached to
netns at all times, the bpf_prog_array pointed by net->bpf.run_array is
always either detached (null) or one element long.
No functional changes intended.
Signed-off-by: Jakub Sitnicki <[email protected]>
Signed-off-by: Alexei Starovoitov <[email protected]>
Acked-by: Martin KaFai Lau <[email protected]>
Acked-by: Andrii Nakryiko <[email protected]>
Link: https://lore.kernel.org/bpf/[email protected]
Diffstat (limited to 'tools/testing/selftests/bpf/prog_tests')
0 files changed, 0 insertions, 0 deletions