]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
RISC-V: clear hot-unplugged cores from all task mm_cpumasks to avoid rfence errors
authorDanil Skrebenkov <danil.skrebenkov@cloudbear.ru>
Fri, 19 Sep 2025 13:28:46 +0000 (16:28 +0300)
committerPaul Walmsley <pjw@kernel.org>
Fri, 10 Oct 2025 01:36:45 +0000 (19:36 -0600)
openSBI v1.7 adds harts checks for ipi operations. Especially it
adds comparison between hmask passed as an argument from linux
and mask of online harts (from openSBI side). If they don't
fit each other the error occurs.

When cpu is offline, cpu_online_mask is explicitly cleared in
__cpu_disable. However, there is no explicit clearing of
mm_cpumask. mm_cpumask is used for rfence operations that
call openSBI RFENCE extension which uses ipi to remote harts.
If hart is offline there may be error if mask of linux is not
as mask of online harts in openSBI.

this patch adds explicit clearing of mm_cpumask for offline hart.

Signed-off-by: Danil Skrebenkov <danil.skrebenkov@cloudbear.ru>
Reviewed-by: Andrew Jones <ajones@ventanamicro.com>
Link: https://lore.kernel.org/r/20250919132849.31676-1-danil.skrebenkov@cloudbear.ru
[pjw@kernel.org: rewrote subject line for clarity]
Signed-off-by: Paul Walmsley <pjw@kernel.org>
arch/riscv/kernel/cpu-hotplug.c

index a1e38ecfc8be21068a2af679f7a093ed630d62b2..3f50d3dd76c6f2e9ed04c1563f7cf34269d1ca39 100644 (file)
@@ -54,6 +54,7 @@ void arch_cpuhp_cleanup_dead_cpu(unsigned int cpu)
 
        pr_notice("CPU%u: off\n", cpu);
 
+       clear_tasks_mm_cpumask(cpu);
        /* Verify from the firmware if the cpu is really stopped*/
        if (cpu_ops->cpu_is_stopped)
                ret = cpu_ops->cpu_is_stopped(cpu);