]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
riscv: don't probe unaligned access speed if already done
authorJisheng Zhang <jszhang@kernel.org>
Tue, 12 Sep 2023 15:40:40 +0000 (23:40 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 10 Jan 2024 16:16:56 +0000 (17:16 +0100)
[ Upstream commit c20d36cc2a2073d4cdcda92bd7a1bb9b3b3b7c79 ]

If misaligned_access_speed percpu var isn't so called "HWPROBE
MISALIGNED UNKNOWN", it means the probe has happened(this is possible
for example, hotplug off then hotplug on one cpu), and the percpu var
has been set, don't probe again in this case.

Signed-off-by: Jisheng Zhang <jszhang@kernel.org>
Fixes: 584ea6564bca ("RISC-V: Probe for unaligned access speed")
Reviewed-by: Conor Dooley <conor.dooley@microchip.com>
Link: https://lore.kernel.org/r/20230912154040.3306-1-jszhang@kernel.org
Signed-off-by: Palmer Dabbelt <palmer@rivosinc.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
arch/riscv/kernel/cpufeature.c

index 1cfbba65d11ae311d54729966e57fb3c9386d61c..e12cd22755c78257bea44b95b813b860922ea4f8 100644 (file)
@@ -568,6 +568,10 @@ void check_unaligned_access(int cpu)
        void *src;
        long speed = RISCV_HWPROBE_MISALIGNED_SLOW;
 
+       /* We are already set since the last check */
+       if (per_cpu(misaligned_access_speed, cpu) != RISCV_HWPROBE_MISALIGNED_UNKNOWN)
+               return;
+
        page = alloc_pages(GFP_NOWAIT, get_order(MISALIGNED_BUFFER_SIZE));
        if (!page) {
                pr_warn("Can't alloc pages to measure memcpy performance");