1 /* SPDX-License-Identifier: GPL-2.0 */
3 * powerpc KFENCE support.
5 * Copyright (C) 2020 CS GROUP France
8 #ifndef __ASM_POWERPC_KFENCE_H
9 #define __ASM_POWERPC_KFENCE_H
12 #include <asm/pgtable.h>
14 #ifdef CONFIG_PPC64_ELF_ABI_V1
15 #define ARCH_FUNC_PREFIX "."
18 extern bool kfence_early_init;
19 extern bool kfence_disabled;
21 static inline void disable_kfence(void)
23 kfence_disabled = true;
26 static inline bool arch_kfence_init_pool(void)
28 return !kfence_disabled;
31 static inline bool kfence_early_init_enabled(void)
33 return IS_ENABLED(CONFIG_KFENCE) && kfence_early_init;
37 static inline bool kfence_protect_page(unsigned long addr, bool protect)
39 struct page *page = virt_to_page((void *)addr);
41 __kernel_map_pages(page, 1, !protect);
46 static inline bool kfence_protect_page(unsigned long addr, bool protect)
48 pte_t *kpte = virt_to_kpte(addr);
51 pte_update(&init_mm, addr, kpte, _PAGE_PRESENT, 0, 0);
52 flush_tlb_kernel_range(addr, addr + PAGE_SIZE);
54 pte_update(&init_mm, addr, kpte, 0, _PAGE_PRESENT, 0);
61 #endif /* __ASM_POWERPC_KFENCE_H */