Commit 8cd2accb authored by Baoquan He's avatar Baoquan He Committed by Andrew Morton

mips, kexec: fix the incorrect ifdeffery and dependency of CONFIG_KEXEC

The select of KEXEC for CRASH_DUMP in kernel/Kconfig.kexec will be
dropped, then compiling errors will be triggered if below config items are
set:

===
CONFIG_CRASH_CORE=y
CONFIG_KEXEC_CORE=y
CONFIG_CRASH_DUMP=y
===

--------------------------------------------------------------------
mipsel-linux-ld: kernel/kexec_core.o: in function `kimage_free':
kernel/kexec_core.c:(.text+0x2200): undefined reference to `machine_kexec_cleanup'
mipsel-linux-ld: kernel/kexec_core.o: in function `__crash_kexec':
kernel/kexec_core.c:(.text+0x2480): undefined reference to `machine_crash_shutdown'
mipsel-linux-ld: kernel/kexec_core.c:(.text+0x2488): undefined reference to `machine_kexec'
mipsel-linux-ld: kernel/kexec_core.o: in function `kernel_kexec':
kernel/kexec_core.c:(.text+0x29b8): undefined reference to `machine_shutdown'
mipsel-linux-ld: kernel/kexec_core.c:(.text+0x29c0): undefined reference to `machine_kexec'
--------------------------------------------------------------------

Here, change the dependency of building kexec_core related object files,
and the ifdeffery in mips from CONFIG_KEXEC to CONFIG_KEXEC_CORE.

