| /* SPDX-License-Identifier: GPL-2.0 */ |
| #ifndef __ASM_KASAN_H |
| #define __ASM_KASAN_H |
| |
| #if defined(CONFIG_KASAN) && !defined(CONFIG_CC_HAS_KASAN_MEMINTRINSIC_PREFIX) |
| #define _GLOBAL_KASAN(fn) _GLOBAL(__##fn) |
| #define _GLOBAL_TOC_KASAN(fn) _GLOBAL_TOC(__##fn) |
| #define EXPORT_SYMBOL_KASAN(fn) EXPORT_SYMBOL(__##fn) |
| #else |
| #define _GLOBAL_KASAN(fn) _GLOBAL(fn) |
| #define _GLOBAL_TOC_KASAN(fn) _GLOBAL_TOC(fn) |
| #define EXPORT_SYMBOL_KASAN(fn) |
| #endif |
| |
| #ifndef __ASSEMBLY__ |
| |
| #include <asm/page.h> |
| #include <linux/sizes.h> |
| |
| #define KASAN_SHADOW_SCALE_SHIFT 3 |
| |
| #if defined(CONFIG_MODULES) && defined(CONFIG_PPC32) |
| #define KASAN_KERN_START ALIGN_DOWN(PAGE_OFFSET - SZ_256M, SZ_256M) |
| #else |
| #define KASAN_KERN_START PAGE_OFFSET |
| #endif |
| |
| #define KASAN_SHADOW_START (KASAN_SHADOW_OFFSET + \ |
| (KASAN_KERN_START >> KASAN_SHADOW_SCALE_SHIFT)) |
| |
| #define KASAN_SHADOW_OFFSET ASM_CONST(CONFIG_KASAN_SHADOW_OFFSET) |
| |
| #ifdef CONFIG_PPC32 |
| #define KASAN_SHADOW_END (-(-KASAN_SHADOW_START >> KASAN_SHADOW_SCALE_SHIFT)) |
| #elif defined(CONFIG_PPC_BOOK3S_64) |
| /* |
| * The shadow ends before the highest accessible address |
| * because we don't need a shadow for the shadow. Instead: |
| * c00e000000000000 << 3 + a80e000000000000 = c00fc00000000000 |
| */ |
| #define KASAN_SHADOW_END 0xc00fc00000000000UL |
| |
| #else |
| |
| /* |
| * The shadow ends before the highest accessible address |
| * because we don't need a shadow for the shadow. |
| * But it doesn't hurt to have a shadow for the shadow, |
| * keep shadow end aligned eases things. |
| */ |
| #define KASAN_SHADOW_END 0xc000200000000000UL |
| |
| #endif |
| |
| #ifdef CONFIG_KASAN |
| #ifdef CONFIG_PPC_BOOK3S_64 |
| DECLARE_STATIC_KEY_FALSE(powerpc_kasan_enabled_key); |
| |
| static __always_inline bool kasan_arch_is_ready(void) |
| { |
| if (static_branch_likely(&powerpc_kasan_enabled_key)) |
| return true; |
| return false; |
| } |
| |
| #define kasan_arch_is_ready kasan_arch_is_ready |
| #endif |
| |
| void kasan_early_init(void); |
| void kasan_mmu_init(void); |
| void kasan_init(void); |
| void kasan_late_init(void); |
| #else |
| static inline void kasan_init(void) { } |
| static inline void kasan_mmu_init(void) { } |
| static inline void kasan_late_init(void) { } |
| #endif |
| |
| void kasan_update_early_region(unsigned long k_start, unsigned long k_end, pte_t pte); |
| int kasan_init_shadow_page_tables(unsigned long k_start, unsigned long k_end); |
| int kasan_init_region(void *start, size_t size); |
| |
| #endif /* __ASSEMBLY */ |
| #endif |