Skip to content
Snippets Groups Projects
Commit 12360982 authored by Simon Glass's avatar Simon Glass Committed by Tom Rini
Browse files

board_init_f_mem(): Don't require memset()


Unfortunately memset() is not always available, so provide a substitute when
needed.

Signed-off-by: default avatarSimon Glass <sjg@chromium.org>
parent af6bbd4d
No related branches found
No related tags found
No related merge requests found
...@@ -11,6 +11,16 @@ ...@@ -11,6 +11,16 @@
DECLARE_GLOBAL_DATA_PTR; DECLARE_GLOBAL_DATA_PTR;
/*
* It isn't trivial to figure out whether memcpy() exists. The arch-specific
* memcpy() is not normally available in SPL due to code size.
*/
#if !defined(CONFIG_SPL_BUILD) || \
(defined(CONFIG_SPL_LIBGENERIC_SUPPORT) && \
!defined(CONFIG_USE_ARCH_MEMSET))
#define _USE_MEMCPY
#endif
/* Unfortunately x86 can't compile this code as gd cannot be assigned */ /* Unfortunately x86 can't compile this code as gd cannot be assigned */
#ifndef CONFIG_X86 #ifndef CONFIG_X86
__weak void arch_setup_gd(struct global_data *gd_ptr) __weak void arch_setup_gd(struct global_data *gd_ptr)
...@@ -22,6 +32,9 @@ __weak void arch_setup_gd(struct global_data *gd_ptr) ...@@ -22,6 +32,9 @@ __weak void arch_setup_gd(struct global_data *gd_ptr)
ulong board_init_f_mem(ulong top) ulong board_init_f_mem(ulong top)
{ {
struct global_data *gd_ptr; struct global_data *gd_ptr;
#ifndef _USE_MEMCPY
int *ptr;
#endif
/* Leave space for the stack we are running with now */ /* Leave space for the stack we are running with now */
top -= 0x40; top -= 0x40;
...@@ -29,7 +42,12 @@ ulong board_init_f_mem(ulong top) ...@@ -29,7 +42,12 @@ ulong board_init_f_mem(ulong top)
top -= sizeof(struct global_data); top -= sizeof(struct global_data);
top = ALIGN(top, 16); top = ALIGN(top, 16);
gd_ptr = (struct global_data *)top; gd_ptr = (struct global_data *)top;
#ifdef _USE_MEMCPY
memset(gd_ptr, '\0', sizeof(*gd)); memset(gd_ptr, '\0', sizeof(*gd));
#else
for (ptr = (int *)gd_ptr; ptr < (int *)(gd_ptr + 1); )
*ptr++ = 0;
#endif
arch_setup_gd(gd_ptr); arch_setup_gd(gd_ptr);
#if defined(CONFIG_SYS_MALLOC_F) #if defined(CONFIG_SYS_MALLOC_F)
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment