mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-26 17:48:26 +00:00 
			
		
		
		
	rk3036 only 4K size SRAM for SPL, so only support timer, uart, sdram driver in SPL stage, when finish initial sdram, back to bootrom.And in rk3036 sdmmc and debug uart use same iomux, so if you want to boot from sdmmc, you must disable debug uart. Signed-off-by: Lin Huang <hl@rock-chips.com> Acked-by: Simon Glass <sjg@chromium.org> Fixed build error for chromebook_jerry, firefly-rk3288: Signed-off-by: Simon Glass <sjg@chromium.org> Series-changes: 8 - Fix build error for chromebook_jerry, firefly-rk3288
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * (C) Copyright 2015 Rockchip Electronics Co., Ltd
 | |
|  *
 | |
|  * SPDX-License-Identifier:     GPL-2.0+
 | |
|  */
 | |
| 
 | |
| #include <common.h>
 | |
| #include <asm/io.h>
 | |
| #include <asm/arch/grf_rk3036.h>
 | |
| #include <asm/arch/hardware.h>
 | |
| #include <asm/arch/sdram_rk3036.h>
 | |
| #include <asm/arch/timer.h>
 | |
| #include <asm/arch/uart.h>
 | |
| 
 | |
| DECLARE_GLOBAL_DATA_PTR;
 | |
| 
 | |
| #define GRF_BASE	0x20008000
 | |
| static struct rk3036_grf * const grf = (void *)GRF_BASE;
 | |
| 
 | |
| #define DEBUG_UART_BASE	0x20068000
 | |
| 
 | |
| extern void back_to_bootrom(void);
 | |
| 
 | |
| void board_init_f(ulong dummy)
 | |
| {
 | |
| #ifdef EARLY_DEBUG
 | |
| 	/*
 | |
| 	 * NOTE: sd card and debug uart use same iomux in rk3036,
 | |
| 	 * so if you enable uart,
 | |
| 	 * you can not boot from sdcard
 | |
| 	 */
 | |
| 	rk_clrsetreg(&grf->gpio1c_iomux,
 | |
| 		     GPIO1C3_MASK << GPIO1C3_SHIFT |
 | |
| 		     GPIO1C2_MASK << GPIO1C2_SHIFT,
 | |
| 		     GPIO1C3_UART2_SOUT << GPIO1C3_SHIFT |
 | |
| 		     GPIO1C2_UART2_SIN << GPIO1C2_SHIFT);
 | |
| 	rk_uart_init((void *)DEBUG_UART_BASE);
 | |
| #endif
 | |
| 	rockchip_timer_init();
 | |
| 	sdram_init();
 | |
| 
 | |
| 	/* return to maskrom */
 | |
| 	back_to_bootrom();
 | |
| }
 | |
| 
 | |
| /* Place Holders */
 | |
| void board_init_r(gd_t *id, ulong dest_addr)
 | |
| {
 | |
| 	/*
 | |
| 	 * Function attribute is no-return
 | |
| 	 * This Function never executes
 | |
| 	 */
 | |
| 	while (1)
 | |
| 		;
 | |
| }
 |