提交 0f83cef0 编写于 作者: P Paul E. McKenney 提交者: Zheng Zengkai

rcu-tasks: Make ksoftirqd provide RCU Tasks quiescent states

mainline inclusion
from mainline-v5.14-rc1
commit cf868c2a
category: bugfix
bugzilla: https://gitee.com/openeuler/kernel/issues/I4U05V
CVE: NA

-------------------------------------------------------------------------

Heavy networking load can cause a CPU to execute continuously and
indefinitely within ksoftirqd, in which case there will be no voluntary
task switches and thus no RCU-tasks quiescent states.  This commit
therefore causes the exiting rcu_softirq_qs() to provide an RCU-tasks
quiescent state.

This of course means that __do_softirq() and its callers cannot be
invoked from within a tracing trampoline.
Reported-by: NToke Høiland-Jørgensen <toke@redhat.com>
Tested-by: NToke Høiland-Jørgensen <toke@redhat.com>
Reviewed-by: NMasami Hiramatsu <mhiramat@kernel.org>
Signed-off-by: NPaul E. McKenney <paulmck@kernel.org>
Cc: Steven Rostedt <rostedt@goodmis.org>
Cc: Masami Hiramatsu <mhiramat@kernel.org>
Signed-off-by: NZhen Lei <thunder.leizhen@huawei.com>
Reviewed-by: NCheng Jian <cj.chengjian@huawei.com>
Reviewed-by: NCheng Jian <cj.chengjian@huawei.com>
Signed-off-by: NZheng Zengkai <zhengzengkai@huawei.com>
上级 6c7ab876
...@@ -236,6 +236,7 @@ void rcu_softirq_qs(void) ...@@ -236,6 +236,7 @@ void rcu_softirq_qs(void)
{ {
rcu_qs(); rcu_qs();
rcu_preempt_deferred_qs(current); rcu_preempt_deferred_qs(current);
rcu_tasks_qs(current, false);
} }
/* /*
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册