[U-Boot] [PATCH] board_f: save "malloc_base" from zeroing in case of CONFIG_SYS_MALLOC_F_LEN

Alexey Brodkin Alexey.Brodkin at synopsys.com
Mon Jan 19 18:55:03 CET 2015


In case of CONFIG_SYS_MALLOC_F_LEN "malloc_base" is used for early
start-up code and is set very early, typically in "start.S" or "crt1.S".

In current implementation in case of CONFIG_SYS_GENERIC_GLOBAL_DATA all
global data gets zeroed on "board_init_f" entry. But by that time
"malloc_base" could have been set already, which means it will be zeroed
and subsequent C-code will be executed improperly (if executed at all -
if there's no memory mapped to 0 or it is read-only then on some arches
there will be an exception and others will quetly die).

To work-around described situation we just need to make sure
"malloc_base" is saved prior zeroing global data and recovered
afterwards.

Signed-off-by: Alexey Brodkin <abrodkin at synopsys.com>
Cc: Wolfgang Denk <wd at denx.de>
Cc: Simon Glass <sjg at chromium.org>
Cc: Tom Rini <trini at ti.com>
Cc: Masahiro Yamada <yamada.m at jp.panasonic.com>
---
 common/board_f.c | 16 ++++++++++++++++
 1 file changed, 16 insertions(+)

diff --git a/common/board_f.c b/common/board_f.c
index 3a4b32c..ebdba0e 100644
--- a/common/board_f.c
+++ b/common/board_f.c
@@ -999,6 +999,9 @@ static init_fnc_t init_sequence_f[] = {
 void board_init_f(ulong boot_flags)
 {
 #ifdef CONFIG_SYS_GENERIC_GLOBAL_DATA
+#ifdef CONFIG_SYS_MALLOC_F_LEN
+	int malloc_base;
+#endif
 	/*
 	 * For some archtectures, global data is initialized and used before
 	 * calling this function. The data should be preserved. For others,
@@ -1009,12 +1012,25 @@ void board_init_f(ulong boot_flags)
 
 	gd = &data;
 
+#ifdef CONFIG_SYS_MALLOC_F_LEN
+	/*
+	 * "malloc_base" is supposed to be set in the very beginning of start-up
+	 * code (start.S or crt0.S), now we need to preserve it from zeroing.
+	 */
+	malloc_base = gd->malloc_base;
+#endif
+
 	/*
 	 * Clear global data before it is accessed at debug print
 	 * in initcall_run_list. Otherwise the debug print probably
 	 * get the wrong vaule of gd->have_console.
 	 */
 	zero_global_data();
+
+#ifdef CONFIG_SYS_MALLOC_F_LEN
+	/* Restore "malloc_base" value */
+	gd->malloc_base = malloc_base;
+#endif
 #endif
 
 	gd->flags = boot_flags;
-- 
2.1.0



More information about the U-Boot mailing list