diff options
author | David S. Miller <davem@davemloft.net> | 2018-08-18 10:02:49 -0700 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2018-08-18 10:02:49 -0700 |
commit | 6e3bf9b04f79a009a7ff336ba7353ab565daaec8 (patch) | |
tree | 12e5914158a802b7761b0b44d953ac06f6c51fcc /net/core/xdp.c | |
parent | 3fe49d699a9604eed851eb45e1e0adab0e25688e (diff) | |
parent | f6069b9aa9934ede26f41ac0781fce241279ad43 (diff) | |
download | linux-6e3bf9b04f79a009a7ff336ba7353ab565daaec8.tar.gz linux-6e3bf9b04f79a009a7ff336ba7353ab565daaec8.tar.bz2 linux-6e3bf9b04f79a009a7ff336ba7353ab565daaec8.zip |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/bpf/bpf
Daniel Borkmann says:
====================
pull-request: bpf 2018-08-18
The following pull-request contains BPF updates for your *net* tree.
The main changes are:
1) Fix a BPF selftest failure in test_cgroup_storage due to rlimit
restrictions, from Yonghong.
2) Fix a suspicious RCU rcu_dereference_check() warning triggered
from removing a device's XDP memory allocator by using the correct
rhashtable lookup function, from Tariq.
3) A batch of BPF sockmap and ULP fixes mainly fixing leaks and races
as well as enforcing module aliases for ULPs. Another fix for BPF
map redirect to make them work again with tail calls, from Daniel.
4) Fix XDP BPF samples to unload their programs upon SIGTERM, from Jesper.
====================
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/core/xdp.c')
-rw-r--r-- | net/core/xdp.c | 14 |
1 files changed, 3 insertions, 11 deletions
diff --git a/net/core/xdp.c b/net/core/xdp.c index 3dd99e1c04f5..89b6785cef2a 100644 --- a/net/core/xdp.c +++ b/net/core/xdp.c @@ -98,23 +98,15 @@ static void __xdp_rxq_info_unreg_mem_model(struct xdp_rxq_info *xdp_rxq) { struct xdp_mem_allocator *xa; int id = xdp_rxq->mem.id; - int err; if (id == 0) return; mutex_lock(&mem_id_lock); - xa = rhashtable_lookup(mem_id_ht, &id, mem_id_rht_params); - if (!xa) { - mutex_unlock(&mem_id_lock); - return; - } - - err = rhashtable_remove_fast(mem_id_ht, &xa->node, mem_id_rht_params); - WARN_ON(err); - - call_rcu(&xa->rcu, __xdp_mem_allocator_rcu_free); + xa = rhashtable_lookup_fast(mem_id_ht, &id, mem_id_rht_params); + if (xa && !rhashtable_remove_fast(mem_id_ht, &xa->node, mem_id_rht_params)) + call_rcu(&xa->rcu, __xdp_mem_allocator_rcu_free); mutex_unlock(&mem_id_lock); } |