1 // SPDX-License-Identifier: GPL-2.0+
3 * Copyright 2015 - 2016 Xilinx, Inc.
5 * Michal Simek <michal.simek@xilinx.com>
16 #include <asm/arch/hardware.h>
17 #include <asm/arch/psu_init_gpl.h>
18 #include <asm/arch/sys_proto.h>
20 void board_init_f(ulong dummy)
26 static void ps_mode_reset(ulong mode)
28 writel(mode << ZYNQMP_CRL_APB_BOOT_PIN_CTRL_OUT_EN_SHIFT,
29 &crlapb_base->boot_pin_ctrl);
31 writel(mode << ZYNQMP_CRL_APB_BOOT_PIN_CTRL_OUT_VAL_SHIFT |
32 mode << ZYNQMP_CRL_APB_BOOT_PIN_CTRL_OUT_EN_SHIFT,
33 &crlapb_base->boot_pin_ctrl);
37 * Set default PS_MODE1 which is used for USB ULPI phy reset
38 * Also other resets can be connected to this certain pin
41 # define MODE_RESET PS_MODE1
44 #ifdef CONFIG_SPL_BOARD_INIT
45 void spl_board_init(void)
47 preloader_console_init();
48 ps_mode_reset(MODE_RESET);
50 psu_post_config_data();
54 void board_boot_order(u32 *spl_boot_list)
56 spl_boot_list[0] = spl_boot_device();
58 if (spl_boot_list[0] == BOOT_DEVICE_MMC1)
59 spl_boot_list[1] = BOOT_DEVICE_MMC2;
60 if (spl_boot_list[0] == BOOT_DEVICE_MMC2)
61 spl_boot_list[1] = BOOT_DEVICE_MMC1;
63 spl_boot_list[2] = BOOT_DEVICE_RAM;
66 u32 spl_boot_device(void)
71 #if defined(CONFIG_SPL_ZYNQMP_ALT_BOOTMODE_ENABLED)
72 /* Change default boot mode at run-time */
73 writel(CONFIG_SPL_ZYNQMP_ALT_BOOTMODE << BOOT_MODE_ALT_SHIFT,
74 &crlapb_base->boot_mode);
77 reg = readl(&crlapb_base->boot_mode);
78 if (reg >> BOOT_MODE_ALT_SHIFT)
79 reg >>= BOOT_MODE_ALT_SHIFT;
81 bootmode = reg & BOOT_MODES_MASK;
85 return BOOT_DEVICE_RAM;
86 #ifdef CONFIG_SPL_MMC_SUPPORT
88 case SD1_LSHFT_MODE: /* not working on silicon v1 */
89 return BOOT_DEVICE_MMC2;
92 return BOOT_DEVICE_MMC1;
96 return BOOT_DEVICE_DFU;
98 #ifdef CONFIG_SPL_SATA_SUPPORT
100 return BOOT_DEVICE_SATA;
102 #ifdef CONFIG_SPL_SPI_SUPPORT
103 case QSPI_MODE_24BIT:
104 case QSPI_MODE_32BIT:
105 return BOOT_DEVICE_SPI;
108 printf("Invalid Boot Mode:0x%x\n", bootmode);
115 #ifdef CONFIG_SPL_OS_BOOT
116 int spl_start_uboot(void)
122 #ifdef CONFIG_SPL_LOAD_FIT
123 int board_fit_config_name_match(const char *name)
125 /* Just empty function now - can't decide what to choose */
126 debug("%s: %s\n", __func__, name);