blob: 0a004d40e1ec80ae9e7b5d61c4f8d831462083d8 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Simon Glassc9356be2014-11-10 17:16:43 -07002/*
3 * Simple malloc implementation
4 *
5 * Copyright (c) 2014 Google, Inc
Simon Glassc9356be2014-11-10 17:16:43 -07006 */
7
Simon Glass7cbd2d22018-11-18 08:14:26 -07008#define LOG_CATEGORY LOGC_ALLOC
9
Tom Rinid678a592024-05-18 20:20:43 -060010#include <common.h>
Simon Glassf7ae49f2020-05-10 11:40:05 -060011#include <log.h>
Simon Glassc9356be2014-11-10 17:16:43 -070012#include <malloc.h>
Joe Hershberger0eb25b62015-03-22 17:08:59 -050013#include <mapmem.h>
Simon Glass401d1c42020-10-30 21:38:53 -060014#include <asm/global_data.h>
Simon Glassc9356be2014-11-10 17:16:43 -070015#include <asm/io.h>
Sean Andersonbdaeea12022-03-23 14:04:49 -040016#include <valgrind/valgrind.h>
Simon Glassc9356be2014-11-10 17:16:43 -070017
18DECLARE_GLOBAL_DATA_PTR;
19
Simon Glass7cbd2d22018-11-18 08:14:26 -070020static void *alloc_simple(size_t bytes, int align)
Simon Glassb6bfb6f2015-05-12 14:55:06 -060021{
22 ulong addr, new_ptr;
23 void *ptr;
24
Simon Glass972ea532015-08-14 13:26:43 -060025 addr = ALIGN(gd->malloc_base + gd->malloc_ptr, align);
Philipp Rosenberger596380d2015-09-08 12:41:24 +020026 new_ptr = addr + bytes - gd->malloc_base;
Pali Roháreebcdb32022-02-03 19:51:37 +010027 log_debug("size=%lx, ptr=%lx, limit=%lx: ", (ulong)bytes, new_ptr,
Simon Glass7cbd2d22018-11-18 08:14:26 -070028 gd->malloc_limit);
Andrew F. Davis1923d542017-01-27 10:39:18 -060029 if (new_ptr > gd->malloc_limit) {
Simon Glass7cbd2d22018-11-18 08:14:26 -070030 log_err("alloc space exhausted\n");
Simon Glassb6bfb6f2015-05-12 14:55:06 -060031 return NULL;
Andrew F. Davis1923d542017-01-27 10:39:18 -060032 }
33
Simon Glassb6bfb6f2015-05-12 14:55:06 -060034 ptr = map_sysmem(addr, bytes);
35 gd->malloc_ptr = ALIGN(new_ptr, sizeof(new_ptr));
Simon Glass7cbd2d22018-11-18 08:14:26 -070036
37 return ptr;
38}
39
40void *malloc_simple(size_t bytes)
41{
42 void *ptr;
43
44 ptr = alloc_simple(bytes, 1);
45 if (!ptr)
46 return ptr;
47
48 log_debug("%lx\n", (ulong)ptr);
Sean Andersonbdaeea12022-03-23 14:04:49 -040049 VALGRIND_MALLOCLIKE_BLOCK(ptr, bytes, 0, false);
Simon Glass7cbd2d22018-11-18 08:14:26 -070050
51 return ptr;
52}
53
54void *memalign_simple(size_t align, size_t bytes)
55{
56 void *ptr;
57
58 ptr = alloc_simple(bytes, align);
59 if (!ptr)
60 return ptr;
61 log_debug("aligned to %lx\n", (ulong)ptr);
Sean Andersonbdaeea12022-03-23 14:04:49 -040062 VALGRIND_MALLOCLIKE_BLOCK(ptr, bytes, 0, false);
Simon Glass836ac742015-09-08 17:52:46 -060063
Simon Glassb6bfb6f2015-05-12 14:55:06 -060064 return ptr;
65}
66
Hans de Goede1eb0c032015-09-13 14:45:15 +020067#if CONFIG_IS_ENABLED(SYS_MALLOC_SIMPLE)
Simon Glassc9356be2014-11-10 17:16:43 -070068void *calloc(size_t nmemb, size_t elem_size)
69{
70 size_t size = nmemb * elem_size;
71 void *ptr;
72
73 ptr = malloc(size);
Simon Glass7cbd2d22018-11-18 08:14:26 -070074 if (!ptr)
75 return ptr;
76 memset(ptr, '\0', size);
Simon Glassc9356be2014-11-10 17:16:43 -070077
78 return ptr;
79}
Sean Andersonbdaeea12022-03-23 14:04:49 -040080
81#if IS_ENABLED(CONFIG_VALGRIND)
82void free_simple(void *ptr)
83{
84 VALGRIND_FREELIKE_BLOCK(ptr, 0);
85}
86#endif
Simon Glassc9356be2014-11-10 17:16:43 -070087#endif
Simon Glass7cbd2d22018-11-18 08:14:26 -070088
89void malloc_simple_info(void)
90{
91 log_info("malloc_simple: %lx bytes used, %lx remain\n", gd->malloc_ptr,
92 CONFIG_VAL(SYS_MALLOC_F_LEN) - gd->malloc_ptr);
93}