Fix use of js_malloc_usable_size

Make sure the one set in the malloc functions is used rather than the
default one, since it will likely use a different allocator.

For some reason, this didn't cause a problem on macOS, but it does in
Linux. Opsie! Added some CI to prevent these kinds of bugs.
This commit is contained in:
Saúl Ibarra Corretgé 2024-09-24 09:50:55 +02:00
parent 1defa63c73
commit c963112349
3 changed files with 48 additions and 9 deletions

View file

@ -484,3 +484,37 @@ jobs:
run: | run: |
cmake --build build --config Release --target qjs cmake --build build --config Release --target qjs
ls -lh build ls -lh build
mimalloc-linux:
runs-on: ubuntu-24.04
env:
BUILD_CLI_WITH_MIMALLOC: ON
MIMALLOC_SHOW_STATS: 1
steps:
- uses: actions/checkout@v4
- name: install dependencies
run: |
sudo apt update && sudo apt -y install libmimalloc-dev
- name: build
run: |
make
- name: test
run: |
make test
mimalloc-macos:
runs-on: macos-latest
env:
BUILD_CLI_WITH_STATIC_MIMALLOC: ON
MIMALLOC_SHOW_STATS: 1
steps:
- uses: actions/checkout@v4
- name: install dependencies
run: |
brew install mimalloc
- name: build
run: |
make
- name: test
run: |
make test

View file

@ -112,6 +112,7 @@ endif()
xoption(BUILD_EXAMPLES "Build examples" OFF) xoption(BUILD_EXAMPLES "Build examples" OFF)
xoption(BUILD_STATIC_QJS_EXE "Build a static qjs executable" OFF) xoption(BUILD_STATIC_QJS_EXE "Build a static qjs executable" OFF)
xoption(BUILD_CLI_WITH_MIMALLOC "Build the qjs executable with mimalloc" OFF) xoption(BUILD_CLI_WITH_MIMALLOC "Build the qjs executable with mimalloc" OFF)
xoption(BUILD_CLI_WITH_STATIC_MIMALLOC "Build the qjs executable with mimalloc (statically linked)" OFF)
xoption(CONFIG_ASAN "Enable AddressSanitizer (ASan)" OFF) xoption(CONFIG_ASAN "Enable AddressSanitizer (ASan)" OFF)
xoption(CONFIG_MSAN "Enable MemorySanitizer (MSan)" OFF) xoption(CONFIG_MSAN "Enable MemorySanitizer (MSan)" OFF)
xoption(CONFIG_UBSAN "Enable UndefinedBehaviorSanitizer (UBSan)" OFF) xoption(CONFIG_UBSAN "Enable UndefinedBehaviorSanitizer (UBSan)" OFF)
@ -255,10 +256,14 @@ endif()
if(NOT WIN32) if(NOT WIN32)
set_target_properties(qjs_exe PROPERTIES ENABLE_EXPORTS TRUE) set_target_properties(qjs_exe PROPERTIES ENABLE_EXPORTS TRUE)
endif() endif()
if(BUILD_CLI_WITH_MIMALLOC) if(BUILD_CLI_WITH_MIMALLOC OR BUILD_CLI_WITH_STATIC_MIMALLOC)
find_package(mimalloc REQUIRED) find_package(mimalloc REQUIRED)
target_compile_definitions(qjs_exe PRIVATE QJS_USE_MIMALLOC) # Upstream mimalloc doesn't provide a way to know if both libraries are supported.
if(BUILD_CLI_WITH_STATIC_MIMALLOC)
target_link_libraries(qjs_exe mimalloc-static) target_link_libraries(qjs_exe mimalloc-static)
else()
target_link_libraries(qjs_exe mimalloc)
endif()
endif() endif()
# Test262 runner # Test262 runner

View file

@ -1409,7 +1409,7 @@ void *js_calloc_rt(JSRuntime *rt, size_t count, size_t size)
return NULL; return NULL;
s->malloc_count++; s->malloc_count++;
s->malloc_size += js__malloc_usable_size(ptr) + MALLOC_OVERHEAD; s->malloc_size += rt->mf.js_malloc_usable_size(ptr) + MALLOC_OVERHEAD;
return ptr; return ptr;
} }
@ -1431,7 +1431,7 @@ void *js_malloc_rt(JSRuntime *rt, size_t size)
return NULL; return NULL;
s->malloc_count++; s->malloc_count++;
s->malloc_size += js__malloc_usable_size(ptr) + MALLOC_OVERHEAD; s->malloc_size += rt->mf.js_malloc_usable_size(ptr) + MALLOC_OVERHEAD;
return ptr; return ptr;
} }
@ -1444,7 +1444,7 @@ void js_free_rt(JSRuntime *rt, void *ptr)
s = &rt->malloc_state; s = &rt->malloc_state;
s->malloc_count--; s->malloc_count--;
s->malloc_size -= js__malloc_usable_size(ptr) + MALLOC_OVERHEAD; s->malloc_size -= rt->mf.js_malloc_usable_size(ptr) + MALLOC_OVERHEAD;
rt->mf.js_free(s->opaque, ptr); rt->mf.js_free(s->opaque, ptr);
} }
@ -1462,7 +1462,7 @@ void *js_realloc_rt(JSRuntime *rt, void *ptr, size_t size)
js_free_rt(rt, ptr); js_free_rt(rt, ptr);
return NULL; return NULL;
} }
old_size = js__malloc_usable_size(ptr); old_size = rt->mf.js_malloc_usable_size(ptr);
s = &rt->malloc_state; s = &rt->malloc_state;
/* When malloc_limit is 0 (unlimited), malloc_limit - 1 will be SIZE_MAX. */ /* When malloc_limit is 0 (unlimited), malloc_limit - 1 will be SIZE_MAX. */
if (s->malloc_size + size - old_size > s->malloc_limit - 1) if (s->malloc_size + size - old_size > s->malloc_limit - 1)
@ -1472,7 +1472,7 @@ void *js_realloc_rt(JSRuntime *rt, void *ptr, size_t size)
if (!ptr) if (!ptr)
return NULL; return NULL;
s->malloc_size += js__malloc_usable_size(ptr) - old_size; s->malloc_size += rt->mf.js_malloc_usable_size(ptr) - old_size;
return ptr; return ptr;
} }
@ -1734,7 +1734,7 @@ JSRuntime *JS_NewRuntime2(const JSMallocFunctions *mf, void *opaque)
return NULL; return NULL;
/* Inline what js_malloc_rt does since we cannot use it here. */ /* Inline what js_malloc_rt does since we cannot use it here. */
ms.malloc_count++; ms.malloc_count++;
ms.malloc_size += js__malloc_usable_size(rt) + MALLOC_OVERHEAD; ms.malloc_size += mf->js_malloc_usable_size(rt) + MALLOC_OVERHEAD;
rt->mf = *mf; rt->mf = *mf;
if (!rt->mf.js_malloc_usable_size) { if (!rt->mf.js_malloc_usable_size) {
/* use dummy function if none provided */ /* use dummy function if none provided */