2022-05-31 18:04:11 +08:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
|
|
|
#include <linux/cpu.h>
|
2022-05-31 18:04:12 +08:00
|
|
|
#include <linux/cpumask.h>
|
2022-05-31 18:04:11 +08:00
|
|
|
#include <linux/init.h>
|
2022-05-31 18:04:12 +08:00
|
|
|
#include <linux/node.h>
|
|
|
|
#include <linux/nodemask.h>
|
2022-05-31 18:04:11 +08:00
|
|
|
#include <linux/percpu.h>
|
2022-10-12 16:36:08 +08:00
|
|
|
#include <asm/bootinfo.h>
|
2022-05-31 18:04:11 +08:00
|
|
|
|
2022-05-31 18:04:12 +08:00
|
|
|
static DEFINE_PER_CPU(struct cpu, cpu_devices);
|
|
|
|
|
|
|
|
#ifdef CONFIG_HOTPLUG_CPU
|
|
|
|
int arch_register_cpu(int cpu)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
struct cpu *c = &per_cpu(cpu_devices, cpu);
|
|
|
|
|
|
|
|
c->hotpluggable = 1;
|
|
|
|
ret = register_cpu(c, cpu);
|
|
|
|
if (ret < 0)
|
|
|
|
pr_warn("register_cpu %d failed (%d)\n", cpu, ret);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(arch_register_cpu);
|
|
|
|
|
|
|
|
void arch_unregister_cpu(int cpu)
|
|
|
|
{
|
|
|
|
struct cpu *c = &per_cpu(cpu_devices, cpu);
|
|
|
|
|
|
|
|
c->hotpluggable = 0;
|
|
|
|
unregister_cpu(c);
|
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(arch_unregister_cpu);
|
|
|
|
#endif
|
2022-05-31 18:04:11 +08:00
|
|
|
|
|
|
|
static int __init topology_init(void)
|
|
|
|
{
|
2022-05-31 18:04:12 +08:00
|
|
|
int i, ret;
|
|
|
|
|
|
|
|
for_each_present_cpu(i) {
|
|
|
|
struct cpu *c = &per_cpu(cpu_devices, i);
|
|
|
|
|
2022-10-12 16:36:08 +08:00
|
|
|
c->hotpluggable = !io_master(i);
|
2022-05-31 18:04:12 +08:00
|
|
|
ret = register_cpu(c, i);
|
|
|
|
if (ret < 0)
|
|
|
|
pr_warn("topology_init: register_cpu %d failed (%d)\n", i, ret);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
2022-05-31 18:04:11 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
subsys_initcall(topology_init);
|