blob: 724c33987ba430675c649e4cab5b3fe4b23acd10 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Michal Simek952d5142007-03-11 13:42:58 +01002/*
Michal Simek4e39ea82018-07-13 08:26:28 +02003 * (C) Copyright 2007-2018 Michal Simek
Michal Simek952d5142007-03-11 13:42:58 +01004 *
Michal Simek4e39ea82018-07-13 08:26:28 +02005 * Michal SIMEK <monstr@monstr.eu>
Michal Simek952d5142007-03-11 13:42:58 +01006 */
7
Shreenidhi Shediffced402018-07-15 02:34:35 +05308/*
9 * This is a board specific file. It's OK to include board specific
10 * header files
11 */
Michal Simek952d5142007-03-11 13:42:58 +010012
13#include <common.h>
Michal Simekdda9bd82007-03-30 22:52:09 +020014#include <config.h>
Simon Glassed38aef2020-05-10 11:40:03 -060015#include <env.h>
Simon Glassa7b51302019-11-14 12:57:46 -070016#include <init.h>
Simon Glass0f2af882020-05-10 11:40:05 -060017#include <log.h>
Michal Simek4e39ea82018-07-13 08:26:28 +020018#include <dm/lists.h>
Michal Simek65e915c2014-05-08 16:08:44 +020019#include <fdtdec.h>
Michal Simek360da4b2019-09-25 11:00:17 +020020#include <linux/sizes.h>
Michal Simek23ccda02013-04-24 10:01:20 +020021
Michal Simek65e915c2014-05-08 16:08:44 +020022DECLARE_GLOBAL_DATA_PTR;
23
Simon Glass2f949c32017-03-31 08:40:32 -060024int dram_init_banksize(void)
Michal Simek65e915c2014-05-08 16:08:44 +020025{
Michal Simekfdf3d802018-11-22 12:39:18 +010026 return fdtdec_setup_memory_banksize();
Michal Simek65e915c2014-05-08 16:08:44 +020027}
28
29int dram_init(void)
30{
Michal Simekfdf3d802018-11-22 12:39:18 +010031 if (fdtdec_setup_mem_size_base() != 0)
32 return -EINVAL;
Michal Simek65e915c2014-05-08 16:08:44 +020033
34 return 0;
35};
Michal Simek65e915c2014-05-08 16:08:44 +020036
Michal Simek01525242015-12-11 15:01:28 +010037int board_late_init(void)
Michal Simek9cabb362012-07-04 13:12:37 +020038{
Michal Simek360da4b2019-09-25 11:00:17 +020039 ulong max_size, lowmem_size;
T Karthik Reddy51d78152020-09-22 05:18:53 -060040 u32 status = 0;
Michal Simek360da4b2019-09-25 11:00:17 +020041
Michal Simek4e39ea82018-07-13 08:26:28 +020042#if !defined(CONFIG_SPL_BUILD) && defined(CONFIG_SYSRESET_MICROBLAZE)
43 int ret;
Shreenidhi Shedi1f8fcbb2018-07-15 02:05:40 +053044
Michal Simek4e39ea82018-07-13 08:26:28 +020045 ret = device_bind_driver(gd->dm_root, "mb_soft_reset",
46 "reset_soft", NULL);
47 if (ret)
48 printf("Warning: No reset driver: ret=%d\n", ret);
49#endif
Michal Simek360da4b2019-09-25 11:00:17 +020050
51 if (!(gd->flags & GD_FLG_ENV_DEFAULT)) {
52 debug("Saved variables - Skipping\n");
53 return 0;
54 }
55
56 max_size = gd->start_addr_sp - CONFIG_STACK_SIZE;
57 max_size = round_down(max_size, SZ_16M);
58
59 /* Linux default LOWMEM_SIZE is 0x30000000 = 768MB */
60 lowmem_size = gd->ram_base + 768 * 1024 * 1024;
61
T Karthik Reddy51d78152020-09-22 05:18:53 -060062 status |= env_set_addr("initrd_high", (void *)min_t(ulong, max_size,
63 lowmem_size));
64 status |= env_set_addr("fdt_high", (void *)min_t(ulong, max_size,
65 lowmem_size));
66 if (status)
67 printf("%s: Saving run time variables FAILED\n", __func__);
Michal Simek360da4b2019-09-25 11:00:17 +020068
Michal Simek01525242015-12-11 15:01:28 +010069 return 0;
Michal Simek9cabb362012-07-04 13:12:37 +020070}