/* * Copyright (C) 2019 Intel Corporation. All rights reserved. * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception */ #include "mem_alloc.h" #if DEFAULT_MEM_ALLOCATOR == MEM_ALLOCATOR_EMS #include "ems/ems_gc.h" mem_allocator_t mem_allocator_create(void *mem, uint32_t size) { return gc_init_with_pool((char *) mem, size); } void mem_allocator_destroy(mem_allocator_t allocator) { gc_destroy_with_pool((gc_handle_t) allocator); } void * mem_allocator_malloc(mem_allocator_t allocator, uint32_t size) { return gc_alloc_vo((gc_handle_t) allocator, size); } void * mem_allocator_realloc(mem_allocator_t allocator, void *ptr, uint32_t size) { return gc_realloc_vo((gc_handle_t) allocator, ptr, size); } void mem_allocator_free(mem_allocator_t allocator, void *ptr) { if (ptr) gc_free_vo((gc_handle_t) allocator, ptr); } int mem_allocator_migrate(mem_allocator_t allocator, mem_allocator_t allocator_old) { return gc_migrate((gc_handle_t) allocator, (gc_handle_t) allocator_old); } int mem_allocator_reinit_lock(mem_allocator_t allocator) { return gc_reinit_lock((gc_handle_t) allocator); } void mem_allocator_destroy_lock(mem_allocator_t allocator) { gc_destroy_lock((gc_handle_t) allocator); } #else /* else of DEFAULT_MEM_ALLOCATOR */ #include "tlsf/tlsf.h" typedef struct mem_allocator_tlsf { tlsf_t tlsf; korp_mutex lock; }mem_allocator_tlsf; mem_allocator_t mem_allocator_create(void *mem, uint32_t size) { mem_allocator_tlsf *allocator_tlsf; tlsf_t tlsf; char *mem_aligned = (char*)(((uintptr_t)mem + 3) & ~3); if (size < 1024) { printf("Create mem allocator failed: pool size must be " "at least 1024 bytes.\n"); return NULL; } size -= mem_aligned - (char*)mem; mem = (void*)mem_aligned; tlsf = tlsf_create_with_pool(mem, size); if (!tlsf) { printf("Create mem allocator failed: tlsf_create_with_pool failed.\n"); return NULL; } allocator_tlsf = tlsf_malloc(tlsf, sizeof(mem_allocator_tlsf)); if (!allocator_tlsf) { printf("Create mem allocator failed: tlsf_malloc failed.\n"); tlsf_destroy(tlsf); return NULL; } allocator_tlsf->tlsf = tlsf; if (os_mutex_init(&allocator_tlsf->lock)) { printf("Create mem allocator failed: tlsf_malloc failed.\n"); tlsf_free(tlsf, allocator_tlsf); tlsf_destroy(tlsf); return NULL; } return allocator_tlsf; } void mem_allocator_destroy(mem_allocator_t allocator) { mem_allocator_tlsf *allocator_tlsf = (mem_allocator_tlsf *)allocator; tlsf_t tlsf = allocator_tlsf->tlsf; os_mutex_destroy(&allocator_tlsf->lock); tlsf_free(tlsf, allocator_tlsf); tlsf_destroy(tlsf); } void * mem_allocator_malloc(mem_allocator_t allocator, uint32_t size) { void *ret; mem_allocator_tlsf *allocator_tlsf = (mem_allocator_tlsf *)allocator; if (size == 0) /* tlsf doesn't allow to allocate 0 byte */ size = 1; os_mutex_lock(&allocator_tlsf->lock); ret = tlsf_malloc(allocator_tlsf->tlsf, size); os_mutex_unlock(&allocator_tlsf->lock); return ret; } void * mem_allocator_realloc(mem_allocator_t allocator, void *ptr, uint32_t size) { void *ret; mem_allocator_tlsf *allocator_tlsf = (mem_allocator_tlsf *)allocator; if (size == 0) /* tlsf doesn't allow to allocate 0 byte */ size = 1; os_mutex_lock(&allocator_tlsf->lock); ret = tlsf_realloc(allocator_tlsf->tlsf, ptr, size); os_mutex_unlock(&allocator_tlsf->lock); return ret; } void mem_allocator_free(mem_allocator_t allocator, void *ptr) { if (ptr) { mem_allocator_tlsf *allocator_tlsf = (mem_allocator_tlsf *)allocator; os_mutex_lock(&allocator_tlsf->lock); tlsf_free(allocator_tlsf->tlsf, ptr); os_mutex_unlock(&allocator_tlsf->lock); } } int mem_allocator_migrate(mem_allocator_t allocator, mem_allocator_t allocator_old) { return tlsf_migrate((mem_allocator_tlsf *) allocator, (mem_allocator_tlsf *) allocator_old); } int mem_allocator_init_lock(mem_allocator_t allocator) { mem_allocator_tlsf *allocator_tlsf = (mem_allocator_tlsf *)allocator; return os_mutex_init(&allocator_tlsf->lock); } void mem_allocator_destroy_lock(mem_allocator_t allocator) { mem_allocator_tlsf *allocator_tlsf = (mem_allocator_tlsf *)allocator; os_mutex_destroy(&allocator_tlsf->lock); } #endif /* end of DEFAULT_MEM_ALLOCATOR */