cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

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