Lines Matching refs:cpu

89 static int op_cpu_kill(unsigned int cpu);
91 static inline int op_cpu_kill(unsigned int cpu) in op_cpu_kill() argument
102 static int boot_secondary(unsigned int cpu, struct task_struct *idle) in boot_secondary() argument
104 if (cpu_ops[cpu]->cpu_boot) in boot_secondary()
105 return cpu_ops[cpu]->cpu_boot(cpu); in boot_secondary()
112 int __cpu_up(unsigned int cpu, struct task_struct *idle) in __cpu_up() argument
129 ret = boot_secondary(cpu, idle); in __cpu_up()
138 if (!cpu_online(cpu)) { in __cpu_up()
139 pr_crit("CPU%u: failed to come online\n", cpu); in __cpu_up()
143 pr_err("CPU%u: failed to boot: %d\n", cpu, ret); in __cpu_up()
157 cpu, status); in __cpu_up()
160 if (!op_cpu_kill(cpu)) { in __cpu_up()
161 pr_crit("CPU%u: died during early boot\n", cpu); in __cpu_up()
165 pr_crit("CPU%u: may not have shut down cleanly\n", cpu); in __cpu_up()
167 pr_crit("CPU%u: is stuck in kernel\n", cpu); in __cpu_up()
171 panic("CPU%u detected unsupported configuration\n", cpu); in __cpu_up()
186 unsigned int cpu; in secondary_start_kernel() local
188 cpu = task_cpu(current); in secondary_start_kernel()
189 set_my_cpu_offset(per_cpu_offset(cpu)); in secondary_start_kernel()
214 if (cpu_ops[cpu]->cpu_postboot) in secondary_start_kernel()
215 cpu_ops[cpu]->cpu_postboot(); in secondary_start_kernel()
225 notify_cpu_starting(cpu); in secondary_start_kernel()
227 store_cpu_topology(cpu); in secondary_start_kernel()
228 numa_add_cpu(cpu); in secondary_start_kernel()
236 cpu, (unsigned long)mpidr, in secondary_start_kernel()
239 set_cpu_online(cpu, true); in secondary_start_kernel()
251 static int op_cpu_disable(unsigned int cpu) in op_cpu_disable() argument
257 if (!cpu_ops[cpu] || !cpu_ops[cpu]->cpu_die) in op_cpu_disable()
264 if (cpu_ops[cpu]->cpu_disable) in op_cpu_disable()
265 return cpu_ops[cpu]->cpu_disable(cpu); in op_cpu_disable()
275 unsigned int cpu = smp_processor_id(); in __cpu_disable() local
278 ret = op_cpu_disable(cpu); in __cpu_disable()
282 remove_cpu_topology(cpu); in __cpu_disable()
283 numa_remove_cpu(cpu); in __cpu_disable()
289 set_cpu_online(cpu, false); in __cpu_disable()
299 static int op_cpu_kill(unsigned int cpu) in op_cpu_kill() argument
306 if (!cpu_ops[cpu]->cpu_kill) in op_cpu_kill()
309 return cpu_ops[cpu]->cpu_kill(cpu); in op_cpu_kill()
316 void __cpu_die(unsigned int cpu) in __cpu_die() argument
320 if (!cpu_wait_death(cpu, 5)) { in __cpu_die()
321 pr_crit("CPU%u: cpu didn't die\n", cpu); in __cpu_die()
324 pr_notice("CPU%u: shutdown\n", cpu); in __cpu_die()
332 err = op_cpu_kill(cpu); in __cpu_die()
335 cpu, err); in __cpu_die()
344 unsigned int cpu = smp_processor_id(); in cpu_die() local
358 cpu_ops[cpu]->cpu_die(cpu); in cpu_die()
370 int cpu = smp_processor_id(); in cpu_die_early() local
372 pr_crit("CPU%d: will not boot\n", cpu); in cpu_die_early()
375 set_cpu_present(cpu, 0); in cpu_die_early()
380 if (cpu_ops[cpu] && cpu_ops[cpu]->cpu_die) in cpu_die_early()
381 cpu_ops[cpu]->cpu_die(cpu); in cpu_die_early()
452 static bool __init is_mpidr_duplicate(unsigned int cpu, u64 hwid) in is_mpidr_duplicate() argument
456 for (i = 1; (i < cpu) && (i < NR_CPUS); i++) in is_mpidr_duplicate()
466 static int __init smp_cpu_setup(int cpu) in smp_cpu_setup() argument
468 if (cpu_read_ops(cpu)) in smp_cpu_setup()
471 if (cpu_ops[cpu]->cpu_init(cpu)) in smp_cpu_setup()
474 set_cpu_possible(cpu, true); in smp_cpu_setup()
485 struct acpi_madt_generic_interrupt *acpi_cpu_get_madt_gicc(int cpu) in acpi_cpu_get_madt_gicc() argument
487 return &cpu_madt_gicc[cpu]; in acpi_cpu_get_madt_gicc()
695 unsigned int cpu; in smp_prepare_cpus() local
717 for_each_possible_cpu(cpu) { in smp_prepare_cpus()
719 per_cpu(cpu_number, cpu) = cpu; in smp_prepare_cpus()
721 if (cpu == smp_processor_id()) in smp_prepare_cpus()
724 if (!cpu_ops[cpu]) in smp_prepare_cpus()
727 err = cpu_ops[cpu]->cpu_prepare(cpu); in smp_prepare_cpus()
731 set_cpu_present(cpu, true); in smp_prepare_cpus()
732 numa_store_cpu_info(cpu); in smp_prepare_cpus()
762 unsigned int cpu, i; in show_ipi_list() local
767 for_each_online_cpu(cpu) in show_ipi_list()
769 __get_irq_stat(cpu, ipi_irqs[i])); in show_ipi_list()
774 u64 smp_irq_stat_cpu(unsigned int cpu) in smp_irq_stat_cpu() argument
780 sum += __get_irq_stat(cpu, ipi_irqs[i]); in smp_irq_stat_cpu()
790 void arch_send_call_function_single_ipi(int cpu) in arch_send_call_function_single_ipi() argument
792 smp_cross_call(cpumask_of(cpu), IPI_CALL_FUNC); in arch_send_call_function_single_ipi()
813 static void ipi_cpu_stop(unsigned int cpu) in ipi_cpu_stop() argument
815 set_cpu_online(cpu, false); in ipi_cpu_stop()
828 static void ipi_cpu_crash_stop(unsigned int cpu, struct pt_regs *regs) in ipi_cpu_crash_stop() argument
831 crash_save_cpu(regs, cpu); in ipi_cpu_crash_stop()
839 if (cpu_ops[cpu]->cpu_die) in ipi_cpu_crash_stop()
840 cpu_ops[cpu]->cpu_die(cpu); in ipi_cpu_crash_stop()
853 unsigned int cpu = smp_processor_id(); in handle_IPI() local
858 __inc_irq_stat(cpu, ipi_irqs[ipinr]); in handle_IPI()
874 ipi_cpu_stop(cpu); in handle_IPI()
881 ipi_cpu_crash_stop(cpu, regs); in handle_IPI()
905 WARN_ONCE(!acpi_parking_protocol_valid(cpu), in handle_IPI()
907 cpu); in handle_IPI()
912 pr_crit("CPU%u: Unknown IPI message 0x%x\n", cpu, ipinr); in handle_IPI()
921 void smp_send_reschedule(int cpu) in smp_send_reschedule() argument
923 smp_cross_call(cpumask_of(cpu), IPI_RESCHEDULE); in smp_send_reschedule()