blob: 8ce0a09ef3f425ffaf1147bab7445b3e32628c64 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Vikas Manochac6d9e9d2017-05-28 12:55:11 -07002/*
Patrice Chotard3bc599c2017-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 Manochac6d9e9d2017-05-28 12:55:11 -07005 */
6
7#include <common.h>
Simon Glass4d72caa2020-05-10 11:40:01 -06008#include <image.h>
Simon Glassf7ae49f2020-05-10 11:40:05 -06009#include <log.h>
Vikas Manochac6d9e9d2017-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{
15#ifdef CONFIG_SPL_OS_BOOT
16 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);