|  | 
|  | 1 | +/* | 
|  | 2 | + * SPDX-FileCopyrightText: Copyright The Zephyr Project Contributors | 
|  | 3 | + * | 
|  | 4 | + * SPDX-License-Identifier: Apache-2.0 | 
|  | 5 | + */ | 
|  | 6 | + | 
|  | 7 | +#include <zephyr/kernel.h> | 
|  | 8 | +#include <zephyr/cache.h> | 
|  | 9 | + | 
|  | 10 | +#ifdef CONFIG_DCACHE | 
|  | 11 | +void arch_dcache_enable(void) | 
|  | 12 | +{ | 
|  | 13 | +	/* Nothing */ | 
|  | 14 | +} | 
|  | 15 | + | 
|  | 16 | +void arch_dcache_disable(void) | 
|  | 17 | +{ | 
|  | 18 | +	/* Nothing */ | 
|  | 19 | +} | 
|  | 20 | + | 
|  | 21 | +int arch_dcache_invd_all(void) | 
|  | 22 | +{ | 
|  | 23 | +	__asm__ volatile(".insn 0x500F\n"); | 
|  | 24 | + | 
|  | 25 | +	return 0; | 
|  | 26 | +} | 
|  | 27 | + | 
|  | 28 | +int arch_dcache_invd_range(void *addr, size_t size) | 
|  | 29 | +{ | 
|  | 30 | +	__asm__ volatile( | 
|  | 31 | +		"mv a0, %1\n" | 
|  | 32 | +		"j 2f\n" | 
|  | 33 | +		"3:\n" | 
|  | 34 | +		".insn 0x5500F\n" /* 0x500f | (a0 << 15) */ | 
|  | 35 | +		"add a0, a0, %0\n" | 
|  | 36 | +		"2:\n" | 
|  | 37 | +		"bltu a0, %2, 3b\n" | 
|  | 38 | +		: : "r"(CONFIG_DCACHE_LINE_SIZE), | 
|  | 39 | +			"r"((unsigned int)(addr) & ~((CONFIG_DCACHE_LINE_SIZE) - 1UL)), | 
|  | 40 | +			"r"((unsigned int)(addr) + (size)) | 
|  | 41 | +		: "a0"); | 
|  | 42 | + | 
|  | 43 | +	return 0; | 
|  | 44 | +} | 
|  | 45 | + | 
|  | 46 | + | 
|  | 47 | +int arch_dcache_flush_all(void) | 
|  | 48 | +{ | 
|  | 49 | +	/* VexRiscv cache is write-through */ | 
|  | 50 | +	return 0; | 
|  | 51 | +} | 
|  | 52 | + | 
|  | 53 | +int arch_dcache_flush_range(void *addr __unused, size_t size __unused) | 
|  | 54 | +{ | 
|  | 55 | +	return 0; | 
|  | 56 | +} | 
|  | 57 | + | 
|  | 58 | +int arch_dcache_flush_and_invd_all(void) | 
|  | 59 | +{ | 
|  | 60 | +	return arch_dcache_invd_all(); | 
|  | 61 | +} | 
|  | 62 | + | 
|  | 63 | +int arch_dcache_flush_and_invd_range(void *addr, size_t size) | 
|  | 64 | +{ | 
|  | 65 | +	return arch_dcache_invd_range(addr, size); | 
|  | 66 | +} | 
|  | 67 | +#endif /* CONFIG_DCACHE */ | 
|  | 68 | + | 
|  | 69 | +#ifdef CONFIG_ICACHE | 
|  | 70 | +void arch_icache_enable(void) | 
|  | 71 | +{ | 
|  | 72 | +	/* Nothing */ | 
|  | 73 | +} | 
|  | 74 | + | 
|  | 75 | +void arch_icache_disable(void) | 
|  | 76 | +{ | 
|  | 77 | +	/* Nothing */ | 
|  | 78 | +} | 
|  | 79 | + | 
|  | 80 | +int arch_icache_flush_all(void) | 
|  | 81 | +{ | 
|  | 82 | +	__asm__ volatile("fence.i\n"); | 
|  | 83 | + | 
|  | 84 | +	return 0; | 
|  | 85 | +} | 
|  | 86 | + | 
|  | 87 | +int arch_icache_invd_all(void) | 
|  | 88 | +{ | 
|  | 89 | +	return arch_icache_flush_all(); | 
|  | 90 | +} | 
|  | 91 | + | 
|  | 92 | +int arch_icache_invd_range(void *addr_in __unused, size_t size __unused) | 
|  | 93 | +{ | 
|  | 94 | +	return arch_icache_flush_all(); | 
|  | 95 | +} | 
|  | 96 | + | 
|  | 97 | +int arch_icache_flush_and_invd_all(void) | 
|  | 98 | +{ | 
|  | 99 | +	return arch_icache_flush_all(); | 
|  | 100 | +} | 
|  | 101 | + | 
|  | 102 | +int arch_icache_flush_range(void *addr __unused, size_t size __unused) | 
|  | 103 | +{ | 
|  | 104 | +	return arch_icache_flush_all(); | 
|  | 105 | +} | 
|  | 106 | + | 
|  | 107 | +int arch_icache_flush_and_invd_range(void *addr __unused, size_t size __unused) | 
|  | 108 | +{ | 
|  | 109 | +	return arch_icache_flush_all(); | 
|  | 110 | +} | 
|  | 111 | +#endif /* CONFIG_ICACHE */ | 
|  | 112 | + | 
|  | 113 | +void arch_cache_init(void) | 
|  | 114 | +{ | 
|  | 115 | +	/* Nothing */ | 
|  | 116 | +} | 
0 commit comments