提交 858d68f1 编写于 作者: D Daniel Borkmann 提交者: David S. Miller

bpf: bpf_event_entry_gen's alloc needs to be in atomic context

Should have been obvious, only called from bpf() syscall via map_update_elem()
that calls bpf_fd_array_map_update_elem() under RCU read lock and thus this
must also be in GFP_ATOMIC, of course.

Fixes: 3b1efb19 ("bpf, maps: flush own entries on perf map release")
Signed-off-by: NDaniel Borkmann <daniel@iogearbox.net>
Acked-by: NAlexei Starovoitov <ast@kernel.org>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 c5c4e45c
...@@ -430,7 +430,7 @@ static struct bpf_event_entry *bpf_event_entry_gen(struct file *perf_file, ...@@ -430,7 +430,7 @@ static struct bpf_event_entry *bpf_event_entry_gen(struct file *perf_file,
{ {
struct bpf_event_entry *ee; struct bpf_event_entry *ee;
ee = kzalloc(sizeof(*ee), GFP_KERNEL); ee = kzalloc(sizeof(*ee), GFP_ATOMIC);
if (ee) { if (ee) {
ee->event = perf_file->private_data; ee->event = perf_file->private_data;
ee->perf_file = perf_file; ee->perf_file = perf_file;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册