mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-31 03:58:17 +00:00 
			
		
		
		
	Due to the removal of weak functions in 7d6cee2cd0 ("cmd: cache: Remove
weak function"), U-Boot fails to compile after updating to v2024.10 for
mediatek target in OpenWrt with GCC-14 with error:
cmd/cache.c: In function 'do_dcache':
cmd/cache.c:57:25: error: implicit declaration of function
	'noncached_set_region' [-Wimplicit-function-declaration]
Thus, provide a prototype in include/cpu_func.h to fix a build
error in cmd/cache.c, since related prototypes are also located there.
The issue occurred after the update of uboot-mediatek in OpenWrt to
v2024.10, in combination with GCC-14 toolchain. It was reported and
discussed in https://github.com/openwrt/openwrt/issues/16697, and
temporarily fixed with
92ca322dd1.
Signed-off-by: Jonas Jelonek <jelonek.jonas@gmail.com>
Link: https://github.com/openwrt/openwrt/issues/16697
Link: 92ca322dd1
Fixes: 7d6cee2cd0 ("cmd: cache: Remove weak function")
Signed-off-by: Tom Rini <trini@konsulko.com>
		
	
			
		
			
				
	
	
		
			105 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			105 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0+ */
 | |
| /*
 | |
|  * (C) Copyright 2000-2009
 | |
|  * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
 | |
|  * Copyright 2019 Google LLC
 | |
|  */
 | |
| 
 | |
| #ifndef __CPU_LEGACY_H
 | |
| #define __CPU_LEGACY_H
 | |
| 
 | |
| #include <linux/types.h>
 | |
| 
 | |
| /*
 | |
|  * Multicore arch functions
 | |
|  *
 | |
|  * These should be moved to use the CPU uclass.
 | |
|  */
 | |
| int cpu_status(u32 nr);
 | |
| int cpu_reset(u32 nr);
 | |
| int cpu_disable(u32 nr);
 | |
| int cpu_release(u32 nr, int argc, char *const argv[]);
 | |
| 
 | |
| static inline int cpumask_next(int cpu, unsigned int mask)
 | |
| {
 | |
| 	for (cpu++; !((1 << cpu) & mask); cpu++)
 | |
| 		;
 | |
| 
 | |
| 	return cpu;
 | |
| }
 | |
| 
 | |
| #define for_each_cpu(iter, cpu, num_cpus, mask) \
 | |
| 	for (iter = 0, cpu = cpumask_next(-1, mask); \
 | |
| 	     iter < num_cpus; \
 | |
| 	     iter++, cpu = cpumask_next(cpu, mask)) \
 | |
| 
 | |
| int cpu_numcores(void);
 | |
| int cpu_num_dspcores(void);
 | |
| u32 cpu_mask(void);
 | |
| u32 cpu_dsp_mask(void);
 | |
| int is_core_valid(unsigned int core);
 | |
| 
 | |
| /**
 | |
|  * checkcpu() - perform an early check of the CPU
 | |
|  *
 | |
|  * This is used on PowerPC, SH and X86 machines as a CPU init mechanism. It is
 | |
|  * called during the pre-relocation init sequence in board_init_f().
 | |
|  *
 | |
|  * Return: 0 if oK, -ve on error
 | |
|  */
 | |
| int checkcpu(void);
 | |
| 
 | |
| void smp_set_core_boot_addr(unsigned long addr, int corenr);
 | |
| void smp_kick_all_cpus(void);
 | |
| 
 | |
| int icache_status(void);
 | |
| void icache_enable(void);
 | |
| void icache_disable(void);
 | |
| int dcache_status(void);
 | |
| void dcache_enable(void);
 | |
| void dcache_disable(void);
 | |
| void mmu_disable(void);
 | |
| int mmu_status(void);
 | |
| 
 | |
| /* arch/$(ARCH)/lib/cache.c */
 | |
| void enable_caches(void);
 | |
| void flush_cache(unsigned long addr, unsigned long size);
 | |
| void flush_dcache_all(void);
 | |
| void flush_dcache_range(unsigned long start, unsigned long stop);
 | |
| void invalidate_dcache_range(unsigned long start, unsigned long stop);
 | |
| void invalidate_dcache_all(void);
 | |
| void invalidate_icache_all(void);
 | |
| /**
 | |
|  * noncached_init() - Initialize non-cached memory region
 | |
|  *
 | |
|  * Initialize non-cached memory area. This memory region will be typically
 | |
|  * located right below the malloc() area and mapped uncached in the MMU.
 | |
|  *
 | |
|  * It is called during the generic post-relocation init sequence.
 | |
|  *
 | |
|  * Return: 0 if OK
 | |
|  */
 | |
| int noncached_init(void);
 | |
| void noncached_set_region(void);
 | |
| 
 | |
| phys_addr_t noncached_alloc(size_t size, size_t align);
 | |
| 
 | |
| enum {
 | |
| 	/* Disable caches (else flush caches but leave them active) */
 | |
| 	CBL_DISABLE_CACHES		= 1 << 0,
 | |
| 	CBL_SHOW_BOOTSTAGE_REPORT	= 1 << 1,
 | |
| 
 | |
| 	CBL_ALL				= 3,
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Clean up ready for linux
 | |
|  *
 | |
|  * @param flags		Flags to control what is done
 | |
|  */
 | |
| int cleanup_before_linux_select(int flags);
 | |
| 
 | |
| void reset_cpu(void);
 | |
| 
 | |
| #endif
 |