]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
xilinx: Add DDR base address to bootscript address
authorT Karthik Reddy <t.karthik.reddy@xilinx.com>
Wed, 1 Apr 2020 12:01:21 +0000 (06:01 -0600)
committerMichal Simek <michal.simek@xilinx.com>
Tue, 27 Oct 2020 07:13:33 +0000 (08:13 +0100)
Add ram base address to scriptaddr env variable to make boot
script address to be a valid address when ddr base address changes.

This works properly if the first memory region is the region where uboot
runs. Also the solution was taken in respect of a lot of jtag script
putting u-boot script to certain address. For standard cases
bd->bi_dram[0].start is 0 all the time. Only for systems with DDR placed
out of this location it does calculation.

This is not the best solution and should be done differently in future but
enough for now till we don't have full solution ready yet.

Signed-off-by: T Karthik Reddy <t.karthik.reddy@xilinx.com>
Signed-off-by: Michal Simek <michal.simek@xilinx.com>
board/xilinx/common/board.c

index 821ee836dd8465a9acf1e91057efe1e090c3a788..857a66a50407ec5e0e1f131046ba7be6b5ef590c 100644 (file)
@@ -371,6 +371,15 @@ int board_late_init_xilinx(void)
        int i, id, macid = 0;
        struct xilinx_board_description *desc;
        phys_size_t bootm_size = gd->ram_size;
+       struct bd_info *bd = gd->bd;
+
+       if (bd->bi_dram[0].start) {
+               ulong scriptaddr;
+
+               scriptaddr = env_get_hex("scriptaddr", 0);
+               ret |= env_set_hex("scriptaddr",
+                                  bd->bi_dram[0].start + scriptaddr);
+       }
 
        if (CONFIG_IS_ENABLED(ARCH_ZYNQ))
                bootm_size = min(bootm_size, (phys_size_t)(SZ_512M + SZ_256M));