mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-11-04 10:21:25 +01:00 
			
		
		
		
	The enable_caches is a generic hook for architecture-implemented, we leverage this function to enable caches for RISC-V Signed-off-by: Zong Li <zong.li@sifive.com> Reviewed-by: Rick Chen <rick@andestech.com>
		
			
				
	
	
		
			77 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
// SPDX-License-Identifier: GPL-2.0+
 | 
						|
/*
 | 
						|
 * Copyright (C) 2017 Andes Technology Corporation
 | 
						|
 * Rick Chen, Andes Technology Corporation <rick@andestech.com>
 | 
						|
 */
 | 
						|
 | 
						|
#include <common.h>
 | 
						|
#include <cpu_func.h>
 | 
						|
 | 
						|
void invalidate_icache_all(void)
 | 
						|
{
 | 
						|
	asm volatile ("fence.i" ::: "memory");
 | 
						|
}
 | 
						|
 | 
						|
__weak void flush_dcache_all(void)
 | 
						|
{
 | 
						|
}
 | 
						|
 | 
						|
__weak void flush_dcache_range(unsigned long start, unsigned long end)
 | 
						|
{
 | 
						|
}
 | 
						|
 | 
						|
void invalidate_icache_range(unsigned long start, unsigned long end)
 | 
						|
{
 | 
						|
	/*
 | 
						|
	 * RISC-V does not have an instruction for invalidating parts of the
 | 
						|
	 * instruction cache. Invalidate all of it instead.
 | 
						|
	 */
 | 
						|
	invalidate_icache_all();
 | 
						|
}
 | 
						|
 | 
						|
__weak void invalidate_dcache_range(unsigned long start, unsigned long end)
 | 
						|
{
 | 
						|
}
 | 
						|
 | 
						|
void cache_flush(void)
 | 
						|
{
 | 
						|
	invalidate_icache_all();
 | 
						|
	flush_dcache_all();
 | 
						|
}
 | 
						|
 | 
						|
void flush_cache(unsigned long addr, unsigned long size)
 | 
						|
{
 | 
						|
	invalidate_icache_range(addr, addr + size);
 | 
						|
	flush_dcache_range(addr, addr + size);
 | 
						|
}
 | 
						|
 | 
						|
__weak void icache_enable(void)
 | 
						|
{
 | 
						|
}
 | 
						|
 | 
						|
__weak void icache_disable(void)
 | 
						|
{
 | 
						|
}
 | 
						|
 | 
						|
__weak int icache_status(void)
 | 
						|
{
 | 
						|
	return 0;
 | 
						|
}
 | 
						|
 | 
						|
__weak void dcache_enable(void)
 | 
						|
{
 | 
						|
}
 | 
						|
 | 
						|
__weak void dcache_disable(void)
 | 
						|
{
 | 
						|
}
 | 
						|
 | 
						|
__weak int dcache_status(void)
 | 
						|
{
 | 
						|
	return 0;
 | 
						|
}
 | 
						|
 | 
						|
__weak void enable_caches(void)
 | 
						|
{
 | 
						|
}
 |