riscv: Switch over to GENERIC_CPU_DEVICES
authorJames Morse <james.morse@arm.com>
Tue, 21 Nov 2023 13:45:32 +0000 (13:45 +0000)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 6 Dec 2023 03:41:50 +0000 (12:41 +0900)
Now that GENERIC_CPU_DEVICES calls arch_register_cpu(), which can be
overridden by the arch code, switch over to this to allow common code
to choose when the register_cpu() call is made.

This allows topology_init() to be removed.

This is an intermediate step to the logic being moved to drivers/acpi,
where GENERIC_CPU_DEVICES will do the work when booting with acpi=off.

This patch also has the effect of moving the registration of CPUs from
subsys to driver core initialisation, prior to any initcalls running.

Signed-off-by: James Morse <james.morse@arm.com>
Reviewed-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
Acked-by: Palmer Dabbelt <palmer@rivosinc.com>
Reviewed-by: Gavin Shan <gshan@redhat.com>
Signed-off-by: "Russell King (Oracle)" <rmk+kernel@armlinux.org.uk>
Reviewed-by: Samuel Holland <samuel.holland@sifive.com>
Tested-by: Samuel Holland <samuel.holland@sifive.com>
Reviewed-by: Thomas Gleixner <tglx@linutronix.de>
Link: https://lore.kernel.org/r/E1r5R4G-00Ct0M-PS@rmk-PC.armlinux.org.uk
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/riscv/Kconfig
arch/riscv/kernel/setup.c

index 95a2a06acc6a62412894e491c3bfd5d4a161d15b..162425cb9739fdeb19f26aa9ca8d8c5f16400d7f 100644 (file)
@@ -71,6 +71,7 @@ config RISCV
        select GENERIC_ARCH_TOPOLOGY
        select GENERIC_ATOMIC64 if !64BIT
        select GENERIC_CLOCKEVENTS_BROADCAST if SMP
+       select GENERIC_CPU_DEVICES
        select GENERIC_EARLY_IOREMAP
        select GENERIC_ENTRY
        select GENERIC_GETTIMEOFDAY if HAVE_GENERIC_VDSO
index 535a837de55d1ba3aa8a45fe4123404ce1a9430f..b3a0aa2b78d5be7efe51ad75a209003a21e95ac1 100644 (file)
@@ -51,7 +51,6 @@ atomic_t hart_lottery __section(".sdata")
 #endif
 ;
 unsigned long boot_cpu_hartid;
-static DEFINE_PER_CPU(struct cpu, cpu_devices);
 
 /*
  * Place kernel memory regions on the resource tree so that
@@ -299,23 +298,13 @@ void __init setup_arch(char **cmdline_p)
        riscv_user_isa_enable();
 }
 
-static int __init topology_init(void)
+int arch_register_cpu(int cpu)
 {
-       int i, ret;
+       struct cpu *c = &per_cpu(cpu_devices, cpu);
 
-       for_each_possible_cpu(i) {
-               struct cpu *cpu = &per_cpu(cpu_devices, i);
-
-               cpu->hotpluggable = cpu_has_hotplug(i);
-               ret = register_cpu(cpu, i);
-               if (unlikely(ret))
-                       pr_warn("Warning: %s: register_cpu %d failed (%d)\n",
-                              __func__, i, ret);
-       }
-
-       return 0;
+       c->hotpluggable = cpu_has_hotplug(cpu);
+       return register_cpu(c, cpu);
 }
-subsys_initcall(topology_init);
 
 void free_initmem(void)
 {