| 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
| 2 | /* |
| 3 | * Copyright IBM Corp. 2005 |
| 4 | * |
| 5 | * Author(s): Rolf Adelsberger <adelsberger@de.ibm.com> |
| 6 | * |
| 7 | */ |
| 8 | |
| 9 | #ifndef _S390_KEXEC_H |
| 10 | #define _S390_KEXEC_H |
| 11 | |
| 12 | #include <linux/module.h> |
| 13 | |
| 14 | #include <asm/processor.h> |
| 15 | #include <asm/page.h> |
| 16 | #include <asm/setup.h> |
| 17 | /* |
| 18 | * KEXEC_SOURCE_MEMORY_LIMIT maximum page get_free_page can return. |
| 19 | * I.e. Maximum page that is mapped directly into kernel memory, |
| 20 | * and kmap is not required. |
| 21 | */ |
| 22 | |
| 23 | /* Maximum physical address we can use pages from */ |
| 24 | #define KEXEC_SOURCE_MEMORY_LIMIT (-1UL) |
| 25 | |
| 26 | /* Maximum address we can reach in physical address mode */ |
| 27 | #define KEXEC_DESTINATION_MEMORY_LIMIT (-1UL) |
| 28 | |
| 29 | /* Maximum address we can use for the control pages */ |
| 30 | /* Not more than 2GB */ |
| 31 | #define KEXEC_CONTROL_MEMORY_LIMIT (1UL<<31) |
| 32 | |
| 33 | /* Allocate control page with GFP_DMA */ |
| 34 | #define KEXEC_CONTROL_MEMORY_GFP (GFP_DMA | __GFP_NORETRY) |
| 35 | |
| 36 | /* Maximum address we can use for the crash control pages */ |
| 37 | #define KEXEC_CRASH_CONTROL_MEMORY_LIMIT (-1UL) |
| 38 | |
| 39 | /* Allocate one page for the pdp and the second for the code */ |
| 40 | #define KEXEC_CONTROL_PAGE_SIZE 4096 |
| 41 | |
| 42 | /* Alignment of crashkernel memory */ |
| 43 | #define KEXEC_CRASH_MEM_ALIGN HPAGE_SIZE |
| 44 | |
| 45 | /* The native architecture */ |
| 46 | #define KEXEC_ARCH KEXEC_ARCH_S390 |
| 47 | |
| 48 | /* Allow kexec_file to load a segment to 0 */ |
| 49 | #define KEXEC_BUF_MEM_UNKNOWN -1 |
| 50 | |
| 51 | /* Provide a dummy definition to avoid build failures. */ |
| 52 | static inline void crash_setup_regs(struct pt_regs *newregs, |
| 53 | struct pt_regs *oldregs) { } |
| 54 | |
| 55 | struct kimage; |
| 56 | struct s390_load_data { |
| 57 | /* Pointer to the kernel buffer. Used to register cmdline etc.. */ |
| 58 | void *kernel_buf; |
| 59 | |
| 60 | /* Load address of the kernel_buf. */ |
| 61 | unsigned long kernel_mem; |
| 62 | |
| 63 | /* Parmarea in the kernel buffer. */ |
| 64 | struct parmarea *parm; |
| 65 | |
| 66 | /* Total size of loaded segments in memory. Used as an offset. */ |
| 67 | size_t memsz; |
| 68 | |
| 69 | struct ipl_report *report; |
| 70 | }; |
| 71 | |
| 72 | int s390_verify_sig(const char *kernel, unsigned long kernel_len); |
| 73 | void *kexec_file_add_components(struct kimage *image, |
| 74 | int (*add_kernel)(struct kimage *image, |
| 75 | struct s390_load_data *data)); |
| 76 | int arch_kexec_do_relocs(int r_type, void *loc, unsigned long val, |
| 77 | unsigned long addr); |
| 78 | |
| 79 | #define ARCH_HAS_KIMAGE_ARCH |
| 80 | |
| 81 | struct kimage_arch { |
| 82 | void *ipl_buf; |
| 83 | }; |
| 84 | |
| 85 | extern const struct kexec_file_ops s390_kexec_image_ops; |
| 86 | extern const struct kexec_file_ops s390_kexec_elf_ops; |
| 87 | |
| 88 | #ifdef CONFIG_CRASH_DUMP |
| 89 | void crash_free_reserved_phys_range(unsigned long begin, unsigned long end); |
| 90 | #define crash_free_reserved_phys_range crash_free_reserved_phys_range |
| 91 | |
| 92 | void arch_kexec_protect_crashkres(void); |
| 93 | #define arch_kexec_protect_crashkres arch_kexec_protect_crashkres |
| 94 | |
| 95 | void arch_kexec_unprotect_crashkres(void); |
| 96 | #define arch_kexec_unprotect_crashkres arch_kexec_unprotect_crashkres |
| 97 | |
| 98 | bool is_kdump_kernel(void); |
| 99 | #define is_kdump_kernel is_kdump_kernel |
| 100 | #endif |
| 101 | |
| 102 | #ifdef CONFIG_KEXEC_FILE |
| 103 | struct purgatory_info; |
| 104 | int arch_kexec_apply_relocations_add(struct purgatory_info *pi, |
| 105 | Elf_Shdr *section, |
| 106 | const Elf_Shdr *relsec, |
| 107 | const Elf_Shdr *symtab); |
| 108 | #define arch_kexec_apply_relocations_add arch_kexec_apply_relocations_add |
| 109 | |
| 110 | int arch_kimage_file_post_load_cleanup(struct kimage *image); |
| 111 | #define arch_kimage_file_post_load_cleanup arch_kimage_file_post_load_cleanup |
| 112 | #endif |
| 113 | #endif /*_S390_KEXEC_H */ |