| From: Baoquan He <bhe@redhat.com> |
| Subject: x86, crash: don't nest CONFIG_CRASH_DUMP ifdef inside CONFIG_KEXEC_CODE ifdef scope |
| Date: Tue, 30 Jan 2024 10:59:59 +0800 |
| |
| Michael pointed out that the CONFIG_CRASH_DUMP ifdef is nested inside |
| CONFIG_KEXEC_CODE ifdef scope in some XEN, Hyper-V codes. |
| |
| Although the nesting works well too since CONFIG_CRASH_DUMP has |
| dependency on CONFIG_KEXEC_CORE, it may cause confusion because there |
| are places where it's not nested, and people may think it needs to be |
| nested even though it doesn't have to. |
| |
| Fix that by moving CONFIG_CRASH_DUMP ifdeffery of codes out of |
| CONFIG_KEXEC_CODE ifdeffery scope. |
| |
| And also put function machine_crash_shutdown() definition inside |
| CONFIG_CRASH_DUMP ifdef scope instead of CONFIG_KEXEC_CORE ifdef. |
| |
| And also fix a building error Nathan reported as below by replacing |
| CONFIG_KEXEC_CORE ifdef with CONFIG_VMCORE_INFO ifdef. |
| |
| ==== |
| $ curl -LSso .config https://git.alpinelinux.org/aports/plain/community/linux-edge/config-edge.x86_64 |
| $ make -skj"$(nproc)" ARCH=x86_64 CROSS_COMPILE=x86_64-linux- olddefconfig all |
| .. |
| x86_64-linux-ld: arch/x86/xen/mmu_pv.o: in function `paddr_vmcoreinfo_note': |
| mmu_pv.c:(.text+0x3af3): undefined reference to `vmcoreinfo_note' |
| ==== |
| |
| Link: https://lore.kernel.org/all/SN6PR02MB4157931105FA68D72E3D3DB8D47B2@SN6PR02MB4157.namprd02.prod.outlook.com/T/#u |
| Link: https://lore.kernel.org/all/20240126045551.GA126645@dev-arch.thelio-3990X/T/#u |
| Link: https://lkml.kernel.org/r/ZbhmL/jQtZ7TFZqV@MiWiFi-R3L-srv |
| Signed-off-by: Baoquan He <bhe@redhat.com> |
| Reviewed-by: Michael Kelley <mhklinux@outlook.com> |
| Cc: Al Viro <viro@zeniv.linux.org.uk> |
| Cc: Eric W. Biederman <ebiederm@xmission.com> |
| Cc: Hari Bathini <hbathini@linux.ibm.com> |
| Cc: Klara Modin <klarasmodin@gmail.com> |
| Cc: Nathan Chancellor <nathan@kernel.org> |
| Cc: Pingfan Liu <piliu@redhat.com> |
| Cc: Stephen Rothwell <sfr@canb.auug.org.au> |
| Cc: Yang Li <yang.lee@linux.alibaba.com> |
| Signed-off-by: Andrew Morton <akpm@linux-foundation.org> |
| --- |
| |
| arch/x86/kernel/cpu/mshyperv.c | 10 ++++++---- |
| arch/x86/kernel/reboot.c | 2 +- |
| arch/x86/xen/enlighten_hvm.c | 4 ++-- |
| arch/x86/xen/mmu_pv.c | 2 +- |
| 4 files changed, 10 insertions(+), 8 deletions(-) |
| |
| --- a/arch/x86/kernel/cpu/mshyperv.c~x86-crash-wrap-crash-dumping-code-into-crash-related-ifdefs-fix |
| +++ a/arch/x86/kernel/cpu/mshyperv.c |
| @@ -209,6 +209,7 @@ static void hv_machine_shutdown(void) |
| if (kexec_in_progress) |
| hyperv_cleanup(); |
| } |
| +#endif /* CONFIG_KEXEC_CORE */ |
| |
| #ifdef CONFIG_CRASH_DUMP |
| static void hv_machine_crash_shutdown(struct pt_regs *regs) |
| @@ -222,8 +223,7 @@ static void hv_machine_crash_shutdown(st |
| /* Disable the hypercall page when there is only 1 active CPU. */ |
| hyperv_cleanup(); |
| } |
| -#endif |
| -#endif /* CONFIG_KEXEC_CORE */ |
| +#endif /* CONFIG_CRASH_DUMP */ |
| #endif /* CONFIG_HYPERV */ |
| |
| static uint32_t __init ms_hyperv_platform(void) |
| @@ -497,9 +497,11 @@ static void __init ms_hyperv_init_platfo |
| no_timer_check = 1; |
| #endif |
| |
| -#if IS_ENABLED(CONFIG_HYPERV) && defined(CONFIG_KEXEC_CORE) |
| +#if IS_ENABLED(CONFIG_HYPERV) |
| +#if defined(CONFIG_KEXEC_CORE) |
| machine_ops.shutdown = hv_machine_shutdown; |
| -#ifdef CONFIG_CRASH_DUMP |
| +#endif |
| +#if defined(CONFIG_CRASH_DUMP) |
| machine_ops.crash_shutdown = hv_machine_crash_shutdown; |
| #endif |
| #endif |
| --- a/arch/x86/kernel/reboot.c~x86-crash-wrap-crash-dumping-code-into-crash-related-ifdefs-fix |
| +++ a/arch/x86/kernel/reboot.c |
| @@ -826,7 +826,7 @@ void machine_halt(void) |
| machine_ops.halt(); |
| } |
| |
| -#ifdef CONFIG_KEXEC_CORE |
| +#ifdef CONFIG_CRASH_DUMP |
| void machine_crash_shutdown(struct pt_regs *regs) |
| { |
| machine_ops.crash_shutdown(regs); |
| --- a/arch/x86/xen/enlighten_hvm.c~x86-crash-wrap-crash-dumping-code-into-crash-related-ifdefs-fix |
| +++ a/arch/x86/xen/enlighten_hvm.c |
| @@ -148,6 +148,7 @@ static void xen_hvm_shutdown(void) |
| if (kexec_in_progress) |
| xen_reboot(SHUTDOWN_soft_reset); |
| } |
| +#endif |
| |
| #ifdef CONFIG_CRASH_DUMP |
| static void xen_hvm_crash_shutdown(struct pt_regs *regs) |
| @@ -156,7 +157,6 @@ static void xen_hvm_crash_shutdown(struc |
| xen_reboot(SHUTDOWN_soft_reset); |
| } |
| #endif |
| -#endif |
| |
| static int xen_cpu_up_prepare_hvm(unsigned int cpu) |
| { |
| @@ -238,10 +238,10 @@ static void __init xen_hvm_guest_init(vo |
| |
| #ifdef CONFIG_KEXEC_CORE |
| machine_ops.shutdown = xen_hvm_shutdown; |
| +#endif |
| #ifdef CONFIG_CRASH_DUMP |
| machine_ops.crash_shutdown = xen_hvm_crash_shutdown; |
| #endif |
| -#endif |
| } |
| |
| static __init int xen_parse_nopv(char *arg) |
| --- a/arch/x86/xen/mmu_pv.c~x86-crash-wrap-crash-dumping-code-into-crash-related-ifdefs-fix |
| +++ a/arch/x86/xen/mmu_pv.c |
| @@ -2520,7 +2520,7 @@ out: |
| } |
| EXPORT_SYMBOL_GPL(xen_remap_pfn); |
| |
| -#ifdef CONFIG_KEXEC_CORE |
| +#ifdef CONFIG_VMCORE_INFO |
| phys_addr_t paddr_vmcoreinfo_note(void) |
| { |
| if (xen_pv_domain()) |
| _ |