blob: 19e34fade28f15eef3c6cba81a4e1b52a0e530dc [file] [log] [blame]
Mingkai Hu0e58b512015-10-26 19:47:50 +08001/*
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
14DECLARE_GLOBAL_DATA_PTR;
15
16u32 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
Marek Vasut64d64bb2016-05-14 23:42:07 +020027u32 spl_boot_mode(const u32 boot_device)
Mingkai Hu0e58b512015-10-26 19:47:50 +080028{
29 switch (spl_boot_device()) {
30 case BOOT_DEVICE_MMC1:
31#ifdef CONFIG_SPL_FAT_SUPPORT
Qianyu Gongb141ef72016-04-27 09:45:23 +080032 return MMCSD_MODE_FS;
Mingkai Hu0e58b512015-10-26 19:47:50 +080033#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
45void board_init_f(ulong dummy)
46{
Mingkai Hu0e58b512015-10-26 19:47:50 +080047 /* Clear global data */
48 memset((void *)gd, 0, sizeof(gd_t));
York Suncbe8e1c2016-04-04 11:41:26 -070049#ifdef CONFIG_LS2080A
Mingkai Hu0e58b512015-10-26 19:47:50 +080050 arch_cpu_init();
51#endif
Mingkai Hu0e58b512015-10-26 19:47:50 +080052 board_early_init_f();
53 timer_init();
York Suncbe8e1c2016-04-04 11:41:26 -070054#ifdef CONFIG_LS2080A
Mingkai Hu0e58b512015-10-26 19:47:50 +080055 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
Gong Qianyu8168a0f2015-10-26 19:47:53 +080069#ifdef CONFIG_LAYERSCAPE_NS_ACCESS
70 enable_layerscape_ns_access();
71#endif
Mingkai Hu0e58b512015-10-26 19:47:50 +080072 board_init_r(NULL, 0);
73}
74#endif