kasan.h (1772B)
1/* SPDX-License-Identifier: GPL-2.0 */ 2#ifndef __ASM_KASAN_H 3#define __ASM_KASAN_H 4 5#include <asm/pgtable.h> 6 7#ifdef CONFIG_KASAN 8 9#define KASAN_SHADOW_SCALE_SHIFT 3 10#define KASAN_SHADOW_SIZE \ 11 (_AC(1, UL) << (_REGION1_SHIFT - KASAN_SHADOW_SCALE_SHIFT)) 12#define KASAN_SHADOW_OFFSET _AC(CONFIG_KASAN_SHADOW_OFFSET, UL) 13#define KASAN_SHADOW_START KASAN_SHADOW_OFFSET 14#define KASAN_SHADOW_END (KASAN_SHADOW_START + KASAN_SHADOW_SIZE) 15 16extern void kasan_early_init(void); 17extern void kasan_copy_shadow_mapping(void); 18extern void kasan_free_early_identity(void); 19 20/* 21 * Estimate kasan memory requirements, which it will reserve 22 * at the very end of available physical memory. To estimate 23 * that, we take into account that kasan would require 24 * 1/8 of available physical memory (for shadow memory) + 25 * creating page tables for the whole memory + shadow memory 26 * region (1 + 1/8). To keep page tables estimates simple take 27 * the double of combined ptes size. 28 * 29 * physmem parameter has to be already adjusted if not entire physical memory 30 * would be used (e.g. due to effect of "mem=" option). 31 */ 32static inline unsigned long kasan_estimate_memory_needs(unsigned long physmem) 33{ 34 unsigned long kasan_needs; 35 unsigned long pages; 36 /* for shadow memory */ 37 kasan_needs = round_up(physmem / 8, PAGE_SIZE); 38 /* for paging structures */ 39 pages = DIV_ROUND_UP(physmem + kasan_needs, PAGE_SIZE); 40 kasan_needs += DIV_ROUND_UP(pages, _PAGE_ENTRIES) * _PAGE_TABLE_SIZE * 2; 41 42 return kasan_needs; 43} 44#else 45static inline void kasan_early_init(void) { } 46static inline void kasan_copy_shadow_mapping(void) { } 47static inline void kasan_free_early_identity(void) { } 48static inline unsigned long kasan_estimate_memory_needs(unsigned long physmem) { return 0; } 49#endif 50 51#endif