Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux
1
fork

Configure Feed

Select the types of activity you want to include in your feed.

at v6.11 57 lines 1.1 kB view raw
1/* SPDX-License-Identifier: GPL-2.0 */ 2/* 3 * powerpc KFENCE support. 4 * 5 * Copyright (C) 2020 CS GROUP France 6 */ 7 8#ifndef __ASM_POWERPC_KFENCE_H 9#define __ASM_POWERPC_KFENCE_H 10 11#include <linux/mm.h> 12#include <asm/pgtable.h> 13 14#ifdef CONFIG_PPC64_ELF_ABI_V1 15#define ARCH_FUNC_PREFIX "." 16#endif 17 18#ifdef CONFIG_KFENCE 19extern bool kfence_disabled; 20 21static inline void disable_kfence(void) 22{ 23 kfence_disabled = true; 24} 25 26static inline bool arch_kfence_init_pool(void) 27{ 28 return !kfence_disabled; 29} 30#endif 31 32#ifdef CONFIG_PPC64 33static inline bool kfence_protect_page(unsigned long addr, bool protect) 34{ 35 struct page *page = virt_to_page((void *)addr); 36 37 __kernel_map_pages(page, 1, !protect); 38 39 return true; 40} 41#else 42static inline bool kfence_protect_page(unsigned long addr, bool protect) 43{ 44 pte_t *kpte = virt_to_kpte(addr); 45 46 if (protect) { 47 pte_update(&init_mm, addr, kpte, _PAGE_PRESENT, 0, 0); 48 flush_tlb_kernel_range(addr, addr + PAGE_SIZE); 49 } else { 50 pte_update(&init_mm, addr, kpte, 0, _PAGE_PRESENT, 0); 51 } 52 53 return true; 54} 55#endif 56 57#endif /* __ASM_POWERPC_KFENCE_H */