blob: 504fd27d28527e3d6339532dcc604533a2030e4c [file] [log] [blame]
Paul Burtoncd71b1d2018-12-16 19:25:22 -03001// SPDX-License-Identifier: GPL-2.0+
2/*
3 * JZ4780 common routines
4 *
5 * Copyright (c) 2013 Imagination Technologies
6 * Author: Paul Burton <paul.burton@imgtec.com>
7 */
8
9#include <config.h>
Simon Glass1eb69ae2019-11-14 12:57:39 -070010#include <cpu_func.h>
Simon Glassdb41d652019-12-28 10:45:07 -070011#include <hang.h>
Simon Glass4d72caa2020-05-10 11:40:01 -060012#include <image.h>
Simon Glass67c4e9f2019-11-14 12:57:45 -070013#include <init.h>
Simon Glass401d1c42020-10-30 21:38:53 -060014#include <asm/global_data.h>
Paul Burtoncd71b1d2018-12-16 19:25:22 -030015#include <asm/io.h>
16#include <asm/sections.h>
17#include <mach/jz4780.h>
18#include <mach/jz4780_dram.h>
19#include <mmc.h>
20#include <spl.h>
21
Simon Glassbef9fdb2024-09-29 19:49:46 -060022#ifdef CONFIG_XPL_BUILD
Paul Burtoncd71b1d2018-12-16 19:25:22 -030023/* Pointer to the global data structure for SPL */
24DECLARE_GLOBAL_DATA_PTR;
Marek BehĂșn236f2ec2021-05-20 13:23:52 +020025gd_t gdata __section(".bss");
Paul Burtoncd71b1d2018-12-16 19:25:22 -030026
27void board_init_f(ulong dummy)
28{
29 typedef void __noreturn (*image_entry_noargs_t)(void);
30 struct mmc *mmc;
31 unsigned long count;
Simon Glassf3543e62022-09-06 20:26:52 -060032 struct legacy_img_hdr *header;
Paul Burtoncd71b1d2018-12-16 19:25:22 -030033 int ret;
34
35 /* Set global data pointer */
36 gd = &gdata;
37
38 timer_init();
39 pll_init();
40 sdram_init();
41 enable_caches();
42
43 /* Clear the BSS */
Shiji Yangccea96f2023-08-03 09:47:17 +080044 memset(__bss_start, 0, (size_t)__bss_end - (size_t)__bss_start);
Paul Burtoncd71b1d2018-12-16 19:25:22 -030045
46 gd->flags |= GD_FLG_SPL_INIT;
47
48 ret = mmc_initialize(NULL);
49 if (ret)
50 hang();
51
52 mmc = find_mmc_device(BOOT_DEVICE_MMC1);
53 if (ret)
54 hang();
55
56 ret = mmc_init(mmc);
57 if (ret)
58 hang();
59
Simon Glass98463902022-10-20 18:22:39 -060060 header = (struct legacy_img_hdr *)(CONFIG_TEXT_BASE -
Simon Glassf3543e62022-09-06 20:26:52 -060061 sizeof(struct legacy_img_hdr));
Paul Burtoncd71b1d2018-12-16 19:25:22 -030062
63 count = blk_dread(mmc_get_blk_desc(mmc),
64 CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_SECTOR,
65 0x800, header);
66 if (count == 0)
67 hang();
68
69 image_entry_noargs_t image_entry =
Simon Glass98463902022-10-20 18:22:39 -060070 (image_entry_noargs_t)CONFIG_TEXT_BASE;
Paul Burtoncd71b1d2018-12-16 19:25:22 -030071
72 image_entry();
73
74 hang();
75}
Simon Glassbef9fdb2024-09-29 19:49:46 -060076#endif /* CONFIG_XPL_BUILD */
Paul Burtoncd71b1d2018-12-16 19:25:22 -030077
Heinrich Schuchardtd768dd82023-08-12 20:16:58 +020078phys_addr_t board_get_usable_ram_top(phys_size_t total_size)
Paul Burtoncd71b1d2018-12-16 19:25:22 -030079{
Tom Riniaa6e94d2022-11-16 13:10:37 -050080 return CFG_SYS_SDRAM_BASE + (256 * 1024 * 1024);
Paul Burtoncd71b1d2018-12-16 19:25:22 -030081}
82
83int print_cpuinfo(void)
84{
85 printf("CPU: Ingenic JZ4780\n");
86 return 0;
87}