c1ae8fbfe742a16b99964bff499e05eb0c8d3739
[platform/kernel/u-boot.git] / board / xilinx / microblaze-generic / microblaze-generic.c
1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * (C) Copyright 2007-2018 Michal Simek
4  *
5  * Michal SIMEK <monstr@monstr.eu>
6  */
7
8 /*
9  * This is a board specific file.  It's OK to include board specific
10  * header files
11  */
12
13 #include <common.h>
14 #include <config.h>
15 #include <env.h>
16 #include <init.h>
17 #include <log.h>
18 #include <dm/lists.h>
19 #include <fdtdec.h>
20 #include <linux/sizes.h>
21
22 DECLARE_GLOBAL_DATA_PTR;
23
24 int dram_init_banksize(void)
25 {
26         return fdtdec_setup_memory_banksize();
27 }
28
29 int dram_init(void)
30 {
31         if (fdtdec_setup_mem_size_base() != 0)
32                 return -EINVAL;
33
34         return 0;
35 };
36
37 int board_late_init(void)
38 {
39         ulong max_size, lowmem_size;
40         u32 status = 0;
41
42 #if !defined(CONFIG_SPL_BUILD) && defined(CONFIG_SYSRESET_MICROBLAZE)
43         int ret;
44
45         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
50
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
62         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
67         status |= env_set_hex("scriptaddr", max_size + SZ_2M);
68
69         status |= env_set_hex("pxefile_addr_r", max_size + SZ_1M);
70
71         status |= env_set_hex("kernel_addr_r", gd->ram_base + SZ_32M);
72
73         status |= env_set_hex("fdt_addr_r", gd->ram_base + SZ_32M - SZ_1M);
74
75         status |= env_set_hex("ramdisk_addr_r",
76                                gd->ram_base + SZ_32M + SZ_4M + SZ_2M);
77
78         status |= env_set_hex("script_offset_f", CONFIG_BOOT_SCRIPT_OFFSET);
79
80         if (status)
81                 printf("%s: Saving run time variables FAILED\n", __func__);
82
83         return 0;
84 }