mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-26 05:51:29 +01:00 
			
		
		
		
	Commits b61e90e6fd83 ("sh: Drop the arch-specific board init") and
f41e6088eb1a ("sh: Fix build errors for generic board") left code and
data relocation done in start.S, however further actual U-boot
configuration is not started anymore. Practically SH boards with the
code relocated into the expected position by start.S still can be
booted, so the change adds this option and provides an option how to
relocate code for board_init_r() execution.
Signed-off-by: Vladimir Zapolskiy <vz@mleia.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
		
	
			
		
			
				
	
	
		
			86 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2007,2008 Nobuhiro Iwamatsu <iwamatsu@nigauri.org>
 | |
|  * Copyright (C) 2008 Renesas Solutions Corp.
 | |
|  *
 | |
|  * SPDX-License-Identifier:	GPL-2.0+
 | |
|  */
 | |
| 
 | |
| #include <common.h>
 | |
| #include <command.h>
 | |
| #include <asm/processor.h>
 | |
| #include <asm/io.h>
 | |
| 
 | |
| #define STBCR4      0xFFFE040C
 | |
| #define cmt_clock_enable() do {\
 | |
| 		writeb(readb(STBCR4) & ~0x04, STBCR4);\
 | |
| 	} while (0)
 | |
| #define scif0_enable() do {\
 | |
| 		writeb(readb(STBCR4) & ~0x80, STBCR4);\
 | |
| 	} while (0)
 | |
| #define scif3_enable() do {\
 | |
| 		writeb(readb(STBCR4) & ~0x10, STBCR4);\
 | |
| 	} while (0)
 | |
| 
 | |
| int checkcpu(void)
 | |
| {
 | |
| 	puts("CPU: SH2\n");
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| int cpu_init(void)
 | |
| {
 | |
| 	/* SCIF enable */
 | |
| #if defined(CONFIG_CONS_SCIF3)
 | |
| 	scif3_enable();
 | |
| #else
 | |
| 	scif0_enable();
 | |
| #endif
 | |
| 	/* CMT clock enable */
 | |
| 	cmt_clock_enable() ;
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| int cleanup_before_linux(void)
 | |
| {
 | |
| 	disable_interrupts();
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| int do_reset(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
 | |
| {
 | |
| 	disable_interrupts();
 | |
| 	reset_cpu(0);
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| void flush_cache(unsigned long addr, unsigned long size)
 | |
| {
 | |
| 
 | |
| }
 | |
| 
 | |
| void icache_enable(void)
 | |
| {
 | |
| }
 | |
| 
 | |
| void icache_disable(void)
 | |
| {
 | |
| }
 | |
| 
 | |
| int icache_status(void)
 | |
| {
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| void dcache_enable(void)
 | |
| {
 | |
| }
 | |
| 
 | |
| void dcache_disable(void)
 | |
| {
 | |
| }
 | |
| 
 | |
| int dcache_status(void)
 | |
| {
 | |
| 	return 0;
 | |
| }
 |