X-Git-Url: https://git.kernelconcepts.de/?a=blobdiff_plain;f=common%2Fmalloc_simple.c;h=9811ab60f6d174a35c9b4e68d39321bca4beb8be;hb=c08f84e1a3a90fe4f10b0a8f3a7426e0ebd3b984;hp=afdacff80d8e1fc411cba7eab59286ef28a8a1e5;hpb=878cd63e02f63f245182a101807186b44e20f116;p=karo-tx-uboot.git diff --git a/common/malloc_simple.c b/common/malloc_simple.c index afdacff80d..9811ab60f6 100644 --- a/common/malloc_simple.c +++ b/common/malloc_simple.c @@ -8,6 +8,7 @@ #include #include +#include #include DECLARE_GLOBAL_DATA_PTR; @@ -19,12 +20,26 @@ void *malloc_simple(size_t bytes) new_ptr = gd->malloc_ptr + bytes; if (new_ptr > gd->malloc_limit) - panic("Out of pre-reloc memory"); + return NULL; ptr = map_sysmem(gd->malloc_base + gd->malloc_ptr, bytes); gd->malloc_ptr = ALIGN(new_ptr, sizeof(new_ptr)); return ptr; } +void *memalign_simple(size_t align, size_t bytes) +{ + ulong addr, new_ptr; + void *ptr; + + addr = ALIGN(gd->malloc_base + gd->malloc_ptr, bytes); + new_ptr = addr + bytes; + if (new_ptr > gd->malloc_limit) + return NULL; + ptr = map_sysmem(addr, bytes); + gd->malloc_ptr = ALIGN(new_ptr, sizeof(new_ptr)); + return ptr; +} + #ifdef CONFIG_SYS_MALLOC_SIMPLE void *calloc(size_t nmemb, size_t elem_size) {