kasan.h 1.7 KB

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