arm: socfpga: Add SPL for Intel N5X device
Add SPL for N5X. Signed-off-by: Siew Chin Lim <elly.siew.chin.lim@intel.com>
This commit is contained in:
		
							parent
							
								
									59d4230429
								
							
						
					
					
						commit
						00a990e9a9
					
				|  | @ -0,0 +1,94 @@ | |||
| // SPDX-License-Identifier: GPL-2.0
 | ||||
| /*
 | ||||
|  * Copyright (C) 2020-2021 Intel Corporation <www.intel.com> | ||||
|  * | ||||
|  */ | ||||
| 
 | ||||
| #include <common.h> | ||||
| #include <asm/arch/clock_manager.h> | ||||
| #include <asm/arch/firewall.h> | ||||
| #include <asm/arch/mailbox_s10.h> | ||||
| #include <asm/arch/misc.h> | ||||
| #include <asm/arch/reset_manager.h> | ||||
| #include <asm/arch/system_manager.h> | ||||
| #include <asm/global_data.h> | ||||
| #include <asm/io.h> | ||||
| #include <asm/u-boot.h> | ||||
| #include <asm/utils.h> | ||||
| #include <dm/uclass.h> | ||||
| #include <hang.h> | ||||
| #include <image.h> | ||||
| #include <init.h> | ||||
| #include <spl.h> | ||||
| #include <watchdog.h> | ||||
| 
 | ||||
| DECLARE_GLOBAL_DATA_PTR; | ||||
| 
 | ||||
| void board_init_f(ulong dummy) | ||||
| { | ||||
| 	int ret; | ||||
| 	struct udevice *dev; | ||||
| 
 | ||||
| 	ret = spl_early_init(); | ||||
| 	if (ret) | ||||
| 		hang(); | ||||
| 
 | ||||
| 	socfpga_get_managers_addr(); | ||||
| 
 | ||||
| 	/* Ensure watchdog is paused when debugging is happening */ | ||||
| 	writel(SYSMGR_WDDBG_PAUSE_ALL_CPU, | ||||
| 	       socfpga_get_sysmgr_addr() + SYSMGR_SOC64_WDDBG); | ||||
| 
 | ||||
| #ifdef CONFIG_HW_WATCHDOG | ||||
| 	/* Enable watchdog before initializing the HW */ | ||||
| 	socfpga_per_reset(SOCFPGA_RESET(L4WD0), 1); | ||||
| 	socfpga_per_reset(SOCFPGA_RESET(L4WD0), 0); | ||||
| 	hw_watchdog_init(); | ||||
| #endif | ||||
| 
 | ||||
| 	/* ensure all processors are not released prior Linux boot */ | ||||
| 	writeq(0, CPU_RELEASE_ADDR); | ||||
| 
 | ||||
| 	timer_init(); | ||||
| 
 | ||||
| 	sysmgr_pinmux_init(); | ||||
| 
 | ||||
| 	preloader_console_init(); | ||||
| 
 | ||||
| 	ret = uclass_get_device(UCLASS_CLK, 0, &dev); | ||||
| 	if (ret) { | ||||
| 		printf("Clock init failed: %d\n", ret); | ||||
| 		hang(); | ||||
| 	} | ||||
| 
 | ||||
| 	ret = uclass_get_device(UCLASS_CLK, 1, &dev); | ||||
| 	if (ret) { | ||||
| 		printf("Memory clock init failed: %d\n", ret); | ||||
| 		hang(); | ||||
| 	} | ||||
| 
 | ||||
| 	print_reset_info(); | ||||
| 	cm_print_clock_quick_summary(); | ||||
| 
 | ||||
| 	firewall_setup(); | ||||
| 
 | ||||
| 	ret = uclass_get_device(UCLASS_CACHE, 0, &dev); | ||||
| 	if (ret) { | ||||
| 		printf("CCU init failed: %d\n", ret); | ||||
| 		hang(); | ||||
| 	} | ||||
| 
 | ||||
| #if CONFIG_IS_ENABLED(ALTERA_SDRAM) | ||||
| 	ret = uclass_get_device(UCLASS_RAM, 0, &dev); | ||||
| 	if (ret) { | ||||
| 		printf("DRAM init failed: %d\n", ret); | ||||
| 		hang(); | ||||
| 	} | ||||
| #endif | ||||
| 
 | ||||
| 	mbox_init(); | ||||
| 
 | ||||
| #ifdef CONFIG_CADENCE_QSPI | ||||
| 	mbox_qspi_open(); | ||||
| #endif | ||||
| } | ||||
		Loading…
	
		Reference in New Issue