xref: /openbmc/u-boot/arch/riscv/lib/cache.c (revision 04b24965)
1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * Copyright (C) 2017 Andes Technology Corporation
4  * Rick Chen, Andes Technology Corporation <rick@andestech.com>
5  */
6 
7 #include <common.h>
8 
9 void invalidate_icache_all(void)
10 {
11 	asm volatile ("fence.i" ::: "memory");
12 }
13 
14 __weak void flush_dcache_all(void)
15 {
16 }
17 
18 __weak void flush_dcache_range(unsigned long start, unsigned long end)
19 {
20 }
21 
22 void invalidate_icache_range(unsigned long start, unsigned long end)
23 {
24 	/*
25 	 * RISC-V does not have an instruction for invalidating parts of the
26 	 * instruction cache. Invalidate all of it instead.
27 	 */
28 	invalidate_icache_all();
29 }
30 
31 __weak void invalidate_dcache_range(unsigned long start, unsigned long end)
32 {
33 }
34 
35 void cache_flush(void)
36 {
37 	invalidate_icache_all();
38 	flush_dcache_all();
39 }
40 
41 void flush_cache(unsigned long addr, unsigned long size)
42 {
43 	invalidate_icache_range(addr, addr + size);
44 	flush_dcache_range(addr, addr + size);
45 }
46 
47 __weak void icache_enable(void)
48 {
49 }
50 
51 __weak void icache_disable(void)
52 {
53 }
54 
55 __weak int icache_status(void)
56 {
57 	return 0;
58 }
59 
60 __weak void dcache_enable(void)
61 {
62 }
63 
64 __weak void dcache_disable(void)
65 {
66 }
67 
68 __weak int dcache_status(void)
69 {
70 	return 0;
71 }
72