blob: f4d3b67e5dd08c7e4d6a95edeae7bf5770bc6098 [file] [log] [blame]
Lukas Auer396f0bd2019-08-21 21:14:45 +02001// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Copyright (C) 2019 Fraunhofer AISEC,
4 * Lukas Auer <lukas.auer@aisec.fraunhofer.de>
5 */
6#include <common.h>
Simon Glass63334482019-11-14 12:57:39 -07007#include <cpu_func.h>
Simon Glassf11478f2019-12-28 10:45:07 -07008#include <hang.h>
Simon Glass97589732020-05-10 11:40:02 -06009#include <init.h>
Simon Glass0f2af882020-05-10 11:40:05 -060010#include <log.h>
Lukas Auer396f0bd2019-08-21 21:14:45 +020011#include <spl.h>
Simon Glass3ba929a2020-10-30 21:38:53 -060012#include <asm/global_data.h>
Lukas Auer396f0bd2019-08-21 21:14:45 +020013#include <asm/smp.h>
Simon Glassfc557362022-03-04 08:43:05 -070014#include <asm/system.h>
Lukas Auer396f0bd2019-08-21 21:14:45 +020015
16DECLARE_GLOBAL_DATA_PTR;
17
Bin Meng63dcfcb2020-08-02 23:09:01 -070018__weak int spl_board_init_f(void)
19{
20 return 0;
21}
22
Lukas Auer396f0bd2019-08-21 21:14:45 +020023__weak void board_init_f(ulong dummy)
24{
25 int ret;
26
27 ret = spl_early_init();
28 if (ret)
29 panic("spl_early_init() failed: %d\n", ret);
30
Simon Glassfc557362022-03-04 08:43:05 -070031 riscv_cpu_setup(NULL, NULL);
Lukas Auer396f0bd2019-08-21 21:14:45 +020032
33 preloader_console_init();
Bin Meng63dcfcb2020-08-02 23:09:01 -070034
35 ret = spl_board_init_f();
36 if (ret)
37 panic("spl_board_init_f() failed: %d\n", ret);
Lukas Auer396f0bd2019-08-21 21:14:45 +020038}
39
40void __noreturn jump_to_image_no_args(struct spl_image_info *spl_image)
41{
42 typedef void __noreturn (*image_entry_riscv_t)(ulong hart, void *dtb);
43 void *fdt_blob;
Heinrich Schuchardtc78eef72020-08-15 09:49:26 +020044 __maybe_unused int ret;
Lukas Auer396f0bd2019-08-21 21:14:45 +020045
46#if CONFIG_IS_ENABLED(LOAD_FIT) || CONFIG_IS_ENABLED(LOAD_FIT_FULL)
47 fdt_blob = spl_image->fdt_addr;
48#else
49 fdt_blob = (void *)gd->fdt_blob;
50#endif
51
52 image_entry_riscv_t image_entry =
53 (image_entry_riscv_t)spl_image->entry_point;
54 invalidate_icache_all();
55
56 debug("image entry point: 0x%lX\n", spl_image->entry_point);
Bin Mengb161f902020-04-16 08:09:30 -070057#ifdef CONFIG_SPL_SMP
Lukas Auerc308e012019-12-08 23:28:51 +010058 ret = smp_call_function(spl_image->entry_point, (ulong)fdt_blob, 0, 0);
Lukas Auer396f0bd2019-08-21 21:14:45 +020059 if (ret)
60 hang();
61#endif
62 image_entry(gd->arch.boot_hart, fdt_blob);
63}