blob: f5e2f95b13ea5090f0602884c9237648ec05e53e [file] [log] [blame]
Enric Balletbo i Serra60009922013-02-07 23:14:48 +00001/*
2 * Copyright (C) 2013
3 * ISEE 2007 SL - Enric Balletbo i Serra <eballetbo@iseebcn.com>
4 *
5 * Based on common/spl/spl_nand.c
6 * Copyright (C) 2011
7 * Corscience GmbH & Co. KG - Simon Schwarz <schwarz@corscience.de>
8 *
Wolfgang Denk1a459662013-07-08 09:37:19 +02009 * SPDX-License-Identifier: GPL-2.0+
Enric Balletbo i Serra60009922013-02-07 23:14:48 +000010 */
11#include <common.h>
12#include <config.h>
13#include <spl.h>
14#include <asm/io.h>
15#include <onenand_uboot.h>
16
Simon Glassecdfd692016-09-24 18:19:57 -060017int spl_onenand_load_image(struct spl_boot_device *bootdev)
Enric Balletbo i Serra60009922013-02-07 23:14:48 +000018{
19 struct image_header *header;
Marek Vasut7e0f2262016-04-29 00:44:54 +020020 int ret;
Enric Balletbo i Serra60009922013-02-07 23:14:48 +000021
22 debug("spl: onenand\n");
23
24 /*use CONFIG_SYS_TEXT_BASE as temporary storage area */
25 header = (struct image_header *)(CONFIG_SYS_TEXT_BASE);
26 /* Load u-boot */
27 onenand_spl_load_image(CONFIG_SYS_ONENAND_U_BOOT_OFFS,
28 CONFIG_SYS_ONENAND_PAGE_SIZE, (void *)header);
Simon Glass71316c12016-09-24 18:19:53 -060029 ret = spl_parse_image_header(&spl_image, header);
Marek Vasut7e0f2262016-04-29 00:44:54 +020030 if (ret)
31 return ret;
Enric Balletbo i Serra60009922013-02-07 23:14:48 +000032 onenand_spl_load_image(CONFIG_SYS_ONENAND_U_BOOT_OFFS,
33 spl_image.size, (void *)spl_image.load_addr);
Nikita Kiryanov36afd452015-11-08 17:11:49 +020034
35 return 0;
Enric Balletbo i Serra60009922013-02-07 23:14:48 +000036}