riscv: move the AX25-specific implementation of flush_dcache_all
The fence instruction is used to enforce device I/O and memory ordering constraints in RISC-V. It can not be relied on to directly affect the data cache on every CPU. Andes' AX25 does not have a coherence agent. Its fence instruction flushes the data cache and is used to keep data in the system coherent. The implementation of flush_dcache_all in lib/cache.c is therefore specific to the AX25. Move it into the AX25-specific cache.c in cpu/ax25/. This also adds a missing new line between flush_dcache_all and flush_dcache_range in lib/cache.c. Signed-off-by: Lukas Auer <lukas.auer@aisec.fraunhofer.de> Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
This commit is contained in:
parent
0c85c113c4
commit
c9056653ec
@ -6,6 +6,28 @@
|
|||||||
|
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
|
|
||||||
|
void flush_dcache_all(void)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* Andes' AX25 does not have a coherence agent. U-Boot must use data
|
||||||
|
* cache flush and invalidate functions to keep data in the system
|
||||||
|
* coherent.
|
||||||
|
* The implementation of the fence instruction in the AX25 flushes the
|
||||||
|
* data cache and is used for this purpose.
|
||||||
|
*/
|
||||||
|
asm volatile ("fence" ::: "memory");
|
||||||
|
}
|
||||||
|
|
||||||
|
void flush_dcache_range(unsigned long start, unsigned long end)
|
||||||
|
{
|
||||||
|
flush_dcache_all();
|
||||||
|
}
|
||||||
|
|
||||||
|
void invalidate_dcache_range(unsigned long start, unsigned long end)
|
||||||
|
{
|
||||||
|
flush_dcache_all();
|
||||||
|
}
|
||||||
|
|
||||||
void icache_enable(void)
|
void icache_enable(void)
|
||||||
{
|
{
|
||||||
#ifndef CONFIG_SYS_ICACHE_OFF
|
#ifndef CONFIG_SYS_ICACHE_OFF
|
||||||
|
@ -11,13 +11,12 @@ void invalidate_icache_all(void)
|
|||||||
asm volatile ("fence.i" ::: "memory");
|
asm volatile ("fence.i" ::: "memory");
|
||||||
}
|
}
|
||||||
|
|
||||||
void flush_dcache_all(void)
|
__weak void flush_dcache_all(void)
|
||||||
{
|
{
|
||||||
asm volatile ("fence" :::"memory");
|
|
||||||
}
|
}
|
||||||
void flush_dcache_range(unsigned long start, unsigned long end)
|
|
||||||
|
__weak void flush_dcache_range(unsigned long start, unsigned long end)
|
||||||
{
|
{
|
||||||
flush_dcache_all();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void invalidate_icache_range(unsigned long start, unsigned long end)
|
void invalidate_icache_range(unsigned long start, unsigned long end)
|
||||||
@ -29,9 +28,8 @@ void invalidate_icache_range(unsigned long start, unsigned long end)
|
|||||||
invalidate_icache_all();
|
invalidate_icache_all();
|
||||||
}
|
}
|
||||||
|
|
||||||
void invalidate_dcache_range(unsigned long start, unsigned long end)
|
__weak void invalidate_dcache_range(unsigned long start, unsigned long end)
|
||||||
{
|
{
|
||||||
flush_dcache_all();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void cache_flush(void)
|
void cache_flush(void)
|
||||||
|
Loading…
Reference in New Issue
Block a user