Move board_init_f_mem() into a common location
This function will be used by both SPL and U-Boot proper. So move it into a common place. Also change the #ifdef so that the early malloc() area is not set up in SPL if CONFIG_SYS_SPL_MALLOC_START is defined. In that case it would never actually be used, and just chews up stack space. Signed-off-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
parent
47b7164450
commit
af6bbd4dae
@ -7,6 +7,7 @@
|
||||
|
||||
# core
|
||||
ifndef CONFIG_SPL_BUILD
|
||||
obj-y += init/
|
||||
obj-y += main.o
|
||||
obj-y += exports.o
|
||||
obj-y += hash.o
|
||||
|
@ -1030,32 +1030,3 @@ void board_init_f_r(void)
|
||||
hang();
|
||||
}
|
||||
#endif /* CONFIG_X86 */
|
||||
|
||||
/* Unfortunately x86 can't compile this code as gd cannot be assigned */
|
||||
#ifndef CONFIG_X86
|
||||
__weak void arch_setup_gd(struct global_data *gd_ptr)
|
||||
{
|
||||
gd = gd_ptr;
|
||||
}
|
||||
#endif /* !CONFIG_X86 */
|
||||
|
||||
ulong board_init_f_mem(ulong top)
|
||||
{
|
||||
struct global_data *gd_ptr;
|
||||
|
||||
/* Leave space for the stack we are running with now */
|
||||
top -= 0x40;
|
||||
|
||||
top -= sizeof(struct global_data);
|
||||
top = ALIGN(top, 16);
|
||||
gd_ptr = (struct global_data *)top;
|
||||
memset(gd_ptr, '\0', sizeof(*gd));
|
||||
arch_setup_gd(gd_ptr);
|
||||
|
||||
#ifdef CONFIG_SYS_MALLOC_F_LEN
|
||||
top -= CONFIG_SYS_MALLOC_F_LEN;
|
||||
gd->malloc_base = top;
|
||||
#endif
|
||||
|
||||
return top;
|
||||
}
|
||||
|
7
common/init/Makefile
Normal file
7
common/init/Makefile
Normal file
@ -0,0 +1,7 @@
|
||||
#
|
||||
# Copyright (c) 2015 Google, Inc
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-2.0+
|
||||
#
|
||||
|
||||
obj-y += board_init.o
|
41
common/init/board_init.c
Normal file
41
common/init/board_init.c
Normal file
@ -0,0 +1,41 @@
|
||||
/*
|
||||
* Code shared between SPL and U-Boot proper
|
||||
*
|
||||
* Copyright (c) 2015 Google, Inc
|
||||
* Written by Simon Glass <sjg@chromium.org>
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#include <common.h>
|
||||
|
||||
DECLARE_GLOBAL_DATA_PTR;
|
||||
|
||||
/* Unfortunately x86 can't compile this code as gd cannot be assigned */
|
||||
#ifndef CONFIG_X86
|
||||
__weak void arch_setup_gd(struct global_data *gd_ptr)
|
||||
{
|
||||
gd = gd_ptr;
|
||||
}
|
||||
#endif /* !CONFIG_X86 */
|
||||
|
||||
ulong board_init_f_mem(ulong top)
|
||||
{
|
||||
struct global_data *gd_ptr;
|
||||
|
||||
/* Leave space for the stack we are running with now */
|
||||
top -= 0x40;
|
||||
|
||||
top -= sizeof(struct global_data);
|
||||
top = ALIGN(top, 16);
|
||||
gd_ptr = (struct global_data *)top;
|
||||
memset(gd_ptr, '\0', sizeof(*gd));
|
||||
arch_setup_gd(gd_ptr);
|
||||
|
||||
#if defined(CONFIG_SYS_MALLOC_F)
|
||||
top -= CONFIG_SYS_MALLOC_F_LEN;
|
||||
gd->malloc_base = top;
|
||||
#endif
|
||||
|
||||
return top;
|
||||
}
|
@ -52,6 +52,7 @@ libs-y += $(if $(BOARDDIR),board/$(BOARDDIR)/)
|
||||
libs-$(HAVE_VENDOR_COMMON_LIB) += board/$(VENDOR)/common/
|
||||
|
||||
libs-$(CONFIG_SPL_FRAMEWORK) += common/spl/
|
||||
libs-y += common/init/
|
||||
libs-$(CONFIG_SPL_LIBCOMMON_SUPPORT) += common/
|
||||
libs-$(CONFIG_SPL_LIBDISK_SUPPORT) += disk/
|
||||
libs-y += drivers/
|
||||
|
Loading…
Reference in New Issue
Block a user