diff options
author | Toke Høiland-Jørgensen <[email protected]> | 2021-06-24 18:06:06 +0200 |
---|---|---|
committer | Daniel Borkmann <[email protected]> | 2021-06-24 19:46:01 +0200 |
commit | 4eb14e3fc6197b7205069ed4e2b31eafa11a0697 (patch) | |
tree | a31ac8a2c2aa564c0f4f781edbc83aeeff7ed2e9 /lib/mpi/mpi-sub-ui.c | |
parent | 4415db6ca85ae57830a83290388f2b9dfa5f237f (diff) |
sfc: Remove rcu_read_lock() around XDP program invocation
The sfc driver has rcu_read_lock()/rcu_read_unlock() pairs around XDP
program invocations. However, the actual lifetime of the objects referred
by the XDP program invocation is longer, all the way through to the call to
xdp_do_flush(), making the scope of the rcu_read_lock() too small. This
turns out to be harmless because it all happens in a single NAPI poll
cycle (and thus under local_bh_disable()), but it makes the rcu_read_lock()
misleading.
Rather than extend the scope of the rcu_read_lock(), just get rid of it
entirely. With the addition of RCU annotations to the XDP_REDIRECT map
types that take bh execution into account, lockdep even understands this to
be safe, so there's really no reason to keep it around.
Signed-off-by: Toke Høiland-Jørgensen <[email protected]>
Signed-off-by: Daniel Borkmann <[email protected]>
Acked-by: Edward Cree <[email protected]>
Cc: Martin Habets <[email protected]>
Link: https://lore.kernel.org/bpf/[email protected]
Diffstat (limited to 'lib/mpi/mpi-sub-ui.c')
0 files changed, 0 insertions, 0 deletions