2019-05-07 02:18:18 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2019 Intel Corporation. All rights reserved.
|
2019-11-11 23:45:21 +00:00
|
|
|
* SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2019-05-07 02:18:18 +00:00
|
|
|
*/
|
|
|
|
|
2020-03-10 11:54:44 +00:00
|
|
|
#include "wasm_runtime_common.h"
|
2019-08-28 07:08:52 +00:00
|
|
|
#include "bh_platform.h"
|
2019-05-07 02:18:18 +00:00
|
|
|
#include "mem_alloc.h"
|
|
|
|
|
|
|
|
typedef enum Memory_Mode {
|
2019-05-31 06:21:39 +00:00
|
|
|
MEMORY_MODE_UNKNOWN = 0,
|
|
|
|
MEMORY_MODE_POOL,
|
|
|
|
MEMORY_MODE_ALLOCATOR
|
2019-05-07 02:18:18 +00:00
|
|
|
} Memory_Mode;
|
|
|
|
|
|
|
|
static Memory_Mode memory_mode = MEMORY_MODE_UNKNOWN;
|
|
|
|
|
|
|
|
static mem_allocator_t pool_allocator = NULL;
|
|
|
|
|
|
|
|
static void *(*malloc_func)(unsigned int size) = NULL;
|
2020-03-08 13:18:18 +00:00
|
|
|
static void *(*realloc_func)(void *ptr, unsigned int size) = NULL;
|
2019-05-07 02:18:18 +00:00
|
|
|
static void (*free_func)(void *ptr) = NULL;
|
|
|
|
|
2019-05-31 06:21:39 +00:00
|
|
|
static unsigned int global_pool_size;
|
|
|
|
|
2020-03-10 11:54:44 +00:00
|
|
|
static bool
|
|
|
|
wasm_memory_init_with_pool(void *mem, unsigned int bytes)
|
2019-05-07 02:18:18 +00:00
|
|
|
{
|
|
|
|
mem_allocator_t _allocator = mem_allocator_create(mem, bytes);
|
|
|
|
|
|
|
|
if (_allocator) {
|
|
|
|
memory_mode = MEMORY_MODE_POOL;
|
|
|
|
pool_allocator = _allocator;
|
2019-05-31 06:21:39 +00:00
|
|
|
global_pool_size = bytes;
|
2020-03-10 11:54:44 +00:00
|
|
|
return true;
|
2019-05-07 02:18:18 +00:00
|
|
|
}
|
2020-03-16 08:43:57 +00:00
|
|
|
LOG_ERROR("Init memory with pool (%p, %u) failed.\n", mem, bytes);
|
2020-03-10 11:54:44 +00:00
|
|
|
return false;
|
2019-05-07 02:18:18 +00:00
|
|
|
}
|
|
|
|
|
2020-03-10 11:54:44 +00:00
|
|
|
static bool
|
2021-10-08 09:47:11 +00:00
|
|
|
wasm_memory_init_with_allocator(void *_malloc_func, void *_realloc_func,
|
2020-03-10 11:54:44 +00:00
|
|
|
void *_free_func)
|
2019-05-07 02:18:18 +00:00
|
|
|
{
|
|
|
|
if (_malloc_func && _free_func && _malloc_func != _free_func) {
|
|
|
|
memory_mode = MEMORY_MODE_ALLOCATOR;
|
|
|
|
malloc_func = _malloc_func;
|
2020-03-08 13:18:18 +00:00
|
|
|
realloc_func = _realloc_func;
|
2019-05-07 02:18:18 +00:00
|
|
|
free_func = _free_func;
|
2020-03-10 11:54:44 +00:00
|
|
|
return true;
|
2019-05-07 02:18:18 +00:00
|
|
|
}
|
2021-10-08 09:47:11 +00:00
|
|
|
LOG_ERROR("Init memory with allocator (%p, %p, %p) failed.\n", _malloc_func,
|
|
|
|
_realloc_func, _free_func);
|
2020-03-10 11:54:44 +00:00
|
|
|
return false;
|
2019-05-07 02:18:18 +00:00
|
|
|
}
|
|
|
|
|
2020-03-10 11:54:44 +00:00
|
|
|
bool
|
|
|
|
wasm_runtime_memory_init(mem_alloc_type_t mem_alloc_type,
|
|
|
|
const MemAllocOption *alloc_option)
|
2020-03-08 13:18:18 +00:00
|
|
|
{
|
2020-03-10 11:54:44 +00:00
|
|
|
if (mem_alloc_type == Alloc_With_Pool)
|
|
|
|
return wasm_memory_init_with_pool(alloc_option->pool.heap_buf,
|
|
|
|
alloc_option->pool.heap_size);
|
|
|
|
else if (mem_alloc_type == Alloc_With_Allocator)
|
2021-10-08 09:47:11 +00:00
|
|
|
return wasm_memory_init_with_allocator(
|
|
|
|
alloc_option->allocator.malloc_func,
|
|
|
|
alloc_option->allocator.realloc_func,
|
|
|
|
alloc_option->allocator.free_func);
|
2020-03-10 11:54:44 +00:00
|
|
|
else if (mem_alloc_type == Alloc_With_System_Allocator)
|
|
|
|
return wasm_memory_init_with_allocator(os_malloc, os_realloc, os_free);
|
|
|
|
else
|
|
|
|
return false;
|
2020-03-08 13:18:18 +00:00
|
|
|
}
|
|
|
|
|
2020-03-10 11:54:44 +00:00
|
|
|
void
|
|
|
|
wasm_runtime_memory_destroy()
|
2019-05-07 02:18:18 +00:00
|
|
|
{
|
|
|
|
if (memory_mode == MEMORY_MODE_POOL)
|
|
|
|
mem_allocator_destroy(pool_allocator);
|
|
|
|
memory_mode = MEMORY_MODE_UNKNOWN;
|
|
|
|
}
|
|
|
|
|
2020-03-10 11:54:44 +00:00
|
|
|
unsigned
|
|
|
|
wasm_runtime_memory_pool_size()
|
2019-05-31 06:21:39 +00:00
|
|
|
{
|
|
|
|
if (memory_mode == MEMORY_MODE_POOL)
|
|
|
|
return global_pool_size;
|
|
|
|
else
|
|
|
|
return 1 * BH_GB;
|
|
|
|
}
|
|
|
|
|
2020-09-18 10:04:56 +00:00
|
|
|
static inline void *
|
|
|
|
wasm_runtime_malloc_internal(unsigned int size)
|
2019-05-07 02:18:18 +00:00
|
|
|
{
|
|
|
|
if (memory_mode == MEMORY_MODE_UNKNOWN) {
|
2021-10-08 09:47:11 +00:00
|
|
|
LOG_WARNING(
|
|
|
|
"wasm_runtime_malloc failed: memory hasn't been initialize.\n");
|
2019-05-07 02:18:18 +00:00
|
|
|
return NULL;
|
2020-09-18 10:04:56 +00:00
|
|
|
}
|
|
|
|
else if (memory_mode == MEMORY_MODE_POOL) {
|
2019-05-07 02:18:18 +00:00
|
|
|
return mem_allocator_malloc(pool_allocator, size);
|
2020-09-18 10:04:56 +00:00
|
|
|
}
|
|
|
|
else {
|
2019-05-07 02:18:18 +00:00
|
|
|
return malloc_func(size);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-18 10:04:56 +00:00
|
|
|
static inline void *
|
|
|
|
wasm_runtime_realloc_internal(void *ptr, unsigned int size)
|
2020-03-08 13:18:18 +00:00
|
|
|
{
|
|
|
|
if (memory_mode == MEMORY_MODE_UNKNOWN) {
|
2021-10-08 09:47:11 +00:00
|
|
|
LOG_WARNING(
|
|
|
|
"wasm_runtime_realloc failed: memory hasn't been initialize.\n");
|
2020-03-08 13:18:18 +00:00
|
|
|
return NULL;
|
2020-09-18 10:04:56 +00:00
|
|
|
}
|
|
|
|
else if (memory_mode == MEMORY_MODE_POOL) {
|
2020-03-08 13:18:18 +00:00
|
|
|
return mem_allocator_realloc(pool_allocator, ptr, size);
|
2020-09-18 10:04:56 +00:00
|
|
|
}
|
|
|
|
else {
|
2020-03-08 13:18:18 +00:00
|
|
|
if (realloc_func)
|
|
|
|
return realloc_func(ptr, size);
|
|
|
|
else
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-18 10:04:56 +00:00
|
|
|
static inline void
|
|
|
|
wasm_runtime_free_internal(void *ptr)
|
2019-05-07 02:18:18 +00:00
|
|
|
{
|
2021-01-28 08:16:02 +00:00
|
|
|
if (!ptr) {
|
|
|
|
LOG_WARNING("warning: wasm_runtime_free with NULL pointer\n");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-05-07 02:18:18 +00:00
|
|
|
if (memory_mode == MEMORY_MODE_UNKNOWN) {
|
2021-01-28 08:16:02 +00:00
|
|
|
LOG_WARNING("warning: wasm_runtime_free failed: "
|
|
|
|
"memory hasn't been initialize.\n");
|
2020-09-18 10:04:56 +00:00
|
|
|
}
|
|
|
|
else if (memory_mode == MEMORY_MODE_POOL) {
|
2019-05-07 02:18:18 +00:00
|
|
|
mem_allocator_free(pool_allocator, ptr);
|
2020-09-18 10:04:56 +00:00
|
|
|
}
|
|
|
|
else {
|
2019-05-07 02:18:18 +00:00
|
|
|
free_func(ptr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-18 10:04:56 +00:00
|
|
|
void *
|
|
|
|
wasm_runtime_malloc(unsigned int size)
|
|
|
|
{
|
2021-01-28 08:16:02 +00:00
|
|
|
if (size == 0) {
|
|
|
|
LOG_WARNING("warning: wasm_runtime_malloc with size zero\n");
|
|
|
|
/* At lease alloc 1 byte to avoid malloc failed */
|
|
|
|
size = 1;
|
|
|
|
}
|
|
|
|
|
2020-09-18 10:04:56 +00:00
|
|
|
return wasm_runtime_malloc_internal(size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void *
|
|
|
|
wasm_runtime_realloc(void *ptr, unsigned int size)
|
|
|
|
{
|
|
|
|
return wasm_runtime_realloc_internal(ptr, size);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
wasm_runtime_free(void *ptr)
|
|
|
|
{
|
|
|
|
wasm_runtime_free_internal(ptr);
|
|
|
|
}
|