1 /*
2  * Copyright 2014-2015 Freescale Semiconductor, Inc.
3  *
4  * SPDX-License-Identifier:	GPL-2.0+
5  */
6 
7 #include <common.h>
8 #include <spl.h>
9 #include <asm/io.h>
10 #include <fsl_ifc.h>
11 #include <fsl_csu.h>
12 #include <i2c.h>
13 
14 DECLARE_GLOBAL_DATA_PTR;
15 
16 u32 spl_boot_device(void)
17 {
18 #ifdef CONFIG_SPL_MMC_SUPPORT
19 	return BOOT_DEVICE_MMC1;
20 #endif
21 #ifdef CONFIG_SPL_NAND_SUPPORT
22 	return BOOT_DEVICE_NAND;
23 #endif
24 	return 0;
25 }
26 
27 u32 spl_boot_mode(void)
28 {
29 	switch (spl_boot_device()) {
30 	case BOOT_DEVICE_MMC1:
31 #ifdef CONFIG_SPL_FAT_SUPPORT
32 		return MMCSD_MODE_FS;
33 #else
34 		return MMCSD_MODE_RAW;
35 #endif
36 	case BOOT_DEVICE_NAND:
37 		return 0;
38 	default:
39 		puts("spl: error: unsupported device\n");
40 		hang();
41 	}
42 }
43 
44 #ifdef CONFIG_SPL_BUILD
45 void board_init_f(ulong dummy)
46 {
47 	/* Clear global data */
48 	memset((void *)gd, 0, sizeof(gd_t));
49 #ifdef CONFIG_LS2080A
50 	arch_cpu_init();
51 #endif
52 	board_early_init_f();
53 	timer_init();
54 #ifdef CONFIG_LS2080A
55 	env_init();
56 #endif
57 	get_clocks();
58 
59 	preloader_console_init();
60 
61 #ifdef CONFIG_SPL_I2C_SUPPORT
62 	i2c_init_all();
63 #endif
64 	dram_init();
65 
66 	/* Clear the BSS */
67 	memset(__bss_start, 0, __bss_end - __bss_start);
68 
69 #ifdef CONFIG_LAYERSCAPE_NS_ACCESS
70 	enable_layerscape_ns_access();
71 #endif
72 	board_init_r(NULL, 0);
73 }
74 #endif
75