mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-11-03 21:48:15 +00:00 
			
		
		
		
	Some RISC-V CPUs, such as the T-HEAD XuanTie series, have a vendor-specific way to invalidate a portion of the instruction cache. Allow them to override invalidate_icache_range(). Signed-off-by: Samuel Holland <samuel@sholland.org> Reviewed-by: Leo Yu-Chi Liang <ycliang@andestech.com>
		
			
				
	
	
		
			76 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			76 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 <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)
 | 
						|
{
 | 
						|
}
 | 
						|
 | 
						|
__weak 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)
 | 
						|
{
 | 
						|
}
 |