]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
riscv: use lw when reading int cpu in new_vmalloc_check
authorRadim Krčmář <rkrcmar@ventanamicro.com>
Fri, 25 Jul 2025 16:54:09 +0000 (18:54 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 9 Sep 2025 17:02:40 +0000 (19:02 +0200)
commit e108c8a94f3f958c877f6ec7a6052a893ae4aa98 upstream.

REG_L is wrong, because thread_info.cpu is 32-bit, not xlen-bit wide.
The struct currently has a hole after cpu, so little endian accesses
seemed fine.

Fixes: 503638e0babf ("riscv: Stop emitting preventive sfence.vma for new vmalloc mappings")
Cc: stable@vger.kernel.org
Reviewed-by: Alexandre Ghiti <alexghiti@rivosinc.com>
Signed-off-by: Radim Krčmář <rkrcmar@ventanamicro.com>
Link: https://lore.kernel.org/r/20250725165410.2896641-4-rkrcmar@ventanamicro.com
Signed-off-by: Paul Walmsley <pjw@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/riscv/kernel/entry.S

index 75656afa2d6be8ca5f2c4711455567c7f8fc0b97..4fdf187a62bfd58220ea1efca3f4b4f03de091da 100644 (file)
@@ -46,7 +46,7 @@
         * a0 = &new_vmalloc[BIT_WORD(cpu)]
         * a1 = BIT_MASK(cpu)
         */
-       REG_L   a2, TASK_TI_CPU(tp)
+       lw      a2, TASK_TI_CPU(tp)
        /*
         * Compute the new_vmalloc element position:
         * (cpu / 64) * 8 = (cpu >> 6) << 3