};
 
 extern const struct cpu_operations cpu_ops_spinwait;
-extern const struct cpu_operations *cpu_ops[NR_CPUS];
-void __init cpu_set_ops(int cpu);
+extern const struct cpu_operations *cpu_ops;
+void __init cpu_set_ops(void);
 
 #endif /* ifndef __ASM_CPU_OPS_H */
 
 
 bool cpu_has_hotplug(unsigned int cpu)
 {
-       if (cpu_ops[cpu]->cpu_stop)
+       if (cpu_ops->cpu_stop)
                return true;
 
        return false;
 {
        unsigned int cpu = smp_processor_id();
 
-       if (!cpu_ops[cpu] || !cpu_ops[cpu]->cpu_stop)
+       if (!cpu_ops->cpu_stop)
                return -EOPNOTSUPP;
 
        remove_cpu_topology(cpu);
        pr_notice("CPU%u: off\n", cpu);
 
        /* Verify from the firmware if the cpu is really stopped*/
-       if (cpu_ops[cpu]->cpu_is_stopped)
-               ret = cpu_ops[cpu]->cpu_is_stopped(cpu);
+       if (cpu_ops->cpu_is_stopped)
+               ret = cpu_ops->cpu_is_stopped(cpu);
        if (ret)
                pr_warn("CPU%d may not have stopped: %d\n", cpu, ret);
 }
 
        cpuhp_ap_report_dead();
 
-       cpu_ops[smp_processor_id()]->cpu_stop();
+       cpu_ops->cpu_stop();
        /* It should never reach here */
        BUG();
 }
 
 #include <asm/sbi.h>
 #include <asm/smp.h>
 
-const struct cpu_operations *cpu_ops[NR_CPUS] __ro_after_init;
+const struct cpu_operations *cpu_ops __ro_after_init = &cpu_ops_spinwait;
 
 extern const struct cpu_operations cpu_ops_sbi;
 #ifndef CONFIG_RISCV_BOOT_SPINWAIT
 };
 #endif
 
-void __init cpu_set_ops(int cpuid)
+void __init cpu_set_ops(void)
 {
 #if IS_ENABLED(CONFIG_RISCV_SBI)
        if (sbi_probe_extension(SBI_EXT_HSM)) {
-               if (!cpuid)
-                       pr_info("SBI HSM extension detected\n");
-               cpu_ops[cpuid] = &cpu_ops_sbi;
-       } else
+               pr_info("SBI HSM extension detected\n");
+               cpu_ops = &cpu_ops_sbi;
+       }
 #endif
-               cpu_ops[cpuid] = &cpu_ops_spinwait;
 }
 
 
 #ifdef CONFIG_HOTPLUG_CPU
        if (cpu_has_hotplug(cpu))
-               cpu_ops[cpu]->cpu_stop();
+               cpu_ops->cpu_stop();
 #endif
 
        for(;;)
 
 {
        int cpuid;
 
-       cpu_set_ops(0);
+       cpu_set_ops();
 
        if (acpi_disabled)
                of_parse_and_init_cpus();
        else
                acpi_parse_and_init_cpus();
 
-       for (cpuid = 1; cpuid < nr_cpu_ids; cpuid++) {
-               if (cpuid_to_hartid_map(cpuid) != INVALID_HARTID) {
-                       cpu_set_ops(cpuid);
+       for (cpuid = 1; cpuid < nr_cpu_ids; cpuid++)
+               if (cpuid_to_hartid_map(cpuid) != INVALID_HARTID)
                        set_cpu_possible(cpuid, true);
-               }
-       }
 }
 
 static int start_secondary_cpu(int cpu, struct task_struct *tidle)
 {
-       if (cpu_ops[cpu]->cpu_start)
-               return cpu_ops[cpu]->cpu_start(cpu, tidle);
+       if (cpu_ops->cpu_start)
+               return cpu_ops->cpu_start(cpu, tidle);
 
        return -EOPNOTSUPP;
 }