.. | .. |
---|
6 | 6 | |
---|
7 | 7 | #include <linux/linkage.h> |
---|
8 | 8 | #include <asm/memory.h> |
---|
| 9 | +#include <asm/mte-kasan.h> |
---|
9 | 10 | #include <asm/pgtable-types.h> |
---|
10 | 11 | |
---|
11 | 12 | #define arch_kasan_set_tag(addr, tag) __tag_set(addr, tag) |
---|
12 | 13 | #define arch_kasan_reset_tag(addr) __tag_reset(addr) |
---|
13 | 14 | #define arch_kasan_get_tag(addr) __tag_get(addr) |
---|
14 | 15 | |
---|
15 | | -#ifdef CONFIG_KASAN |
---|
| 16 | +#if defined(CONFIG_KASAN_GENERIC) || defined(CONFIG_KASAN_SW_TAGS) |
---|
| 17 | + |
---|
| 18 | +void kasan_init(void); |
---|
16 | 19 | |
---|
17 | 20 | /* |
---|
18 | 21 | * KASAN_SHADOW_START: beginning of the kernel virtual addresses. |
---|
19 | 22 | * KASAN_SHADOW_END: KASAN_SHADOW_START + 1/N of kernel virtual addresses, |
---|
20 | 23 | * where N = (1 << KASAN_SHADOW_SCALE_SHIFT). |
---|
21 | | - */ |
---|
22 | | -#define KASAN_SHADOW_START (VA_START) |
---|
23 | | -#define KASAN_SHADOW_END (KASAN_SHADOW_START + KASAN_SHADOW_SIZE) |
---|
24 | | - |
---|
25 | | -/* |
---|
| 24 | + * |
---|
| 25 | + * KASAN_SHADOW_OFFSET: |
---|
26 | 26 | * This value is used to map an address to the corresponding shadow |
---|
27 | 27 | * address by the following formula: |
---|
28 | 28 | * shadow_addr = (address >> KASAN_SHADOW_SCALE_SHIFT) + KASAN_SHADOW_OFFSET |
---|
.. | .. |
---|
33 | 33 | * KASAN_SHADOW_OFFSET = KASAN_SHADOW_END - |
---|
34 | 34 | * (1ULL << (64 - KASAN_SHADOW_SCALE_SHIFT)) |
---|
35 | 35 | */ |
---|
36 | | -#define KASAN_SHADOW_OFFSET (KASAN_SHADOW_END - (1ULL << \ |
---|
37 | | - (64 - KASAN_SHADOW_SCALE_SHIFT))) |
---|
| 36 | +#define _KASAN_SHADOW_START(va) (KASAN_SHADOW_END - (1UL << ((va) - KASAN_SHADOW_SCALE_SHIFT))) |
---|
| 37 | +#define KASAN_SHADOW_START _KASAN_SHADOW_START(vabits_actual) |
---|
38 | 38 | |
---|
39 | | -void kasan_init(void); |
---|
40 | 39 | void kasan_copy_shadow(pgd_t *pgdir); |
---|
41 | 40 | asmlinkage void kasan_early_init(void); |
---|
42 | 41 | |
---|