blob: b638ea7be6117f8c7800dc19dccdb747824da6cb [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Stefan Roeseec90d342012-08-23 08:34:21 +02002/*
3 * Copyright 2012 Stefan Roese <sr@denx.de>
Stefan Roeseec90d342012-08-23 08:34:21 +02004 */
Tom Riniabb9a042024-05-18 20:20:43 -06005#include <common.h>
Stefan Roeseec90d342012-08-23 08:34:21 +02006#include <config.h>
Simon Glass0f2af882020-05-10 11:40:05 -06007#include <log.h>
Stefan Roeseec90d342012-08-23 08:34:21 +02008#include <spl.h>
9#include <image.h>
10#include <linux/compiler.h>
11
Stefan Roeseec90d342012-08-23 08:34:21 +020012/*
13 * This function jumps to an image with argument. Normally an FDT or ATAGS
14 * image.
Stefan Roeseec90d342012-08-23 08:34:21 +020015 */
16#ifdef CONFIG_SPL_OS_BOOT
Vikas Manocha62b021c2017-04-07 15:38:13 -070017void __noreturn jump_to_image_linux(struct spl_image_info *spl_image)
Stefan Roeseec90d342012-08-23 08:34:21 +020018{
Vikas Manocha62b021c2017-04-07 15:38:13 -070019 debug("Entering kernel arg pointer: 0x%p\n", spl_image->arg);
Stefan Roeseec90d342012-08-23 08:34:21 +020020 typedef void (*image_entry_arg_t)(void *, ulong r4, ulong r5, ulong r6,
21 ulong r7, ulong r8, ulong r9)
22 __attribute__ ((noreturn));
23 image_entry_arg_t image_entry =
Simon Glassb805c352016-09-24 18:19:54 -060024 (image_entry_arg_t)spl_image->entry_point;
Stefan Roeseec90d342012-08-23 08:34:21 +020025
Tom Rini6a5dccc2022-11-16 13:10:41 -050026 image_entry(spl_image->arg, 0, 0, EPAPR_MAGIC, CFG_SYS_BOOTMAPSZ,
Vikas Manocha62b021c2017-04-07 15:38:13 -070027 0, 0);
Stefan Roeseec90d342012-08-23 08:34:21 +020028}
29#endif /* CONFIG_SPL_OS_BOOT */