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
|
# core
|
||||||
ifndef CONFIG_SPL_BUILD
|
ifndef CONFIG_SPL_BUILD
|
||||||
|
obj-y += init/
|
||||||
obj-y += main.o
|
obj-y += main.o
|
||||||
obj-y += exports.o
|
obj-y += exports.o
|
||||||
obj-y += hash.o
|
obj-y += hash.o
|
||||||
|
@ -1030,32 +1030,3 @@ void board_init_f_r(void)
|
|||||||
hang();
|
hang();
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_X86 */
|
#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-$(HAVE_VENDOR_COMMON_LIB) += board/$(VENDOR)/common/
|
||||||
|
|
||||||
libs-$(CONFIG_SPL_FRAMEWORK) += common/spl/
|
libs-$(CONFIG_SPL_FRAMEWORK) += common/spl/
|
||||||
|
libs-y += common/init/
|
||||||
libs-$(CONFIG_SPL_LIBCOMMON_SUPPORT) += common/
|
libs-$(CONFIG_SPL_LIBCOMMON_SUPPORT) += common/
|
||||||
libs-$(CONFIG_SPL_LIBDISK_SUPPORT) += disk/
|
libs-$(CONFIG_SPL_LIBDISK_SUPPORT) += disk/
|
||||||
libs-y += drivers/
|
libs-y += drivers/
|
||||||
|
Loading…
Reference in New Issue
Block a user