提交 2965faa5 编写于 作者: D Dave Young 提交者: Linus Torvalds

kexec: split kexec_load syscall from kexec core code

There are two kexec load syscalls, kexec_load another and kexec_file_load.
 kexec_file_load has been splited as kernel/kexec_file.c.  In this patch I
split kexec_load syscall code to kernel/kexec.c.

And add a new kconfig option KEXEC_CORE, so we can disable kexec_load and
use kexec_file_load only, or vice verse.

The original requirement is from Ted Ts'o, he want kexec kernel signature
being checked with CONFIG_KEXEC_VERIFY_SIG enabled.  But kexec-tools use
kexec_load syscall can bypass the checking.

Vivek Goyal proposed to create a common kconfig option so user can compile
in only one syscall for loading kexec kernel.  KEXEC/KEXEC_FILE selects
KEXEC_CORE so that old config files still work.

Because there's general code need CONFIG_KEXEC_CORE, so I updated all the
architecture Kconfig with a new option KEXEC_CORE, and let KEXEC selects
KEXEC_CORE in arch Kconfig.  Also updated general kernel code with to
kexec_load syscall.

[akpm@linux-foundation.org: coding-style fixes]
Signed-off-by: NDave Young <dyoung@redhat.com>
Cc: Eric W. Biederman <ebiederm@xmission.com>
Cc: Vivek Goyal <vgoyal@redhat.com>
Cc: Petr Tesarik <ptesarik@suse.cz>
Cc: Theodore Ts'o <tytso@mit.edu>
Cc: Josh Boyer <jwboyer@fedoraproject.org>
Cc: David Howells <dhowells@redhat.com>
Cc: Geert Uytterhoeven <geert@linux-m68k.org>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 a43cac0d
...@@ -2,6 +2,9 @@ ...@@ -2,6 +2,9 @@
# General architecture dependent options # General architecture dependent options
# #
config KEXEC_CORE
bool
config OPROFILE config OPROFILE
tristate "OProfile system profiling" tristate "OProfile system profiling"
depends on PROFILING depends on PROFILING
......
...@@ -2020,6 +2020,7 @@ config KEXEC ...@@ -2020,6 +2020,7 @@ config KEXEC
bool "Kexec system call (EXPERIMENTAL)" bool "Kexec system call (EXPERIMENTAL)"
depends on (!SMP || PM_SLEEP_SMP) depends on (!SMP || PM_SLEEP_SMP)
depends on !CPU_V7M depends on !CPU_V7M
select KEXEC_CORE
help help
kexec is a system call that implements the ability to shutdown your kexec is a system call that implements the ability to shutdown your
current kernel, and to start another kernel. It is like a reboot current kernel, and to start another kernel. It is like a reboot
......
...@@ -518,6 +518,7 @@ source "drivers/sn/Kconfig" ...@@ -518,6 +518,7 @@ source "drivers/sn/Kconfig"
config KEXEC config KEXEC
bool "kexec system call" bool "kexec system call"
depends on !IA64_HP_SIM && (!SMP || HOTPLUG_CPU) depends on !IA64_HP_SIM && (!SMP || HOTPLUG_CPU)
select KEXEC_CORE
help help
kexec is a system call that implements the ability to shutdown your kexec is a system call that implements the ability to shutdown your
current kernel, and to start another kernel. It is like a reboot current kernel, and to start another kernel. It is like a reboot
......
...@@ -95,6 +95,7 @@ config MMU_SUN3 ...@@ -95,6 +95,7 @@ config MMU_SUN3
config KEXEC config KEXEC
bool "kexec system call" bool "kexec system call"
depends on M68KCLASSIC depends on M68KCLASSIC
select KEXEC_CORE
help help
kexec is a system call that implements the ability to shutdown your kexec is a system call that implements the ability to shutdown your
current kernel, and to start another kernel. It is like a reboot current kernel, and to start another kernel. It is like a reboot
......
...@@ -2597,6 +2597,7 @@ source "kernel/Kconfig.preempt" ...@@ -2597,6 +2597,7 @@ source "kernel/Kconfig.preempt"
config KEXEC config KEXEC
bool "Kexec system call" bool "Kexec system call"
select KEXEC_CORE
help help
kexec is a system call that implements the ability to shutdown your kexec is a system call that implements the ability to shutdown your
current kernel, and to start another kernel. It is like a reboot current kernel, and to start another kernel. It is like a reboot
......
...@@ -420,6 +420,7 @@ config PPC64_SUPPORTS_MEMORY_FAILURE ...@@ -420,6 +420,7 @@ config PPC64_SUPPORTS_MEMORY_FAILURE
config KEXEC config KEXEC
bool "kexec system call" bool "kexec system call"
depends on (PPC_BOOK3S || FSL_BOOKE || (44x && !SMP)) depends on (PPC_BOOK3S || FSL_BOOKE || (44x && !SMP))
select KEXEC_CORE
help help
kexec is a system call that implements the ability to shutdown your kexec is a system call that implements the ability to shutdown your
current kernel, and to start another kernel. It is like a reboot current kernel, and to start another kernel. It is like a reboot
......
...@@ -48,6 +48,7 @@ config ARCH_SUPPORTS_DEBUG_PAGEALLOC ...@@ -48,6 +48,7 @@ config ARCH_SUPPORTS_DEBUG_PAGEALLOC
config KEXEC config KEXEC
def_bool y def_bool y
select KEXEC_CORE
config AUDIT_ARCH config AUDIT_ARCH
def_bool y def_bool y
......
...@@ -602,6 +602,7 @@ source kernel/Kconfig.hz ...@@ -602,6 +602,7 @@ source kernel/Kconfig.hz
config KEXEC config KEXEC
bool "kexec system call (EXPERIMENTAL)" bool "kexec system call (EXPERIMENTAL)"
depends on SUPERH32 && MMU depends on SUPERH32 && MMU
select KEXEC_CORE
help help
kexec is a system call that implements the ability to shutdown your kexec is a system call that implements the ability to shutdown your
current kernel, and to start another kernel. It is like a reboot current kernel, and to start another kernel. It is like a reboot
......
...@@ -205,6 +205,7 @@ source "kernel/Kconfig.hz" ...@@ -205,6 +205,7 @@ source "kernel/Kconfig.hz"
config KEXEC config KEXEC
bool "kexec system call" bool "kexec system call"
select KEXEC_CORE
---help--- ---help---
kexec is a system call that implements the ability to shutdown your kexec is a system call that implements the ability to shutdown your
current kernel, and to start another kernel. It is like a reboot current kernel, and to start another kernel. It is like a reboot
......
...@@ -1754,6 +1754,7 @@ source kernel/Kconfig.hz ...@@ -1754,6 +1754,7 @@ source kernel/Kconfig.hz
config KEXEC config KEXEC
bool "kexec system call" bool "kexec system call"
select KEXEC_CORE
---help--- ---help---
kexec is a system call that implements the ability to shutdown your kexec is a system call that implements the ability to shutdown your
current kernel, and to start another kernel. It is like a reboot current kernel, and to start another kernel. It is like a reboot
...@@ -1770,8 +1771,8 @@ config KEXEC ...@@ -1770,8 +1771,8 @@ config KEXEC
config KEXEC_FILE config KEXEC_FILE
bool "kexec file based system call" bool "kexec file based system call"
select KEXEC_CORE
select BUILD_BIN2C select BUILD_BIN2C
depends on KEXEC
depends on X86_64 depends on X86_64
depends on CRYPTO=y depends on CRYPTO=y
depends on CRYPTO_SHA256=y depends on CRYPTO_SHA256=y
......
...@@ -414,7 +414,7 @@ xloadflags: ...@@ -414,7 +414,7 @@ xloadflags:
# define XLF23 0 # define XLF23 0
#endif #endif
#if defined(CONFIG_X86_64) && defined(CONFIG_EFI) && defined(CONFIG_KEXEC) #if defined(CONFIG_X86_64) && defined(CONFIG_EFI) && defined(CONFIG_KEXEC_CORE)
# define XLF4 XLF_EFI_KEXEC # define XLF4 XLF_EFI_KEXEC
#else #else
# define XLF4 0 # define XLF4 0
......
...@@ -29,7 +29,7 @@ extern void show_trace(struct task_struct *t, struct pt_regs *regs, ...@@ -29,7 +29,7 @@ extern void show_trace(struct task_struct *t, struct pt_regs *regs,
extern void __show_regs(struct pt_regs *regs, int all); extern void __show_regs(struct pt_regs *regs, int all);
extern unsigned long oops_begin(void); extern unsigned long oops_begin(void);
extern void oops_end(unsigned long, struct pt_regs *, int signr); extern void oops_end(unsigned long, struct pt_regs *, int signr);
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
extern int in_crash_kexec; extern int in_crash_kexec;
#else #else
/* no crash dump is ever in progress if no crash kernel can be kexec'd */ /* no crash dump is ever in progress if no crash kernel can be kexec'd */
......
...@@ -71,8 +71,8 @@ obj-$(CONFIG_LIVEPATCH) += livepatch.o ...@@ -71,8 +71,8 @@ obj-$(CONFIG_LIVEPATCH) += livepatch.o
obj-$(CONFIG_FUNCTION_GRAPH_TRACER) += ftrace.o obj-$(CONFIG_FUNCTION_GRAPH_TRACER) += ftrace.o
obj-$(CONFIG_FTRACE_SYSCALLS) += ftrace.o obj-$(CONFIG_FTRACE_SYSCALLS) += ftrace.o
obj-$(CONFIG_X86_TSC) += trace_clock.o obj-$(CONFIG_X86_TSC) += trace_clock.o
obj-$(CONFIG_KEXEC) += machine_kexec_$(BITS).o obj-$(CONFIG_KEXEC_CORE) += machine_kexec_$(BITS).o
obj-$(CONFIG_KEXEC) += relocate_kernel_$(BITS).o crash.o obj-$(CONFIG_KEXEC_CORE) += relocate_kernel_$(BITS).o crash.o
obj-$(CONFIG_KEXEC_FILE) += kexec-bzimage64.o obj-$(CONFIG_KEXEC_FILE) += kexec-bzimage64.o
obj-$(CONFIG_CRASH_DUMP) += crash_dump_$(BITS).o obj-$(CONFIG_CRASH_DUMP) += crash_dump_$(BITS).o
obj-y += kprobes/ obj-y += kprobes/
......
...@@ -200,7 +200,7 @@ static void kvm_setup_secondary_clock(void) ...@@ -200,7 +200,7 @@ static void kvm_setup_secondary_clock(void)
* kind of shutdown from our side, we unregister the clock by writting anything * kind of shutdown from our side, we unregister the clock by writting anything
* that does not have the 'enable' bit set in the msr * that does not have the 'enable' bit set in the msr
*/ */
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
static void kvm_crash_shutdown(struct pt_regs *regs) static void kvm_crash_shutdown(struct pt_regs *regs)
{ {
native_write_msr(msr_kvm_system_time, 0, 0); native_write_msr(msr_kvm_system_time, 0, 0);
...@@ -259,7 +259,7 @@ void __init kvmclock_init(void) ...@@ -259,7 +259,7 @@ void __init kvmclock_init(void)
x86_platform.save_sched_clock_state = kvm_save_sched_clock_state; x86_platform.save_sched_clock_state = kvm_save_sched_clock_state;
x86_platform.restore_sched_clock_state = kvm_restore_sched_clock_state; x86_platform.restore_sched_clock_state = kvm_restore_sched_clock_state;
machine_ops.shutdown = kvm_shutdown; machine_ops.shutdown = kvm_shutdown;
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
machine_ops.crash_shutdown = kvm_crash_shutdown; machine_ops.crash_shutdown = kvm_crash_shutdown;
#endif #endif
kvm_get_preset_lpj(); kvm_get_preset_lpj();
......
...@@ -673,7 +673,7 @@ struct machine_ops machine_ops = { ...@@ -673,7 +673,7 @@ struct machine_ops machine_ops = {
.emergency_restart = native_machine_emergency_restart, .emergency_restart = native_machine_emergency_restart,
.restart = native_machine_restart, .restart = native_machine_restart,
.halt = native_machine_halt, .halt = native_machine_halt,
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
.crash_shutdown = native_machine_crash_shutdown, .crash_shutdown = native_machine_crash_shutdown,
#endif #endif
}; };
...@@ -703,7 +703,7 @@ void machine_halt(void) ...@@ -703,7 +703,7 @@ void machine_halt(void)
machine_ops.halt(); machine_ops.halt();
} }
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
void machine_crash_shutdown(struct pt_regs *regs) void machine_crash_shutdown(struct pt_regs *regs)
{ {
machine_ops.crash_shutdown(regs); machine_ops.crash_shutdown(regs);
......
...@@ -478,7 +478,7 @@ static void __init memblock_x86_reserve_range_setup_data(void) ...@@ -478,7 +478,7 @@ static void __init memblock_x86_reserve_range_setup_data(void)
* --------- Crashkernel reservation ------------------------------ * --------- Crashkernel reservation ------------------------------
*/ */
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
/* /*
* Keep the crash kernel below this limit. On 32 bits earlier kernels * Keep the crash kernel below this limit. On 32 bits earlier kernels
......
...@@ -364,7 +364,7 @@ INIT_PER_CPU(irq_stack_union); ...@@ -364,7 +364,7 @@ INIT_PER_CPU(irq_stack_union);
#endif /* CONFIG_X86_32 */ #endif /* CONFIG_X86_32 */
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
#include <asm/kexec.h> #include <asm/kexec.h>
. = ASSERT(kexec_control_code_size <= KEXEC_CONTROL_CODE_MAX_SIZE, . = ASSERT(kexec_control_code_size <= KEXEC_CONTROL_CODE_MAX_SIZE,
......
...@@ -1264,7 +1264,7 @@ static void vmcs_load(struct vmcs *vmcs) ...@@ -1264,7 +1264,7 @@ static void vmcs_load(struct vmcs *vmcs)
vmcs, phys_addr); vmcs, phys_addr);
} }
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
/* /*
* This bitmap is used to indicate whether the vmclear * This bitmap is used to indicate whether the vmclear
* operation is enabled on all cpus. All disabled by * operation is enabled on all cpus. All disabled by
...@@ -1302,7 +1302,7 @@ static void crash_vmclear_local_loaded_vmcss(void) ...@@ -1302,7 +1302,7 @@ static void crash_vmclear_local_loaded_vmcss(void)
#else #else
static inline void crash_enable_local_vmclear(int cpu) { } static inline void crash_enable_local_vmclear(int cpu) { }
static inline void crash_disable_local_vmclear(int cpu) { } static inline void crash_disable_local_vmclear(int cpu) { }
#endif /* CONFIG_KEXEC */ #endif /* CONFIG_KEXEC_CORE */
static void __loaded_vmcs_clear(void *arg) static void __loaded_vmcs_clear(void *arg)
{ {
...@@ -10411,7 +10411,7 @@ static int __init vmx_init(void) ...@@ -10411,7 +10411,7 @@ static int __init vmx_init(void)
if (r) if (r)
return r; return r;
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
rcu_assign_pointer(crash_vmclear_loaded_vmcss, rcu_assign_pointer(crash_vmclear_loaded_vmcss,
crash_vmclear_local_loaded_vmcss); crash_vmclear_local_loaded_vmcss);
#endif #endif
...@@ -10421,7 +10421,7 @@ static int __init vmx_init(void) ...@@ -10421,7 +10421,7 @@ static int __init vmx_init(void)
static void __exit vmx_exit(void) static void __exit vmx_exit(void)
{ {
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
RCU_INIT_POINTER(crash_vmclear_loaded_vmcss, NULL); RCU_INIT_POINTER(crash_vmclear_loaded_vmcss, NULL);
synchronize_rcu(); synchronize_rcu();
#endif #endif
......
...@@ -650,7 +650,7 @@ static void __init get_systab_virt_addr(efi_memory_desc_t *md) ...@@ -650,7 +650,7 @@ static void __init get_systab_virt_addr(efi_memory_desc_t *md)
static void __init save_runtime_map(void) static void __init save_runtime_map(void)
{ {
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
efi_memory_desc_t *md; efi_memory_desc_t *md;
void *tmp, *p, *q = NULL; void *tmp, *p, *q = NULL;
int count = 0; int count = 0;
...@@ -748,7 +748,7 @@ static void * __init efi_map_regions(int *count, int *pg_shift) ...@@ -748,7 +748,7 @@ static void * __init efi_map_regions(int *count, int *pg_shift)
static void __init kexec_enter_virtual_mode(void) static void __init kexec_enter_virtual_mode(void)
{ {
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
efi_memory_desc_t *md; efi_memory_desc_t *md;
void *p; void *p;
......
...@@ -492,7 +492,7 @@ static void uv_nmi_touch_watchdogs(void) ...@@ -492,7 +492,7 @@ static void uv_nmi_touch_watchdogs(void)
touch_nmi_watchdog(); touch_nmi_watchdog();
} }
#if defined(CONFIG_KEXEC) #if defined(CONFIG_KEXEC_CORE)
static atomic_t uv_nmi_kexec_failed; static atomic_t uv_nmi_kexec_failed;
static void uv_nmi_kdump(int cpu, int master, struct pt_regs *regs) static void uv_nmi_kdump(int cpu, int master, struct pt_regs *regs)
{ {
...@@ -519,13 +519,13 @@ static void uv_nmi_kdump(int cpu, int master, struct pt_regs *regs) ...@@ -519,13 +519,13 @@ static void uv_nmi_kdump(int cpu, int master, struct pt_regs *regs)
uv_nmi_sync_exit(0); uv_nmi_sync_exit(0);
} }
#else /* !CONFIG_KEXEC */ #else /* !CONFIG_KEXEC_CORE */
static inline void uv_nmi_kdump(int cpu, int master, struct pt_regs *regs) static inline void uv_nmi_kdump(int cpu, int master, struct pt_regs *regs)
{ {
if (master) if (master)
pr_err("UV: NMI kdump: KEXEC not supported in this kernel\n"); pr_err("UV: NMI kdump: KEXEC not supported in this kernel\n");
} }
#endif /* !CONFIG_KEXEC */ #endif /* !CONFIG_KEXEC_CORE */
#ifdef CONFIG_KGDB #ifdef CONFIG_KGDB
#ifdef CONFIG_KGDB_KDB #ifdef CONFIG_KGDB_KDB
......
...@@ -43,7 +43,7 @@ config EFI_VARS_PSTORE_DEFAULT_DISABLE ...@@ -43,7 +43,7 @@ config EFI_VARS_PSTORE_DEFAULT_DISABLE
config EFI_RUNTIME_MAP config EFI_RUNTIME_MAP
bool "Export efi runtime maps to sysfs" bool "Export efi runtime maps to sysfs"
depends on X86 && EFI && KEXEC depends on X86 && EFI && KEXEC_CORE
default y default y
help help
Export efi runtime memory maps to /sys/firmware/efi/runtime-map. Export efi runtime memory maps to /sys/firmware/efi/runtime-map.
......
...@@ -467,7 +467,7 @@ static void pci_device_shutdown(struct device *dev) ...@@ -467,7 +467,7 @@ static void pci_device_shutdown(struct device *dev)
pci_msi_shutdown(pci_dev); pci_msi_shutdown(pci_dev);
pci_msix_shutdown(pci_dev); pci_msix_shutdown(pci_dev);
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
/* /*
* If this is a kexec reboot, turn off Bus Master bit on the * If this is a kexec reboot, turn off Bus Master bit on the
* device to tell it to not continue to do DMA. Don't touch * device to tell it to not continue to do DMA. Don't touch
......
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
#include <uapi/linux/kexec.h> #include <uapi/linux/kexec.h>
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
#include <linux/list.h> #include <linux/list.h>
#include <linux/linkage.h> #include <linux/linkage.h>
#include <linux/compat.h> #include <linux/compat.h>
...@@ -329,13 +329,13 @@ int __weak arch_kexec_apply_relocations_add(const Elf_Ehdr *ehdr, ...@@ -329,13 +329,13 @@ int __weak arch_kexec_apply_relocations_add(const Elf_Ehdr *ehdr,
int __weak arch_kexec_apply_relocations(const Elf_Ehdr *ehdr, Elf_Shdr *sechdrs, int __weak arch_kexec_apply_relocations(const Elf_Ehdr *ehdr, Elf_Shdr *sechdrs,
unsigned int relsec); unsigned int relsec);
#else /* !CONFIG_KEXEC */ #else /* !CONFIG_KEXEC_CORE */
struct pt_regs; struct pt_regs;
struct task_struct; struct task_struct;
static inline void crash_kexec(struct pt_regs *regs) { } static inline void crash_kexec(struct pt_regs *regs) { }
static inline int kexec_should_crash(struct task_struct *p) { return 0; } static inline int kexec_should_crash(struct task_struct *p) { return 0; }
#define kexec_in_progress false #define kexec_in_progress false
#endif /* CONFIG_KEXEC */ #endif /* CONFIG_KEXEC_CORE */
#endif /* !defined(__ASSEBMLY__) */ #endif /* !defined(__ASSEBMLY__) */
......
...@@ -526,14 +526,14 @@ extern unsigned long __initramfs_size; ...@@ -526,14 +526,14 @@ extern unsigned long __initramfs_size;
static void __init free_initrd(void) static void __init free_initrd(void)
{ {
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
unsigned long crashk_start = (unsigned long)__va(crashk_res.start); unsigned long crashk_start = (unsigned long)__va(crashk_res.start);
unsigned long crashk_end = (unsigned long)__va(crashk_res.end); unsigned long crashk_end = (unsigned long)__va(crashk_res.end);
#endif #endif
if (do_retain_initrd) if (do_retain_initrd)
goto skip; goto skip;
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
/* /*
* If the initrd region is overlapped with crashkernel reserved region, * If the initrd region is overlapped with crashkernel reserved region,
* free only memory that is not part of crashkernel region. * free only memory that is not part of crashkernel region.
......
...@@ -49,6 +49,7 @@ obj-$(CONFIG_MODULES) += module.o ...@@ -49,6 +49,7 @@ obj-$(CONFIG_MODULES) += module.o
obj-$(CONFIG_MODULE_SIG) += module_signing.o obj-$(CONFIG_MODULE_SIG) += module_signing.o
obj-$(CONFIG_KALLSYMS) += kallsyms.o obj-$(CONFIG_KALLSYMS) += kallsyms.o
obj-$(CONFIG_BSD_PROCESS_ACCT) += acct.o obj-$(CONFIG_BSD_PROCESS_ACCT) += acct.o
obj-$(CONFIG_KEXEC_CORE) += kexec_core.o
obj-$(CONFIG_KEXEC) += kexec.o obj-$(CONFIG_KEXEC) += kexec.o
obj-$(CONFIG_KEXEC_FILE) += kexec_file.o obj-$(CONFIG_KEXEC_FILE) += kexec_file.o
obj-$(CONFIG_BACKTRACE_SELF_TEST) += backtracetest.o obj-$(CONFIG_BACKTRACE_SELF_TEST) += backtracetest.o
......
...@@ -9094,7 +9094,7 @@ static void perf_event_init_cpu(int cpu) ...@@ -9094,7 +9094,7 @@ static void perf_event_init_cpu(int cpu)
mutex_unlock(&swhash->hlist_mutex); mutex_unlock(&swhash->hlist_mutex);
} }
#if defined CONFIG_HOTPLUG_CPU || defined CONFIG_KEXEC #if defined CONFIG_HOTPLUG_CPU || defined CONFIG_KEXEC_CORE
static void __perf_event_exit_context(void *__info) static void __perf_event_exit_context(void *__info)
{ {
struct remove_event re = { .detach_group = true }; struct remove_event re = { .detach_group = true };
......
此差异已折叠。
此差异已折叠。
...@@ -90,7 +90,7 @@ static ssize_t profiling_store(struct kobject *kobj, ...@@ -90,7 +90,7 @@ static ssize_t profiling_store(struct kobject *kobj,
KERNEL_ATTR_RW(profiling); KERNEL_ATTR_RW(profiling);
#endif #endif
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
static ssize_t kexec_loaded_show(struct kobject *kobj, static ssize_t kexec_loaded_show(struct kobject *kobj,
struct kobj_attribute *attr, char *buf) struct kobj_attribute *attr, char *buf)
{ {
...@@ -134,7 +134,7 @@ static ssize_t vmcoreinfo_show(struct kobject *kobj, ...@@ -134,7 +134,7 @@ static ssize_t vmcoreinfo_show(struct kobject *kobj,
} }
KERNEL_ATTR_RO(vmcoreinfo); KERNEL_ATTR_RO(vmcoreinfo);
#endif /* CONFIG_KEXEC */ #endif /* CONFIG_KEXEC_CORE */
/* whether file capabilities are enabled */ /* whether file capabilities are enabled */
static ssize_t fscaps_show(struct kobject *kobj, static ssize_t fscaps_show(struct kobject *kobj,
...@@ -196,7 +196,7 @@ static struct attribute * kernel_attrs[] = { ...@@ -196,7 +196,7 @@ static struct attribute * kernel_attrs[] = {
#ifdef CONFIG_PROFILING #ifdef CONFIG_PROFILING
&profiling_attr.attr, &profiling_attr.attr,
#endif #endif
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
&kexec_loaded_attr.attr, &kexec_loaded_attr.attr,
&kexec_crash_loaded_attr.attr, &kexec_crash_loaded_attr.attr,
&kexec_crash_size_attr.attr, &kexec_crash_size_attr.attr,
......
...@@ -835,7 +835,7 @@ const struct file_operations kmsg_fops = { ...@@ -835,7 +835,7 @@ const struct file_operations kmsg_fops = {
.release = devkmsg_release, .release = devkmsg_release,
}; };
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
/* /*
* This appends the listed symbols to /proc/vmcore * This appends the listed symbols to /proc/vmcore
* *
......
...@@ -346,7 +346,7 @@ SYSCALL_DEFINE4(reboot, int, magic1, int, magic2, unsigned int, cmd, ...@@ -346,7 +346,7 @@ SYSCALL_DEFINE4(reboot, int, magic1, int, magic2, unsigned int, cmd,
kernel_restart(buffer); kernel_restart(buffer);
break; break;
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
case LINUX_REBOOT_CMD_KEXEC: case LINUX_REBOOT_CMD_KEXEC:
ret = kernel_kexec(); ret = kernel_kexec();
break; break;
......
...@@ -621,7 +621,7 @@ static struct ctl_table kern_table[] = { ...@@ -621,7 +621,7 @@ static struct ctl_table kern_table[] = {
.proc_handler = proc_dointvec, .proc_handler = proc_dointvec,
}, },
#endif #endif
#ifdef CONFIG_KEXEC #ifdef CONFIG_KEXEC_CORE
{ {
.procname = "kexec_load_disabled", .procname = "kexec_load_disabled",
.data = &kexec_load_disabled, .data = &kexec_load_disabled,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册