[U-Boot] [PATCH 1/2] ARMv8: enable pre-allocation malloc
Albert ARIBAUD
albert.u.boot at aribaud.net
Fri Mar 27 16:35:56 CET 2015
Hello fenghua at phytium.com.cn,
On Sat, 31 Jan 2015 11:55:28 +0800, fenghua at phytium.com.cn <fenghua at phytium.com.cn> wrote:
> From: David Feng <fenghua at phytium.com.cn>
>
> Allocate memory space for pre-allocation malloc and zero global data.
> This code is partly from crt0.S.
>
> Signed-off-by: David Feng <fenghua at phytium.com.cn>
> ---
> arch/arm/include/asm/config.h | 4 ----
> arch/arm/lib/crt0_64.S | 13 +++++++++++--
> 2 files changed, 11 insertions(+), 6 deletions(-)
>
> diff --git a/arch/arm/include/asm/config.h b/arch/arm/include/asm/config.h
> index be80434..7a34a01 100644
> --- a/arch/arm/include/asm/config.h
> +++ b/arch/arm/include/asm/config.h
> @@ -7,10 +7,6 @@
> #ifndef _ASM_CONFIG_H_
> #define _ASM_CONFIG_H_
>
> -#ifdef __aarch64__
> -#define CONFIG_SYS_GENERIC_GLOBAL_DATA
> -#endif
> -
> #define CONFIG_LMB
> #define CONFIG_SYS_BOOT_RAMDISK_HIGH
>
> diff --git a/arch/arm/lib/crt0_64.S b/arch/arm/lib/crt0_64.S
> index 7756396..1654011 100644
> --- a/arch/arm/lib/crt0_64.S
> +++ b/arch/arm/lib/crt0_64.S
> @@ -62,9 +62,18 @@ ENTRY(_main)
> * Set up initial C runtime environment and call board_init_f(0).
> */
> ldr x0, =(CONFIG_SYS_INIT_SP_ADDR)
> - sub x0, x0, #GD_SIZE /* allocate one GD above SP */
> + sub x18, x0, #GD_SIZE /* allocate one GD above SP */
> + bic x18, x18, #0x7 /* 8-byte alignment for GD */
> +zero_gd:
> + sub x0, x0, #0x8
> + str xzr, [x0]
> + cmp x0, x18
> + b.gt zero_gd
> +#if defined(CONFIG_SYS_MALLOC_F_LEN)
> + sub x0, x18, #CONFIG_SYS_MALLOC_F_LEN
> + str x0, [x18, #GD_MALLOC_BASE]
> +#endif
> bic sp, x0, #0xf /* 16-byte alignment for ABI compliance */
> - mov x18, sp /* GD is above SP */
> mov x0, #0
> bl board_init_f
>
> --
> 1.7.9.5
>
>
Applied to u-boot-arm/master, thanks!
Amicalement,
--
Albert.
More information about the U-Boot
mailing list