1/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
2#ifndef _UAPILINUX_KEXEC_H
3#define _UAPILINUX_KEXEC_H
4
5/* kexec system call - It loads the new kernel to boot into.
6 * kexec does not sync, or unmount filesystems so if you need
7 * that to happen you need to do that yourself.
8 */
9
10#include <linux/types.h>
11
12/* kexec flags for different usage scenarios */
13#define KEXEC_ON_CRASH 0x00000001
14#define KEXEC_PRESERVE_CONTEXT 0x00000002
15#define KEXEC_UPDATE_ELFCOREHDR 0x00000004
16#define KEXEC_CRASH_HOTPLUG_SUPPORT 0x00000008
17#define KEXEC_ARCH_MASK 0xffff0000
18
19/*
20 * Kexec file load interface flags.
21 * KEXEC_FILE_UNLOAD : Unload already loaded kexec/kdump image.
22 * KEXEC_FILE_ON_CRASH : Load/unload operation belongs to kdump image.
23 * KEXEC_FILE_NO_INITRAMFS : No initramfs is being loaded. Ignore the initrd
24 * fd field.
25 * KEXEC_FILE_FORCE_DTB : Force carrying over the current boot's DTB to the new
26 * kernel on x86. This is already the default behavior on
27 * some other architectures, like ARM64 and PowerPC.
28 */
29#define KEXEC_FILE_UNLOAD 0x00000001
30#define KEXEC_FILE_ON_CRASH 0x00000002
31#define KEXEC_FILE_NO_INITRAMFS 0x00000004
32#define KEXEC_FILE_DEBUG 0x00000008
33#define KEXEC_FILE_NO_CMA 0x00000010
34#define KEXEC_FILE_FORCE_DTB 0x00000020
35
36/* These values match the ELF architecture values.
37 * Unless there is a good reason that should continue to be the case.
38 */
39#define KEXEC_ARCH_DEFAULT ( 0 << 16)
40#define KEXEC_ARCH_386 ( 3 << 16)
41#define KEXEC_ARCH_68K ( 4 << 16)
42#define KEXEC_ARCH_PARISC (15 << 16)
43#define KEXEC_ARCH_X86_64 (62 << 16)
44#define KEXEC_ARCH_PPC (20 << 16)
45#define KEXEC_ARCH_PPC64 (21 << 16)
46#define KEXEC_ARCH_IA_64 (50 << 16)
47#define KEXEC_ARCH_ARM (40 << 16)
48#define KEXEC_ARCH_S390 (22 << 16)
49#define KEXEC_ARCH_SH (42 << 16)
50#define KEXEC_ARCH_MIPS_LE (10 << 16)
51#define KEXEC_ARCH_MIPS ( 8 << 16)
52#define KEXEC_ARCH_AARCH64 (183 << 16)
53#define KEXEC_ARCH_RISCV (243 << 16)
54#define KEXEC_ARCH_LOONGARCH (258 << 16)
55
56/* The artificial cap on the number of segments passed to kexec_load. */
57#define KEXEC_SEGMENT_MAX 16
58
59#ifndef __KERNEL__
60/*
61 * This structure is used to hold the arguments that are used when
62 * loading kernel binaries.
63 */
64struct kexec_segment {
65 const void *buf;
66 __kernel_size_t bufsz;
67 const void *mem;
68 __kernel_size_t memsz;
69};
70
71#endif /* __KERNEL__ */
72
73#endif /* _UAPILINUX_KEXEC_H */
74