summaryrefslogtreecommitdiff
path: root/include/linux
diff options
context:
space:
mode:
authorAndrii Nakryiko <andrii@kernel.org>2026-05-29 00:58:14 +0300
committerAndrii Nakryiko <andrii@kernel.org>2026-05-29 00:58:14 +0300
commit7f9ce282da0c397673be7d5870b0bcdbc8c6ce82 (patch)
tree2b5d551fe2ba2bac97e77180accc788ede78f05a /include/linux
parenta4a5d4ee061240a1d39053db0a87f841d43277c0 (diff)
parent5e9099d8ff24ec32aa5af872a4d84d086bd70579 (diff)
downloadlinux-7f9ce282da0c397673be7d5870b0bcdbc8c6ce82.tar.xz
Merge branch 'bpf-implement-stack_map_get_build_id_offset_sleepable'
Ihor Solodrai says: ==================== bpf: Implement stack_map_get_build_id_offset_sleepable() The series introduces stack_map_get_build_id_offset_sleepable(), fixing a gap with parsing build_id in sleepable context in stackmap.c In particular, this fixes a deadlock in stack_map_get_build_id_offset() doing a blocking __kernel_read(), which happens since commit 777a8560fd29 ("lib/buildid: use __kernel_read() for sleepable context"). See previous revisions for more details. --- v6->v7: * Addressed feedback from Andrii (mostly patch #2): * implement proper CONFIG_PER_VMA_LOCK=n support, following a VMA locking pattern similar to one used in PROCMAP_QUERY * change the contract of stack_map_lock_vma(): if a non-NULL VMA is returned, then a read lock is held * remove now unnecessary vma_locked flag * and various other nits * Add vma_is_anonymous() checks where appropriate (AIs) v6: https://lore.kernel.org/bpf/20260521225022.2695755-1-ihor.solodrai@linux.dev/ v5->v6: * Misc refactoring (Andrii): * add stack_map_build_id_set_valid() helper * simplify control flow in stack_map_get_build_id_offset_sleepable() v5: https://lore.kernel.org/bpf/20260515005244.1333013-1-ihor.solodrai@linux.dev/ v4->v5: * Add comments explaining mmap_read_trylock() (Shakeel) * Rebase on bpf-next (Alexei) v4: https://lore.kernel.org/bpf/20260514184727.1067141-1-ihor.solodrai@linux.dev/ v3->v4: * Change Fixes tag in patch #2 (AI) * Nit in caching implementation (Mykyta) v3: https://lore.kernel.org/bpf/20260512032906.2670326-1-ihor.solodrai@linux.dev/ v2->v3: * Split patch #2 in two: stack_map_get_build_id_offset_sleepable() implementation, and then introduce caching * Drop taking mmap_lock if CONFIG_PER_VMA_LOCK=n, fall back to raw IPs instead * Cache vm_{start,end} in addition to prev_file (Mykyta) v2: https://lore.kernel.org/bpf/20260409010604.1439087-1-ihor.solodrai@linux.dev/ v1->v2: * Addressed feedback from Puranjay: * split out a small refactoring patch * use mmap_read_trylock() * take into account CONFIG_PER_VMA_LOCK * replace find_vma() with vma_lookup() * cache prev_build_id to avoid re-parsing the same file * Snapshot vm_pgoff and vm_start before unlocking (AI) * To avoid repetitive unlocking statements, introduce struct stack_map_vma_lock to hold relevant lock state info and add an unlock helper v1: https://lore.kernel.org/bpf/20260407223003.720428-1-ihor.solodrai@linux.dev/ --- ==================== Link: https://patch.msgid.link/20260525223948.1920986-1-ihor.solodrai@linux.dev Signed-off-by: Andrii Nakryiko <andrii@kernel.org>
Diffstat (limited to 'include/linux')
0 files changed, 0 insertions, 0 deletions