EXPORT_SYMBOL_GPL(cpu_is_hotpluggable);
 
 #ifdef CONFIG_GENERIC_CPU_DEVICES
-static DEFINE_PER_CPU(struct cpu, cpu_devices);
+DEFINE_PER_CPU(struct cpu, cpu_devices);
+
+int __weak arch_register_cpu(int cpu)
+{
+       return register_cpu(&per_cpu(cpu_devices, cpu), cpu);
+}
 #endif
 
 static void __init cpu_dev_register_generic(void)
 {
-#ifdef CONFIG_GENERIC_CPU_DEVICES
        int i;
 
+       if (!IS_ENABLED(CONFIG_GENERIC_CPU_DEVICES))
+               return;
+
        for_each_present_cpu(i) {
-               if (register_cpu(&per_cpu(cpu_devices, i), i))
+               if (arch_register_cpu(i))
                        panic("Failed to register CPU device");
        }
-#endif
 }
 
 #ifdef CONFIG_GENERIC_CPU_VULNERABILITIES
 
 extern ssize_t arch_cpu_release(const char *, size_t);
 #endif
 
+#ifdef CONFIG_GENERIC_CPU_DEVICES
+DECLARE_PER_CPU(struct cpu, cpu_devices);
+#endif
+
 /*
  * These states are not related to the core CPU hotplug mechanism. They are
  * used by various (sub)architectures to track internal state