]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
arm: xea: Modify board code to generate single binary u-boot
authorLukasz Majewski <lukma@denx.de>
Mon, 27 Dec 2021 10:38:21 +0000 (11:38 +0100)
committerStefano Babic <sbabic@denx.de>
Sat, 5 Feb 2022 12:38:39 +0000 (13:38 +0100)
This change provides the possibility to build XEA (imx287 based) board
U-Boot as a single binary (without support for CONFIG_SPL_FRAMEWORK).

The generated u-boot.sb can be used in the factory environment to for
example perform initial setup or HW testing.

It can be used with 'uuu' utility
(SDPS: boot -f /srv/tftp/xea/u-boot.sb)

In the configs/imx28_xea_defconfig one needs to disable following configs:
# CONFIG_SPL_BLK is not set
# CONFIG_SPL_FRAMEWORK is not set

The board_init_ll() is used in arch/arm/cpu/arm926ejs/mxs/start.S, which
is utilized when CONFIG_SPL_FRAMEWORK is disabled.

However, when it is enabled - the arch/arm/cpu/arm926ejs/start.S is used,
which requires the lowlevel_init() function.

Signed-off-by: Lukasz Majewski <lukma@denx.de>
board/liebherr/xea/spl_xea.c
board/liebherr/xea/xea.c

index 192f68fca5f8bcd5c32a79e40fd049ca182fa4d3..df354cac641d68cb271bf5c06495bcfcc7853c86 100644 (file)
@@ -290,6 +290,12 @@ u32 mxs_dram_vals[] = {
        0x00000000, 0xffffffff
 };
 
+#ifndef CONFIG_SPL_FRAMEWORK
+void board_init_ll(const u32 arg, const uint32_t *resptr)
+{
+       mxs_common_spl_init(arg, resptr, iomux_setup, ARRAY_SIZE(iomux_setup));
+}
+#else
 void lowlevel_init(void)
 {
        struct mxs_pinctrl_regs *pinctrl_regs =
@@ -301,3 +307,4 @@ void lowlevel_init(void)
 
        mxs_common_spl_init(0, NULL, iomux_setup, ARRAY_SIZE(iomux_setup));
 }
+#endif
index cd11b0ada77c2417c7b3c2ab567fb691347aae0d..38e841c5f679c5400d2eead9f44cc284411b774c 100644 (file)
@@ -58,7 +58,7 @@ static void init_clocks(void)
        mxs_set_sspclk(MXC_SSPCLK3, 96000, 0);
 }
 
-#ifdef CONFIG_SPL_BUILD
+#if defined(CONFIG_SPL_BUILD) && defined(CONFIG_SPL_FRAMEWORK)
 void board_init_f(ulong arg)
 {
        init_clocks();