blob: 361a1b34dbe2ac02a45e2ad979010bc9115a60a7 [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 Glassafa6e6c2016-09-24 18:20:03 -060017static int 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}
Simon Glassafa6e6c2016-09-24 18:20:03 -060037/* Use priorty 1 so that Ubi can override this */
38SPL_LOAD_IMAGE_METHOD(1, BOOT_DEVICE_ONENAND, spl_onenand_load_image);