1 // SPDX-License-Identifier: GPL-2.0+
3 * (C) Copyright 2007-2018 Michal Simek
5 * Michal SIMEK <monstr@monstr.eu>
9 * This is a board specific file. It's OK to include board specific
20 #include <asm/global_data.h>
23 #include <linux/sizes.h>
24 #include "../common/board.h"
26 DECLARE_GLOBAL_DATA_PTR;
28 int dram_init_banksize(void)
30 return fdtdec_setup_memory_banksize();
35 if (fdtdec_setup_mem_size_base() != 0)
41 ulong board_get_usable_ram_top(ulong total_size)
47 /* found enough not-reserved memory to relocated U-Boot */
49 lmb_add(&lmb, gd->ram_base, gd->ram_size);
50 boot_fdt_add_mem_rsv_regions(&lmb, (void *)gd->fdt_blob);
51 size = ALIGN(CONFIG_SYS_MALLOC_LEN + total_size, MMU_SECTION_SIZE);
52 reg = lmb_alloc(&lmb, size, MMU_SECTION_SIZE);
55 reg = gd->ram_top - size;
60 int board_late_init(void)
65 #if !defined(CONFIG_SPL_BUILD) && defined(CONFIG_SYSRESET_MICROBLAZE)
68 ret = device_bind_driver(gd->dm_root, "mb_soft_reset",
71 printf("Warning: No reset driver: ret=%d\n", ret);
74 if (!(gd->flags & GD_FLG_ENV_DEFAULT)) {
75 debug("Saved variables - Skipping\n");
79 max_size = gd->start_addr_sp - CONFIG_STACK_SIZE;
80 max_size = round_down(max_size, SZ_16M);
82 status |= env_set_hex("scriptaddr", max_size + SZ_2M);
84 status |= env_set_hex("pxefile_addr_r", max_size + SZ_1M);
86 status |= env_set_hex("kernel_addr_r", gd->ram_base + SZ_32M);
88 status |= env_set_hex("fdt_addr_r", gd->ram_base + SZ_32M - SZ_1M);
90 status |= env_set_hex("ramdisk_addr_r",
91 gd->ram_base + SZ_32M + SZ_4M + SZ_2M);
92 if (IS_ENABLED(CONFIG_MTD_NOR_FLASH))
93 status |= env_set_hex("script_offset_nor",
94 gd->bd->bi_flashstart +
95 CONFIG_BOOT_SCRIPT_OFFSET);
97 printf("%s: Saving run time variables FAILED\n", __func__);
99 return board_late_init_xilinx();