#endif /* HAS_PPC_PMC_PA6T */
 #endif /* HAS_PPC_PMC_CLASSIC */
 
-static void register_cpu_online(unsigned int cpu)
+static int register_cpu_online(unsigned int cpu)
 {
        struct cpu *c = &per_cpu(cpu_devices, cpu);
        struct device *s = &c->dev;
        }
 #endif
        cacheinfo_cpu_online(cpu);
+       return 0;
 }
 
-#ifdef CONFIG_HOTPLUG_CPU
-static void unregister_cpu_online(unsigned int cpu)
+static int unregister_cpu_online(unsigned int cpu)
 {
+#ifdef CONFIG_HOTPLUG_CPU
        struct cpu *c = &per_cpu(cpu_devices, cpu);
        struct device *s = &c->dev;
        struct device_attribute *attrs, *pmc_attrs;
        }
 #endif
        cacheinfo_cpu_offline(cpu);
+#endif /* CONFIG_HOTPLUG_CPU */
+       return 0;
 }
 
 #ifdef CONFIG_ARCH_CPU_PROBE_RELEASE
 }
 #endif /* CONFIG_ARCH_CPU_PROBE_RELEASE */
 
-#endif /* CONFIG_HOTPLUG_CPU */
-
-static int sysfs_cpu_notify(struct notifier_block *self,
-                                     unsigned long action, void *hcpu)
-{
-       unsigned int cpu = (unsigned int)(long)hcpu;
-
-       switch (action) {
-       case CPU_ONLINE:
-       case CPU_ONLINE_FROZEN:
-               register_cpu_online(cpu);
-               break;
-#ifdef CONFIG_HOTPLUG_CPU
-       case CPU_DEAD:
-       case CPU_DEAD_FROZEN:
-               unregister_cpu_online(cpu);
-               break;
-#endif
-       }
-       return NOTIFY_OK;
-}
-
-static struct notifier_block sysfs_cpu_nb = {
-       .notifier_call  = sysfs_cpu_notify,
-};
-
 static DEFINE_MUTEX(cpu_mutex);
 
 int cpu_add_dev_attr(struct device_attribute *attr)
 
 static int __init topology_init(void)
 {
-       int cpu;
+       int cpu, r;
 
        register_nodes();
 
-       cpu_notifier_register_begin();
-
        for_each_possible_cpu(cpu) {
                struct cpu *c = &per_cpu(cpu_devices, cpu);
 
 
                        device_create_file(&c->dev, &dev_attr_physical_id);
                }
-
-               if (cpu_online(cpu))
-                       register_cpu_online(cpu);
        }
-
-       __register_cpu_notifier(&sysfs_cpu_nb);
-
-       cpu_notifier_register_done();
-
+       r = cpuhp_setup_state(CPUHP_AP_ONLINE_DYN, "powerpc/topology:online",
+                             register_cpu_online, unregister_cpu_online);
+       WARN_ON(r < 0);
 #ifdef CONFIG_PPC64
        sysfs_create_dscr_default();
 #endif /* CONFIG_PPC64 */