[PATCH] board: freescale: fix LS1021a build

Benjamin Lemouzy blemouzy.ml at gmail.com
Fri Feb 28 09:16:08 CET 2025


Hi Peng,

On Fri, 28 Feb 2025 12:10:01 +0800
Peng Fan <peng.fan at oss.nxp.com> wrote:

> On Mon, Feb 17, 2025 at 04:36:03PM +0100, blemouzy.ml at gmail.com wrote:
> >From: Benjamin Lemouzy <blemouzy at centralp.fr>
> >
> >Fix build error "undefined reference to `is_warm_boot'" when
> >ls1021atsn and ls1021atwr boards are built with CONFIG_SPL=y and
> >CONFIG_DEEP_SLEEP=n.
> >
> >Signed-off-by: Benjamin Lemouzy <blemouzy at centralp.fr>
> >---
> > board/freescale/ls1021atsn/ls1021atsn.c | 4 ++++
> > board/freescale/ls1021atwr/ls1021atwr.c | 4 ++++
> > 2 files changed, 8 insertions(+)
> >
> >diff --git a/board/freescale/ls1021atsn/ls1021atsn.c b/board/freescale/ls1021atsn/ls1021atsn.c
> >index d1acccec11..6d64df7cc4 100644
> >--- a/board/freescale/ls1021atsn/ls1021atsn.c
> >+++ b/board/freescale/ls1021atsn/ls1021atsn.c
> >@@ -159,7 +159,9 @@ int board_early_init_f(void)
> > #ifdef CONFIG_XPL_BUILD
> > void board_init_f(ulong dummy)
> > {
> >+#if defined(CONFIG_DEEP_SLEEP)
> > 	void (*second_uboot)(void);
> >+#endif
> > 
> > 	/* Clear the BSS */
> > 	memset(__bss_start, 0, __bss_end - __bss_start);
> >@@ -181,6 +183,7 @@ void board_init_f(ulong dummy)
> > 	enable_layerscape_ns_access();
> > #endif
> > 
> >+#if defined(CONFIG_DEEP_SLEEP)
> > 	/*
> > 	 * if it is woken up from deep sleep, then jump to second
> > 	 * stage U-Boot and continue executing without recopying
> >@@ -191,6 +194,7 @@ void board_init_f(ulong dummy)
> > 		second_uboot = (void (*)(void))CONFIG_TEXT_BASE;
> > 		second_uboot();
> > 	}
> >+#endif  
> 
> Please use 'if (CONFIG_IS_ENABLED(DEEP_SLEEP) {}'
> Then no need guard 'void (*second_uboot)(void)' with if defined.

I was torn between using the new syntax and keeping coherency with the
rest of the file: I will always use new syntax now!

I saw you submitted the V2: thanks for that (and the review).

Benjamin

> 
> > 
> > 	board_init_r(NULL, 0);
> > }
> >diff --git a/board/freescale/ls1021atwr/ls1021atwr.c b/board/freescale/ls1021atwr/ls1021atwr.c
> >index cc9665c041..937e766069 100644
> >--- a/board/freescale/ls1021atwr/ls1021atwr.c
> >+++ b/board/freescale/ls1021atwr/ls1021atwr.c
> >@@ -410,7 +410,9 @@ int board_early_init_f(void)
> > #ifdef CONFIG_XPL_BUILD
> > void board_init_f(ulong dummy)
> > {
> >+#if defined(CONFIG_DEEP_SLEEP)
> > 	void (*second_uboot)(void);
> >+#endif
> > 
> > 	/* Clear the BSS */
> > 	memset(__bss_start, 0, __bss_end - __bss_start);
> >@@ -432,6 +434,7 @@ void board_init_f(ulong dummy)
> > 	enable_layerscape_ns_access();
> > #endif
> > 
> >+#if defined(CONFIG_DEEP_SLEEP)
> > 	/*
> > 	 * if it is woken up from deep sleep, then jump to second
> > 	 * stage uboot and continue executing without recopying
> >@@ -442,6 +445,7 @@ void board_init_f(ulong dummy)
> > 		second_uboot = (void (*)(void))CONFIG_TEXT_BASE;
> > 		second_uboot();
> > 	}
> >+#endif  
> 
> Ditto.
> 
> Thanks,
> Peng
> > 
> > 	board_init_r(NULL, 0);
> > }
> >-- 
> >2.43.0
> >  



More information about the U-Boot mailing list