The following commit has been merged into the sched/core branch of tip: Commit-ID: 2aa45be430a031c10d5f4a5bf3329ff8413a9187 Gitweb: https://git.kernel.org/tip/2aa45be430a031c10d5f4a5bf3329ff8413a9187 Author: Peter Zijlstra <peterz@xxxxxxxxxxxxx> AuthorDate: Tue, 21 Sep 2021 22:16:02 +02:00 Committer: Peter Zijlstra <peterz@xxxxxxxxxxxxx> CommitterDate: Thu, 07 Oct 2021 13:51:16 +02:00 sched,livepatch: Use wake_up_if_idle() Make sure to prod idle CPUs so they call klp_update_patch_state(). Signed-off-by: Peter Zijlstra (Intel) <peterz@xxxxxxxxxxxxx> Reviewed-by: Petr Mladek <pmladek@xxxxxxxx> Acked-by: Miroslav Benes <mbenes@xxxxxxx> Acked-by: Vasily Gorbik <gor@xxxxxxxxxxxxx> Tested-by: Petr Mladek <pmladek@xxxxxxxx> Tested-by: Vasily Gorbik <gor@xxxxxxxxxxxxx> # on s390 Link: https://lkml.kernel.org/r/20210929151723.162004989@xxxxxxxxxxxxx --- kernel/livepatch/transition.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/kernel/livepatch/transition.c b/kernel/livepatch/transition.c index 75251e9..5683ac0 100644 --- a/kernel/livepatch/transition.c +++ b/kernel/livepatch/transition.c @@ -413,8 +413,11 @@ void klp_try_complete_transition(void) for_each_possible_cpu(cpu) { task = idle_task(cpu); if (cpu_online(cpu)) { - if (!klp_try_switch_task(task)) + if (!klp_try_switch_task(task)) { complete = false; + /* Make idle task go through the main loop. */ + wake_up_if_idle(cpu); + } } else if (task->patch_state != klp_target_state) { /* offline idle tasks can be switched immediately */ clear_tsk_thread_flag(task, TIF_PATCH_PENDING);
![]() |