Link: https://lkml.kernel.org/r/20231208073036.7884-4-bhe@redhat.comSigned-off-by: default avatarBaoquan He <bhe@redhat.com>
Reported-by: default avatarkernel test robot <lkp@intel.com>
Closes: https://lore.kernel.org/oe-kbuild-all/202311302042.sn8cDPIX-lkp@intel.com/
Cc: Eric DeVolder <eric_devolder@yahoo.com>
Cc: Ignat Korchagin <ignat@cloudflare.com>
Cc: Stephen Rothwell <sfr@canb.auug.org.au>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent 9bad6b75
...@@ -422,7 +422,7 @@ static const struct plat_smp_ops octeon_smp_ops = { ...@@ -422,7 +422,7 @@ static const struct plat_smp_ops octeon_smp_ops = {
.cpu_disable = octeon_cpu_disable, .cpu_disable = octeon_cpu_disable,
.cpu_die = octeon_cpu_die, .cpu_die = octeon_cpu_die,
#endif #endif
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
.kexec_nonboot_cpu = kexec_nonboot_cpu_jump, .kexec_nonboot_cpu = kexec_nonboot_cpu_jump,
#endif #endif
}; };
...@@ -502,7 +502,7 @@ static const struct plat_smp_ops octeon_78xx_smp_ops = { ...@@ -502,7 +502,7 @@ static const struct plat_smp_ops octeon_78xx_smp_ops = {
.cpu_disable = octeon_cpu_disable, .cpu_disable = octeon_cpu_disable,
.cpu_die = octeon_cpu_die, .cpu_die = octeon_cpu_die,
#endif #endif
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
.kexec_nonboot_cpu = kexec_nonboot_cpu_jump, .kexec_nonboot_cpu = kexec_nonboot_cpu_jump,
#endif #endif
}; };
......
...@@ -31,7 +31,7 @@ static inline void crash_setup_regs(struct pt_regs *newregs, ...@@ -31,7 +31,7 @@ static inline void crash_setup_regs(struct pt_regs *newregs,
prepare_frametrace(newregs); prepare_frametrace(newregs);
} }
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
struct kimage; struct kimage;
extern unsigned long kexec_args[4]; extern unsigned long kexec_args[4];
extern int (*_machine_kexec_prepare)(struct kimage *); extern int (*_machine_kexec_prepare)(struct kimage *);
......
...@@ -35,7 +35,7 @@ struct plat_smp_ops { ...@@ -35,7 +35,7 @@ struct plat_smp_ops {
void (*cpu_die)(unsigned int cpu); void (*cpu_die)(unsigned int cpu);
void (*cleanup_dead_cpu)(unsigned cpu); void (*cleanup_dead_cpu)(unsigned cpu);
#endif #endif
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
void (*kexec_nonboot_cpu)(void); void (*kexec_nonboot_cpu)(void);
#endif #endif
}; };
......
...@@ -93,7 +93,7 @@ static inline void __cpu_die(unsigned int cpu) ...@@ -93,7 +93,7 @@ static inline void __cpu_die(unsigned int cpu)
extern void __noreturn play_dead(void); extern void __noreturn play_dead(void);
#endif #endif
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
static inline void kexec_nonboot_cpu(void) static inline void kexec_nonboot_cpu(void)
{ {
extern const struct plat_smp_ops *mp_ops; /* private */ extern const struct plat_smp_ops *mp_ops; /* private */
......
...@@ -90,7 +90,7 @@ obj-$(CONFIG_GPIO_TXX9) += gpio_txx9.o ...@@ -90,7 +90,7 @@ obj-$(CONFIG_GPIO_TXX9) += gpio_txx9.o
obj-$(CONFIG_RELOCATABLE) += relocate.o obj-$(CONFIG_RELOCATABLE) += relocate.o
obj-$(CONFIG_KEXEC) += machine_kexec.o relocate_kernel.o crash.o obj-$(CONFIG_KEXEC_CORE) += machine_kexec.o relocate_kernel.o crash.o
obj-$(CONFIG_CRASH_DUMP) += crash_dump.o obj-$(CONFIG_CRASH_DUMP) += crash_dump.o
obj-$(CONFIG_EARLY_PRINTK) += early_printk.o obj-$(CONFIG_EARLY_PRINTK) += early_printk.o
obj-$(CONFIG_EARLY_PRINTK_8250) += early_printk_8250.o obj-$(CONFIG_EARLY_PRINTK_8250) += early_printk_8250.o
......
...@@ -434,7 +434,7 @@ const struct plat_smp_ops bmips43xx_smp_ops = { ...@@ -434,7 +434,7 @@ const struct plat_smp_ops bmips43xx_smp_ops = {
.cpu_disable = bmips_cpu_disable, .cpu_disable = bmips_cpu_disable,
.cpu_die = bmips_cpu_die, .cpu_die = bmips_cpu_die,
#endif #endif
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
.kexec_nonboot_cpu = kexec_nonboot_cpu_jump, .kexec_nonboot_cpu = kexec_nonboot_cpu_jump,
#endif #endif
}; };
...@@ -451,7 +451,7 @@ const struct plat_smp_ops bmips5000_smp_ops = { ...@@ -451,7 +451,7 @@ const struct plat_smp_ops bmips5000_smp_ops = {
.cpu_disable = bmips_cpu_disable, .cpu_disable = bmips_cpu_disable,
.cpu_die = bmips_cpu_die, .cpu_die = bmips_cpu_die,
#endif #endif
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
.kexec_nonboot_cpu = kexec_nonboot_cpu_jump, .kexec_nonboot_cpu = kexec_nonboot_cpu_jump,
#endif #endif
}; };
......
...@@ -392,7 +392,7 @@ static void cps_smp_finish(void) ...@@ -392,7 +392,7 @@ static void cps_smp_finish(void)
local_irq_enable(); local_irq_enable();
} }
#if defined(CONFIG_HOTPLUG_CPU) || defined(CONFIG_KEXEC) #if defined(CONFIG_HOTPLUG_CPU) || defined(CONFIG_KEXEC_CORE)
enum cpu_death { enum cpu_death {
CPU_DEATH_HALT, CPU_DEATH_HALT,
...@@ -429,7 +429,7 @@ static void cps_shutdown_this_cpu(enum cpu_death death) ...@@ -429,7 +429,7 @@ static void cps_shutdown_this_cpu(enum cpu_death death)
} }
} }
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
static void cps_kexec_nonboot_cpu(void) static void cps_kexec_nonboot_cpu(void)
{ {
...@@ -439,9 +439,9 @@ static void cps_kexec_nonboot_cpu(void) ...@@ -439,9 +439,9 @@ static void cps_kexec_nonboot_cpu(void)
cps_shutdown_this_cpu(CPU_DEATH_POWER); cps_shutdown_this_cpu(CPU_DEATH_POWER);
} }
#endif /* CONFIG_KEXEC */ #endif /* CONFIG_KEXEC_CORE */
#endif /* CONFIG_HOTPLUG_CPU || CONFIG_KEXEC */ #endif /* CONFIG_HOTPLUG_CPU || CONFIG_KEXEC_CORE */
#ifdef CONFIG_HOTPLUG_CPU #ifdef CONFIG_HOTPLUG_CPU
...@@ -610,7 +610,7 @@ static const struct plat_smp_ops cps_smp_ops = { ...@@ -610,7 +610,7 @@ static const struct plat_smp_ops cps_smp_ops = {
.cpu_die = cps_cpu_die, .cpu_die = cps_cpu_die,
.cleanup_dead_cpu = cps_cleanup_dead_cpu, .cleanup_dead_cpu = cps_cleanup_dead_cpu,
#endif #endif
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
.kexec_nonboot_cpu = cps_kexec_nonboot_cpu, .kexec_nonboot_cpu = cps_kexec_nonboot_cpu,
#endif #endif
}; };
......
...@@ -53,7 +53,7 @@ static void loongson_halt(void) ...@@ -53,7 +53,7 @@ static void loongson_halt(void)
} }
} }
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
/* 0X80000000~0X80200000 is safe */ /* 0X80000000~0X80200000 is safe */
#define MAX_ARGS 64 #define MAX_ARGS 64
...@@ -158,7 +158,7 @@ static int __init mips_reboot_setup(void) ...@@ -158,7 +158,7 @@ static int __init mips_reboot_setup(void)
_machine_halt = loongson_halt; _machine_halt = loongson_halt;
pm_power_off = loongson_poweroff; pm_power_off = loongson_poweroff;
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
kexec_argv = kmalloc(KEXEC_ARGV_SIZE, GFP_KERNEL); kexec_argv = kmalloc(KEXEC_ARGV_SIZE, GFP_KERNEL);
if (WARN_ON(!kexec_argv)) if (WARN_ON(!kexec_argv))
return -ENOMEM; return -ENOMEM;
......
...@@ -864,7 +864,7 @@ const struct plat_smp_ops loongson3_smp_ops = { ...@@ -864,7 +864,7 @@ const struct plat_smp_ops loongson3_smp_ops = {
.cpu_disable = loongson3_cpu_disable, .cpu_disable = loongson3_cpu_disable,
.cpu_die = loongson3_cpu_die, .cpu_die = loongson3_cpu_die,
#endif #endif
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
.kexec_nonboot_cpu = kexec_nonboot_cpu_jump, .kexec_nonboot_cpu = kexec_nonboot_cpu_jump,
#endif #endif
}; };
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