summaryrefslogtreecommitdiff
path: root/scripts/gdb/linux
diff options
context:
space:
mode:
authorHou Tao <houtao1@huawei.com>2025-01-17 13:18:12 +0300
committerAlexei Starovoitov <ast@kernel.org>2025-01-20 20:09:01 +0300
commit45dc92c32a476daf60eaef855014d0ea35780ba5 (patch)
treeb803c853e1bdaed74d2c427ba93f0147e1cb0682 /scripts/gdb/linux
parent01f3ce5328c405179b2c69ea047c423dad2bfa6d (diff)
downloadlinux-45dc92c32a476daf60eaef855014d0ea35780ba5.tar.xz
bpf: Free special fields after unlock in htab_lru_map_delete_node()
When bpf_timer is used in LRU hash map, calling check_and_free_fields() in htab_lru_map_delete_node() will invoke bpf_timer_cancel_and_free() to free the bpf_timer. If the timer is running on other CPUs, hrtimer_cancel() will invoke hrtimer_cancel_wait_running() to spin on current CPU to wait for the completion of the hrtimer callback. Considering that the deletion has already acquired a raw-spin-lock (bucket lock). To reduce the time holding the bucket lock, move the invocation of check_and_free_fields() out of bucket lock. However, because htab_lru_map_delete_node() is invoked with LRU raw spin lock being held, the freeing of special fields still happens in a locked scope. Signed-off-by: Hou Tao <houtao1@huawei.com> Reviewed-by: Toke Høiland-Jørgensen <toke@kernel.org> Link: https://lore.kernel.org/r/20250117101816.2101857-2-houtao@huaweicloud.com Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Diffstat (limited to 'scripts/gdb/linux')
0 files changed, 0 insertions, 0 deletions