imx: spl: implement spl_load_simple_fit_fix_load
authorHeiko Schocher <hs@denx.de>
Fri, 6 Aug 2021 04:44:27 +0000 (06:44 +0200)
committerStefano Babic <sbabic@denx.de>
Thu, 7 Oct 2021 14:53:50 +0000 (16:53 +0200)
read the address where the IVT header must sit
from IVT image header, loaded from SPL into
an malloced buffer and copy the IVT header
to this address

May make this dependend on SoC ?

Signed-off-by: Heiko Schocher <hs@denx.de>
arch/arm/mach-imx/spl.c

index c2845241d9dcb50571d02ded72ba1373b31107fb..01f6f0a1dee0264a66cb432626b8528c4722f1ae 100644 (file)
@@ -345,3 +345,36 @@ int dram_init_banksize(void)
        return 0;
 }
 #endif
+
+/*
+ * read the address where the IVT header must sit
+ * from IVT image header, loaded from SPL into
+ * an malloced buffer and copy the IVT header
+ * to this address
+ */
+void *spl_load_simple_fit_fix_load(const void *fit)
+{
+       struct ivt *ivt;
+       unsigned long new;
+       unsigned long offset;
+       unsigned long size;
+       u8 *tmp = (u8 *)fit;
+
+       offset = ALIGN(fdt_totalsize(fit), 0x1000);
+       size = ALIGN(fdt_totalsize(fit), 4);
+       size = board_spl_fit_size_align(size);
+       tmp += offset;
+       ivt = (struct ivt *)tmp;
+       if (ivt->hdr.magic != IVT_HEADER_MAGIC) {
+               debug("no IVT header found\n");
+               return (void *)fit;
+       }
+       debug("%s: ivt: %p offset: %lx size: %lx\n", __func__, ivt, offset, size);
+       debug("%s: ivt self: %x\n", __func__, ivt->self);
+       new = ivt->self;
+       new -= offset;
+       debug("%s: new %lx\n", __func__, new);
+       memcpy((void *)new, fit, size);
+
+       return (void *)new;
+}