Commit 79093f3e authored by Samuel Holland's avatar Samuel Holland Committed by Palmer Dabbelt

riscv: Remove unused members from struct cpu_operations

name is not used anywhere at all. cpu_prepare and cpu_disable do nothing
and always return 0 if implemented.
Signed-off-by: default avatarSamuel Holland <samuel.holland@sifive.com>
Reviewed-by: default avatarConor Dooley <conor.dooley@microchip.com>
Link: https://lore.kernel.org/r/20231121234736.3489608-3-samuel.holland@sifive.comSigned-off-by: default avatarPalmer Dabbelt <palmer@rivosinc.com>
parent a4166aec
...@@ -13,26 +13,16 @@ ...@@ -13,26 +13,16 @@
/** /**
* struct cpu_operations - Callback operations for hotplugging CPUs. * struct cpu_operations - Callback operations for hotplugging CPUs.
* *
* @name: Name of the boot protocol.
* @cpu_prepare: Early one-time preparation step for a cpu. If there
* is a mechanism for doing so, tests whether it is
* possible to boot the given HART.
* @cpu_start: Boots a cpu into the kernel. * @cpu_start: Boots a cpu into the kernel.
* @cpu_disable: Prepares a cpu to die. May fail for some
* mechanism-specific reason, which will cause the hot
* unplug to be aborted. Called from the cpu to be killed.
* @cpu_stop: Makes a cpu leave the kernel. Must not fail. Called from * @cpu_stop: Makes a cpu leave the kernel. Must not fail. Called from
* the cpu being stopped. * the cpu being stopped.
* @cpu_is_stopped: Ensures a cpu has left the kernel. Called from another * @cpu_is_stopped: Ensures a cpu has left the kernel. Called from another
* cpu. * cpu.
*/ */
struct cpu_operations { struct cpu_operations {
const char *name;
int (*cpu_prepare)(unsigned int cpu);
int (*cpu_start)(unsigned int cpu, int (*cpu_start)(unsigned int cpu,
struct task_struct *tidle); struct task_struct *tidle);
#ifdef CONFIG_HOTPLUG_CPU #ifdef CONFIG_HOTPLUG_CPU
int (*cpu_disable)(unsigned int cpu);
void (*cpu_stop)(void); void (*cpu_stop)(void);
int (*cpu_is_stopped)(unsigned int cpu); int (*cpu_is_stopped)(unsigned int cpu);
#endif #endif
......
...@@ -29,25 +29,18 @@ bool cpu_has_hotplug(unsigned int cpu) ...@@ -29,25 +29,18 @@ bool cpu_has_hotplug(unsigned int cpu)
*/ */
int __cpu_disable(void) int __cpu_disable(void)
{ {
int ret = 0;
unsigned int cpu = smp_processor_id(); unsigned int cpu = smp_processor_id();
if (!cpu_ops[cpu] || !cpu_ops[cpu]->cpu_stop) if (!cpu_ops[cpu] || !cpu_ops[cpu]->cpu_stop)
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (cpu_ops[cpu]->cpu_disable)
ret = cpu_ops[cpu]->cpu_disable(cpu);
if (ret)
return ret;
remove_cpu_topology(cpu); remove_cpu_topology(cpu);
numa_remove_cpu(cpu); numa_remove_cpu(cpu);
set_cpu_online(cpu, false); set_cpu_online(cpu, false);
riscv_ipi_disable(); riscv_ipi_disable();
irq_migrate_all_off_this_cpu(); irq_migrate_all_off_this_cpu();
return ret; return 0;
} }
#ifdef CONFIG_HOTPLUG_CPU #ifdef CONFIG_HOTPLUG_CPU
......
...@@ -18,8 +18,6 @@ const struct cpu_operations *cpu_ops[NR_CPUS] __ro_after_init; ...@@ -18,8 +18,6 @@ const struct cpu_operations *cpu_ops[NR_CPUS] __ro_after_init;
extern const struct cpu_operations cpu_ops_sbi; extern const struct cpu_operations cpu_ops_sbi;
#ifndef CONFIG_RISCV_BOOT_SPINWAIT #ifndef CONFIG_RISCV_BOOT_SPINWAIT
const struct cpu_operations cpu_ops_spinwait = { const struct cpu_operations cpu_ops_spinwait = {
.name = "",
.cpu_prepare = NULL,
.cpu_start = NULL, .cpu_start = NULL,
}; };
#endif #endif
......
...@@ -79,23 +79,7 @@ static int sbi_cpu_start(unsigned int cpuid, struct task_struct *tidle) ...@@ -79,23 +79,7 @@ static int sbi_cpu_start(unsigned int cpuid, struct task_struct *tidle)
return sbi_hsm_hart_start(hartid, boot_addr, hsm_data); return sbi_hsm_hart_start(hartid, boot_addr, hsm_data);
} }
static int sbi_cpu_prepare(unsigned int cpuid)
{
if (!cpu_ops_sbi.cpu_start) {
pr_err("cpu start method not defined for CPU [%d]\n", cpuid);
return -ENODEV;
}
return 0;
}
#ifdef CONFIG_HOTPLUG_CPU #ifdef CONFIG_HOTPLUG_CPU
static int sbi_cpu_disable(unsigned int cpuid)
{
if (!cpu_ops_sbi.cpu_stop)
return -EOPNOTSUPP;
return 0;
}
static void sbi_cpu_stop(void) static void sbi_cpu_stop(void)
{ {
int ret; int ret;
...@@ -118,11 +102,8 @@ static int sbi_cpu_is_stopped(unsigned int cpuid) ...@@ -118,11 +102,8 @@ static int sbi_cpu_is_stopped(unsigned int cpuid)
#endif #endif
const struct cpu_operations cpu_ops_sbi = { const struct cpu_operations cpu_ops_sbi = {
.name = "sbi",
.cpu_prepare = sbi_cpu_prepare,
.cpu_start = sbi_cpu_start, .cpu_start = sbi_cpu_start,
#ifdef CONFIG_HOTPLUG_CPU #ifdef CONFIG_HOTPLUG_CPU
.cpu_disable = sbi_cpu_disable,
.cpu_stop = sbi_cpu_stop, .cpu_stop = sbi_cpu_stop,
.cpu_is_stopped = sbi_cpu_is_stopped, .cpu_is_stopped = sbi_cpu_is_stopped,
#endif #endif
......
...@@ -39,15 +39,6 @@ static void cpu_update_secondary_bootdata(unsigned int cpuid, ...@@ -39,15 +39,6 @@ static void cpu_update_secondary_bootdata(unsigned int cpuid,
WRITE_ONCE(__cpu_spinwait_task_pointer[hartid], tidle); WRITE_ONCE(__cpu_spinwait_task_pointer[hartid], tidle);
} }
static int spinwait_cpu_prepare(unsigned int cpuid)
{
if (!cpu_ops_spinwait.cpu_start) {
pr_err("cpu start method not defined for CPU [%d]\n", cpuid);
return -ENODEV;
}
return 0;
}
static int spinwait_cpu_start(unsigned int cpuid, struct task_struct *tidle) static int spinwait_cpu_start(unsigned int cpuid, struct task_struct *tidle)
{ {
/* /*
...@@ -64,7 +55,5 @@ static int spinwait_cpu_start(unsigned int cpuid, struct task_struct *tidle) ...@@ -64,7 +55,5 @@ static int spinwait_cpu_start(unsigned int cpuid, struct task_struct *tidle)
} }
const struct cpu_operations cpu_ops_spinwait = { const struct cpu_operations cpu_ops_spinwait = {
.name = "spinwait",
.cpu_prepare = spinwait_cpu_prepare,
.cpu_start = spinwait_cpu_start, .cpu_start = spinwait_cpu_start,
}; };
...@@ -11,7 +11,6 @@ ...@@ -11,7 +11,6 @@
#include <asm/page.h> #include <asm/page.h>
#include <asm/pgtable.h> #include <asm/pgtable.h>
#include <asm/csr.h> #include <asm/csr.h>
#include <asm/cpu_ops_sbi.h>
#include <asm/hwcap.h> #include <asm/hwcap.h>
#include <asm/image.h> #include <asm/image.h>
#include <asm/scs.h> #include <asm/scs.h>
......
...@@ -26,7 +26,6 @@ ...@@ -26,7 +26,6 @@
#include <asm/alternative.h> #include <asm/alternative.h>
#include <asm/cacheflush.h> #include <asm/cacheflush.h>
#include <asm/cpufeature.h> #include <asm/cpufeature.h>
#include <asm/cpu_ops.h>
#include <asm/early_ioremap.h> #include <asm/early_ioremap.h>
#include <asm/pgtable.h> #include <asm/pgtable.h>
#include <asm/setup.h> #include <asm/setup.h>
......
...@@ -49,7 +49,6 @@ void __init smp_prepare_boot_cpu(void) ...@@ -49,7 +49,6 @@ void __init smp_prepare_boot_cpu(void)
void __init smp_prepare_cpus(unsigned int max_cpus) void __init smp_prepare_cpus(unsigned int max_cpus)
{ {
int cpuid; int cpuid;
int ret;
unsigned int curr_cpuid; unsigned int curr_cpuid;
init_cpu_topology(); init_cpu_topology();
...@@ -66,11 +65,6 @@ void __init smp_prepare_cpus(unsigned int max_cpus) ...@@ -66,11 +65,6 @@ void __init smp_prepare_cpus(unsigned int max_cpus)
for_each_possible_cpu(cpuid) { for_each_possible_cpu(cpuid) {
if (cpuid == curr_cpuid) if (cpuid == curr_cpuid)
continue; continue;
if (cpu_ops[cpuid]->cpu_prepare) {
ret = cpu_ops[cpuid]->cpu_prepare(cpuid);
if (ret)
continue;
}
set_cpu_present(cpuid, true); set_cpu_present(cpuid, true);
numa_store_cpu_info(cpuid); numa_store_cpu_info(cpuid);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment