blob: 13025f034bf43df13f48af98624c7364b3e983f0 [file] [log] [blame]
Michal Simeke60148d2014-01-14 14:21:52 +01001/*
2 * (C) Copyright 2014 Xilinx, Inc. Michal Simek
3 *
4 * SPDX-License-Identifier: GPL-2.0+
5 */
6#include <common.h>
7#include <spl.h>
8
9#include <asm/io.h>
10#include <asm/arch/hardware.h>
Michal Simek162c6372014-08-11 14:03:15 +020011#include <asm/spl.h>
Michal Simeke60148d2014-01-14 14:21:52 +010012#include <asm/arch/sys_proto.h>
13
14DECLARE_GLOBAL_DATA_PTR;
15
16void board_init_f(ulong dummy)
17{
18 ps7_init();
19
20 /* Clear the BSS. */
21 memset(__bss_start, 0, __bss_end - __bss_start);
22
Michal Simeke60148d2014-01-14 14:21:52 +010023 preloader_console_init();
24 arch_cpu_init();
25 board_init_r(NULL, 0);
26}
27
Michal Simeka831f1f2014-04-25 12:15:40 +020028#ifdef CONFIG_SPL_BOARD_INIT
29void spl_board_init(void)
30{
31 board_init();
32}
33#endif
34
Michal Simeke60148d2014-01-14 14:21:52 +010035u32 spl_boot_device(void)
36{
37 u32 mode;
38
39 switch ((zynq_slcr_get_boot_mode()) & ZYNQ_BM_MASK) {
40#ifdef CONFIG_SPL_SPI_SUPPORT
41 case ZYNQ_BM_QSPI:
42 puts("qspi boot\n");
43 mode = BOOT_DEVICE_SPI;
44 break;
45#endif
Michal Simek25830022015-01-13 16:04:10 +010046 case ZYNQ_BM_NAND:
47 mode = BOOT_DEVICE_NAND;
48 break;
49 case ZYNQ_BM_NOR:
50 mode = BOOT_DEVICE_NOR;
51 break;
Michal Simeke60148d2014-01-14 14:21:52 +010052#ifdef CONFIG_SPL_MMC_SUPPORT
53 case ZYNQ_BM_SD:
54 puts("mmc boot\n");
55 mode = BOOT_DEVICE_MMC1;
56 break;
57#endif
Michal Simek25830022015-01-13 16:04:10 +010058 case ZYNQ_BM_JTAG:
59 mode = BOOT_DEVICE_RAM;
60 break;
Michal Simeke60148d2014-01-14 14:21:52 +010061 default:
62 puts("Unsupported boot mode selected\n");
63 hang();
64 }
65
66 return mode;
67}
68
69#ifdef CONFIG_SPL_MMC_SUPPORT
70u32 spl_boot_mode(void)
71{
Guillaume GARDET602a16c2014-10-15 17:53:11 +020072 return MMCSD_MODE_FS;
Michal Simeke60148d2014-01-14 14:21:52 +010073}
74#endif
75
76#ifdef CONFIG_SPL_OS_BOOT
77int spl_start_uboot(void)
78{
79 /* boot linux */
80 return 0;
81}
82#endif
Masahiro Yamadac2d10792014-05-12 12:18:30 +090083
84__weak void ps7_init(void)
85{
86 /*
87 * This function is overridden by the one in
Masahiro Yamadaeab653252015-04-14 16:50:50 +090088 * board/xilinx/zynq/ps7_init_gpl.c, if it exists.
Masahiro Yamadac2d10792014-05-12 12:18:30 +090089 */
90}