bpf: Use rcu_trace_implies_rcu_gp() for program array freeing
authorHou Tao <houtao1@huawei.com>
Fri, 14 Oct 2022 11:39:46 +0000 (19:39 +0800)
committerAlexei Starovoitov <ast@kernel.org>
Tue, 18 Oct 2022 17:27:02 +0000 (10:27 -0700)
commit4835f9ee980c1867584018e69cbf1f62d7844cb3
treee2b8022025e270d1f39a04f592dbdd468be80f94
parentd39d1445d37747032e2b26732fed6fe25161cd36
bpf: Use rcu_trace_implies_rcu_gp() for program array freeing

To support both sleepable and normal uprobe bpf program, the freeing of
trace program array chains a RCU-tasks-trace grace period and a normal
RCU grace period one after the other.

With the introduction of rcu_trace_implies_rcu_gp(),
__bpf_prog_array_free_sleepable_cb() can check whether or not a normal
RCU grace period has also passed after a RCU-tasks-trace grace period
has passed. If it is true, it is safe to invoke kfree() directly.

Signed-off-by: Hou Tao <houtao1@huawei.com>
Link: https://lore.kernel.org/r/20221014113946.965131-5-houtao@huaweicloud.com
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
kernel/bpf/core.c