board_init: Change the logic to setup malloc_base
authorFabio Estevam <fabio.estevam@freescale.com>
Thu, 12 Nov 2015 14:30:19 +0000 (12:30 -0200)
committerTom Rini <trini@konsulko.com>
Fri, 13 Nov 2015 01:34:07 +0000 (20:34 -0500)
Prior to commit 5ba534d247d418 ("arm: Switch 32-bit ARM to using generic
global_data setup") we used to have assembly code that configured the
malloc_base address.

Since this commit we use the board_init_f_mem() function in C to setup
malloc_base address.

In board_init_f_mem() there was a deliberate choice to support only
early malloc() or full malloc() in SPL, but not both.

Adapt this logic to allow both to be used, one after the other, in SPL.

This issue has been observed in a Congatec board, where we need to
retrieve the manufacturing information from the SPI NOR (the SPI API
calls malloc) prior to configuring the DRAM. In this case as malloc_base
was not configured we always see malloc to fail.

With this change we are able to use malloc in SPL prior to DRAM gets
initialized.

Also update the CONFIG_SYS_SPL_MALLOC_START entry in the README file.

Signed-off-by: Fabio Estevam <fabio.estevam@freescale.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
README
common/init/board_init.c

diff --git a/README b/README
index e98c49b6b7a4e01c1af0332fa0163c24c164df3c..32c5ea66531302af1d311d5fbc94e98abdfa17ee 100644 (file)
--- a/README
+++ b/README
@@ -3577,6 +3577,9 @@ FIT uImage format:
 
                CONFIG_SYS_SPL_MALLOC_START
                Starting address of the malloc pool used in SPL.
+               When this option is set the full malloc is used in SPL and
+               it is set up by spl_init() and before that, the simple malloc()
+               can be used if CONFIG_SYS_MALLOC_F is defined.
 
                CONFIG_SYS_SPL_MALLOC_SIZE
                The size of the malloc pool used in SPL.
index e74b63b8a8717cffe052a0a8bf393c1b2855c45e..1c6126d8ce55a08c85f8e0d576672fdf7f16f8bf 100644 (file)
@@ -50,8 +50,7 @@ ulong board_init_f_mem(ulong top)
 #endif
        arch_setup_gd(gd_ptr);
 
-#if defined(CONFIG_SYS_MALLOC_F) && \
-       (!defined(CONFIG_SPL_BUILD) || !defined(CONFIG_SYS_SPL_MALLOC_START))
+#if defined(CONFIG_SYS_MALLOC_F)
        top -= CONFIG_SYS_MALLOC_F_LEN;
        gd->malloc_base = top;
 #endif