mirror of
https://github.com/microsoft/mimalloc.git
synced 2025-01-15 09:38:00 +08:00
fix std malloc compile of the stress test
This commit is contained in:
parent
54940a6a65
commit
c57e9b855c
@ -47,10 +47,6 @@ static int ITER = 50; // N full iterations destructing and re-creating a
|
|||||||
|
|
||||||
#define STRESS // undefine for leak test
|
#define STRESS // undefine for leak test
|
||||||
|
|
||||||
#ifndef NDEBUG
|
|
||||||
#define HEAP_WALK // walk the heap objects?
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static bool allow_large_objects = true; // allow very large objects? (set to `true` if SCALE>100)
|
static bool allow_large_objects = true; // allow very large objects? (set to `true` if SCALE>100)
|
||||||
static size_t use_one_size = 0; // use single object size of `N * sizeof(uintptr_t)`?
|
static size_t use_one_size = 0; // use single object size of `N * sizeof(uintptr_t)`?
|
||||||
|
|
||||||
@ -66,6 +62,9 @@ static bool main_participates = false; // main thread participates as a
|
|||||||
#define custom_calloc(n,s) mi_calloc(n,s)
|
#define custom_calloc(n,s) mi_calloc(n,s)
|
||||||
#define custom_realloc(p,s) mi_realloc(p,s)
|
#define custom_realloc(p,s) mi_realloc(p,s)
|
||||||
#define custom_free(p) mi_free(p)
|
#define custom_free(p) mi_free(p)
|
||||||
|
#ifndef NDEBUG
|
||||||
|
#define HEAP_WALK // walk the heap objects?
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// transfer pointer between threads
|
// transfer pointer between threads
|
||||||
@ -220,7 +219,7 @@ static void test_stress(void) {
|
|||||||
uintptr_t r = rand();
|
uintptr_t r = rand();
|
||||||
for (int n = 0; n < ITER; n++) {
|
for (int n = 0; n < ITER; n++) {
|
||||||
run_os_threads(THREADS, &stress);
|
run_os_threads(THREADS, &stress);
|
||||||
#ifndef NDEBUG
|
#if !defined(NDEBUG) && !defined(USE_STD_MALLOC)
|
||||||
// switch between arena and OS allocation for testing
|
// switch between arena and OS allocation for testing
|
||||||
mi_option_set_enabled(mi_option_disallow_arena_alloc, (n%2)==1);
|
mi_option_set_enabled(mi_option_disallow_arena_alloc, (n%2)==1);
|
||||||
#endif
|
#endif
|
||||||
@ -270,7 +269,7 @@ int main(int argc, char** argv) {
|
|||||||
#ifdef HEAP_WALK
|
#ifdef HEAP_WALK
|
||||||
mi_option_enable(mi_option_visit_abandoned);
|
mi_option_enable(mi_option_visit_abandoned);
|
||||||
#endif
|
#endif
|
||||||
#ifndef NDEBUG
|
#if !defined(NDEBUG) && !defined(USE_STD_MALLOC)
|
||||||
mi_option_set(mi_option_arena_reserve, 32 * 1024 /* in kib = 32MiB */);
|
mi_option_set(mi_option_arena_reserve, 32 * 1024 /* in kib = 32MiB */);
|
||||||
#endif
|
#endif
|
||||||
#ifndef USE_STD_MALLOC
|
#ifndef USE_STD_MALLOC
|
||||||
|
Loading…
x
Reference in New Issue
Block a user