blob: ba4af38a3eca057256292c249059013a60231f10 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Vikas Manocha9e582652017-05-28 12:55:11 -07002/*
Patrice Chotard789ee0e2017-10-23 09:53:58 +02003 * Copyright (C) 2017, STMicroelectronics - All Rights Reserved
4 * Author(s): Vikas Manocha, <vikas.manocha@st.com> for STMicroelectronics.
Vikas Manocha9e582652017-05-28 12:55:11 -07005 */
6
7#include <common.h>
Simon Glass2dc9c342020-05-10 11:40:01 -06008#include <image.h>
Simon Glass0f2af882020-05-10 11:40:05 -06009#include <log.h>
Vikas Manocha9e582652017-05-28 12:55:11 -070010#include <spl.h>
11
12static int spl_xip(struct spl_image_info *spl_image,
13 struct spl_boot_device *bootdev)
14{
Tom Rinic2e78882021-10-30 23:03:48 -040015#if CONFIG_IS_ENABLED(OS_BOOT)
Vikas Manocha9e582652017-05-28 12:55:11 -070016 if (!spl_start_uboot()) {
17 spl_image->arg = (void *)CONFIG_SYS_FDT_BASE;
18 spl_image->name = "Linux";
19 spl_image->os = IH_OS_LINUX;
20 spl_image->load_addr = CONFIG_SYS_LOAD_ADDR;
21 spl_image->entry_point = CONFIG_SYS_LOAD_ADDR;
22 debug("spl: payload xipImage, load addr: 0x%lx\n",
23 spl_image->load_addr);
24 return 0;
25 }
26#endif
27 return(spl_parse_image_header(spl_image, (const struct image_header *)
28 CONFIG_SYS_UBOOT_BASE));
29}
30SPL_LOAD_IMAGE_METHOD("XIP", 0, BOOT_DEVICE_XIP, spl_xip);