bpf: fix htab map destruction when extra reserve is in use
Commita6ed3ea65d
("bpf: restore behavior of bpf_map_update_elem") added an extra per-cpu reserve to the hash table map to restore old behaviour from pre prealloc times. When non-prealloc is in use for a map, then problem is that once a hash table extra element has been linked into the hash-table, and the hash table is destroyed due to refcount dropping to zero, then htab_map_free() -> delete_all_elements() will walk the whole hash table and drop all elements via htab_elem_free(). The problem is that the element from the extra reserve is first fed to the wrong backend allocator and eventually freed twice. Fixes:a6ed3ea65d
("bpf: restore behavior of bpf_map_update_elem") Reported-by: Dmitry Vyukov <dvyukov@google.com> Signed-off-by: Daniel Borkmann <daniel@iogearbox.net> Acked-by: Alexei Starovoitov <ast@kernel.org> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
7233bc84a3
commit
483bed2b0d
|
@ -687,6 +687,7 @@ static void delete_all_elements(struct bpf_htab *htab)
|
||||||
|
|
||||||
hlist_for_each_entry_safe(l, n, head, hash_node) {
|
hlist_for_each_entry_safe(l, n, head, hash_node) {
|
||||||
hlist_del_rcu(&l->hash_node);
|
hlist_del_rcu(&l->hash_node);
|
||||||
|
if (l->state != HTAB_EXTRA_ELEM_USED)
|
||||||
htab_elem_free(htab, l);
|
htab_elem_free(htab, l);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue