Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux
at v6.16 109 lines 2.6 kB view raw
1/* SPDX-License-Identifier: GPL-2.0 */ 2#ifndef LINUX_KEXEC_HANDOVER_H 3#define LINUX_KEXEC_HANDOVER_H 4 5#include <linux/types.h> 6#include <linux/errno.h> 7 8struct kho_scratch { 9 phys_addr_t addr; 10 phys_addr_t size; 11}; 12 13/* KHO Notifier index */ 14enum kho_event { 15 KEXEC_KHO_FINALIZE = 0, 16 KEXEC_KHO_ABORT = 1, 17}; 18 19struct folio; 20struct notifier_block; 21 22#define DECLARE_KHOSER_PTR(name, type) \ 23 union { \ 24 phys_addr_t phys; \ 25 type ptr; \ 26 } name 27#define KHOSER_STORE_PTR(dest, val) \ 28 ({ \ 29 typeof(val) v = val; \ 30 typecheck(typeof((dest).ptr), v); \ 31 (dest).phys = virt_to_phys(v); \ 32 }) 33#define KHOSER_LOAD_PTR(src) \ 34 ({ \ 35 typeof(src) s = src; \ 36 (typeof((s).ptr))((s).phys ? phys_to_virt((s).phys) : NULL); \ 37 }) 38 39struct kho_serialization; 40 41#ifdef CONFIG_KEXEC_HANDOVER 42bool kho_is_enabled(void); 43 44int kho_preserve_folio(struct folio *folio); 45int kho_preserve_phys(phys_addr_t phys, size_t size); 46struct folio *kho_restore_folio(phys_addr_t phys); 47int kho_add_subtree(struct kho_serialization *ser, const char *name, void *fdt); 48int kho_retrieve_subtree(const char *name, phys_addr_t *phys); 49 50int register_kho_notifier(struct notifier_block *nb); 51int unregister_kho_notifier(struct notifier_block *nb); 52 53void kho_memory_init(void); 54 55void kho_populate(phys_addr_t fdt_phys, u64 fdt_len, phys_addr_t scratch_phys, 56 u64 scratch_len); 57#else 58static inline bool kho_is_enabled(void) 59{ 60 return false; 61} 62 63static inline int kho_preserve_folio(struct folio *folio) 64{ 65 return -EOPNOTSUPP; 66} 67 68static inline int kho_preserve_phys(phys_addr_t phys, size_t size) 69{ 70 return -EOPNOTSUPP; 71} 72 73static inline struct folio *kho_restore_folio(phys_addr_t phys) 74{ 75 return NULL; 76} 77 78static inline int kho_add_subtree(struct kho_serialization *ser, 79 const char *name, void *fdt) 80{ 81 return -EOPNOTSUPP; 82} 83 84static inline int kho_retrieve_subtree(const char *name, phys_addr_t *phys) 85{ 86 return -EOPNOTSUPP; 87} 88 89static inline int register_kho_notifier(struct notifier_block *nb) 90{ 91 return -EOPNOTSUPP; 92} 93 94static inline int unregister_kho_notifier(struct notifier_block *nb) 95{ 96 return -EOPNOTSUPP; 97} 98 99static inline void kho_memory_init(void) 100{ 101} 102 103static inline void kho_populate(phys_addr_t fdt_phys, u64 fdt_len, 104 phys_addr_t scratch_phys, u64 scratch_len) 105{ 106} 107#endif /* CONFIG_KEXEC_HANDOVER */ 108 109#endif /* LINUX_KEXEC_HANDOVER_H */