Revert "bpf: Fix potential call bpf_link_free() in atomic context"
This reverts commit 31f23a6a18
.
This change made many selftests/bpf flaky: flow_dissector, sk_lookup, sk_assign and others.
There was no issue in the code.
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
This commit is contained in:
Родитель
3fc826f121
Коммит
f00f2f7fe8
|
@ -2345,8 +2345,12 @@ void bpf_link_put(struct bpf_link *link)
|
||||||
if (!atomic64_dec_and_test(&link->refcnt))
|
if (!atomic64_dec_and_test(&link->refcnt))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
INIT_WORK(&link->work, bpf_link_put_deferred);
|
if (in_atomic()) {
|
||||||
schedule_work(&link->work);
|
INIT_WORK(&link->work, bpf_link_put_deferred);
|
||||||
|
schedule_work(&link->work);
|
||||||
|
} else {
|
||||||
|
bpf_link_free(link);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int bpf_link_release(struct inode *inode, struct file *filp)
|
static int bpf_link_release(struct inode *inode, struct file *filp)
|
||||||
|
|
Загрузка…
Ссылка в новой задаче