Viewing file: kexec.h (1.46 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* SPDX-License-Identifier: GPL-2.0 */ /* * kexec.h for kexec * * Copyright (C) 2022 Loongson Technology Corporation Limited */
#ifndef _ASM_KEXEC_H #define _ASM_KEXEC_H
#include <asm/stacktrace.h> #include <asm/page.h>
/* Maximum physical address we can use pages from */ #define KEXEC_SOURCE_MEMORY_LIMIT (-1UL) /* Maximum address we can reach in physical address mode */ #define KEXEC_DESTINATION_MEMORY_LIMIT (-1UL) /* Maximum address we can use for the control code buffer */ #define KEXEC_CONTROL_MEMORY_LIMIT (-1UL)
/* Reserve a page for the control code buffer */ #define KEXEC_CONTROL_PAGE_SIZE PAGE_SIZE
/* The native architecture */ #define KEXEC_ARCH KEXEC_ARCH_LOONGARCH
static inline void crash_setup_regs(struct pt_regs *newregs, struct pt_regs *oldregs) { if (oldregs) memcpy(newregs, oldregs, sizeof(*newregs)); else prepare_frametrace(newregs); }
#define ARCH_HAS_KIMAGE_ARCH
struct kimage_arch { unsigned long efi_boot; unsigned long cmdline_ptr; unsigned long systable_ptr; };
typedef void (*do_kexec_t)(unsigned long efi_boot, unsigned long cmdline_ptr, unsigned long systable_ptr, unsigned long start_addr, unsigned long first_ind_entry);
struct kimage; extern const unsigned char relocate_new_kernel[]; extern const size_t relocate_new_kernel_size; extern void kexec_reboot(void);
#ifdef CONFIG_SMP extern atomic_t kexec_ready_to_reboot; extern const unsigned char kexec_smp_wait[]; #endif
#endif /* !_ASM_KEXEC_H */
|