blob: 1a28a84e4407a252706a2a3eb4870dd72b39503f [file] [log] [blame]
Enric Balletbo i Serrad6b5eed2013-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 Denkd79de1d2013-07-08 09:37:19 +02009 * SPDX-License-Identifier: GPL-2.0+
Enric Balletbo i Serrad6b5eed2013-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
Nikita Kiryanov33eefe42015-11-08 17:11:49 +020017int spl_onenand_load_image(void)
Enric Balletbo i Serrad6b5eed2013-02-07 23:14:48 +000018{
19 struct image_header *header;
Marek Vasut02266e22016-04-29 00:44:54 +020020 int ret;
Enric Balletbo i Serrad6b5eed2013-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);
Marek Vasut02266e22016-04-29 00:44:54 +020029 ret = spl_parse_image_header(header);
30 if (ret)
31 return ret;
Enric Balletbo i Serrad6b5eed2013-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 Kiryanov33eefe42015-11-08 17:11:49 +020034
35 return 0;
Enric Balletbo i Serrad6b5eed2013-02-07 23:14:48 +000036}