183d290c5STom Rini // SPDX-License-Identifier: GPL-2.0+
29d242745SMichal Simek /*
39d242745SMichal Simek * (C) Copyright 2013 - 2014 Xilinx, Inc
49d242745SMichal Simek *
59d242745SMichal Simek * Michal Simek <michal.simek@xilinx.com>
69d242745SMichal Simek */
79d242745SMichal Simek
89d242745SMichal Simek #include <common.h>
99d242745SMichal Simek #include <image.h>
109d242745SMichal Simek #include <spl.h>
119d242745SMichal Simek #include <asm/io.h>
129d242745SMichal Simek #include <asm/u-boot.h>
139d242745SMichal Simek
149d242745SMichal Simek bool boot_linux;
159d242745SMichal Simek
spl_boot_device(void)169d242745SMichal Simek u32 spl_boot_device(void)
179d242745SMichal Simek {
189d242745SMichal Simek return BOOT_DEVICE_NOR;
199d242745SMichal Simek }
209d242745SMichal Simek
219d242745SMichal Simek /* Board initialization after bss clearance */
spl_board_init(void)229d242745SMichal Simek void spl_board_init(void)
239d242745SMichal Simek {
249d242745SMichal Simek /* enable console uart printing */
259d242745SMichal Simek preloader_console_init();
269d242745SMichal Simek }
279d242745SMichal Simek
289d242745SMichal Simek #ifdef CONFIG_SPL_OS_BOOT
jump_to_image_linux(struct spl_image_info * spl_image)295bf5250eSVikas Manocha void __noreturn jump_to_image_linux(struct spl_image_info *spl_image)
309d242745SMichal Simek {
315bf5250eSVikas Manocha debug("Entering kernel arg pointer: 0x%p\n", spl_image->arg);
329d242745SMichal Simek typedef void (*image_entry_arg_t)(char *, ulong, ulong)
339d242745SMichal Simek __attribute__ ((noreturn));
349d242745SMichal Simek image_entry_arg_t image_entry =
35ca12e65cSSimon Glass (image_entry_arg_t)spl_image->entry_point;
369d242745SMichal Simek
375bf5250eSVikas Manocha image_entry(NULL, 0, (ulong)spl_image->arg);
389d242745SMichal Simek }
399d242745SMichal Simek #endif /* CONFIG_SPL_OS_BOOT */
409d242745SMichal Simek
spl_start_uboot(void)419d242745SMichal Simek int spl_start_uboot(void)
429d242745SMichal Simek {
439d242745SMichal Simek #ifdef CONFIG_SPL_OS_BOOT
449d242745SMichal Simek if (boot_linux)
459d242745SMichal Simek return 0;
469d242745SMichal Simek #endif
479d242745SMichal Simek
489d242745SMichal Simek return 1;
499d242745SMichal Simek }
50*4a693669SMichal Simek
do_reset(cmd_tbl_t * cmdtp,int flag,int argc,char * const argv[])51*4a693669SMichal Simek int do_reset(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
52*4a693669SMichal Simek {
53*4a693669SMichal Simek __asm__ __volatile__ ("mts rmsr, r0;" \
54*4a693669SMichal Simek "bra r0");
55*4a693669SMichal Simek
56*4a693669SMichal Simek return 0;
57*4a693669SMichal Simek }
58