mirror of
https://github.com/microsoft/mimalloc.git
synced 2025-01-14 00:27:59 +08:00
merge from dev
This commit is contained in:
commit
b0ba746307
@ -104,12 +104,13 @@ void _mi_prim_thread_associate_default_heap(mi_heap_t* heap);
|
|||||||
|
|
||||||
|
|
||||||
//-------------------------------------------------------------------
|
//-------------------------------------------------------------------
|
||||||
// Thread id
|
// Thread id: `_mi_prim_thread_id()`
|
||||||
//
|
//
|
||||||
// Getting the thread id should be performant as it is called in the
|
// Getting the thread id should be performant as it is called in the
|
||||||
// fast path of `_mi_free` and we specialize for various platforms as
|
// fast path of `_mi_free` and we specialize for various platforms as
|
||||||
// inlined definitions. Regular code should call `init.c:_mi_thread_id()`.
|
// inlined definitions. Regular code should call `init.c:_mi_thread_id()`.
|
||||||
// We only require _mi_prim_thread_id() to return a unique id for each thread.
|
// We only require _mi_prim_thread_id() to return a unique id
|
||||||
|
// for each thread (unequal to zero).
|
||||||
//-------------------------------------------------------------------
|
//-------------------------------------------------------------------
|
||||||
|
|
||||||
static inline mi_threadid_t _mi_prim_thread_id(void) mi_attr_noexcept;
|
static inline mi_threadid_t _mi_prim_thread_id(void) mi_attr_noexcept;
|
||||||
|
15
src/init.c
15
src/init.c
@ -409,15 +409,24 @@ void mi_thread_done(void) mi_attr_noexcept {
|
|||||||
_mi_thread_done(NULL);
|
_mi_thread_done(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
void _mi_thread_done(mi_heap_t* heap)
|
void _mi_thread_done(mi_heap_t* heap)
|
||||||
{
|
{
|
||||||
mi_atomic_decrement_relaxed(&thread_count);
|
// calling with NULL implies using the default heap
|
||||||
_mi_stat_decrease(&_mi_stats_main.threads, 1);
|
|
||||||
|
|
||||||
if (heap == NULL) {
|
if (heap == NULL) {
|
||||||
heap = mi_prim_get_default_heap();
|
heap = mi_prim_get_default_heap();
|
||||||
if (heap == NULL) return;
|
if (heap == NULL) return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// prevent re-entrancy through heap_done/heap_set_default_direct (issue #699)
|
||||||
|
if (!mi_heap_is_initialized(heap)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// adjust stats
|
||||||
|
mi_atomic_decrement_relaxed(&thread_count);
|
||||||
|
_mi_stat_decrease(&_mi_stats_main.threads, 1);
|
||||||
|
|
||||||
// check thread-id as on Windows shutdown with FLS the main (exit) thread may call this on thread-local heaps...
|
// check thread-id as on Windows shutdown with FLS the main (exit) thread may call this on thread-local heaps...
|
||||||
if (heap->thread_id != _mi_thread_id()) return;
|
if (heap->thread_id != _mi_thread_id()) return;
|
||||||
|
@ -629,8 +629,8 @@ bool _mi_prim_getenv(const char* name, char* result, size_t result_size) {
|
|||||||
if (len == 0) return false;
|
if (len == 0) return false;
|
||||||
char** env = mi_get_environ();
|
char** env = mi_get_environ();
|
||||||
if (env == NULL) return false;
|
if (env == NULL) return false;
|
||||||
// compare up to 256 entries
|
// compare up to 64K entries
|
||||||
for (int i = 0; i < 256 && env[i] != NULL; i++) {
|
for (int i = 0; i < 64*MI_KiB && env[i] != NULL; i++) {
|
||||||
const char* s = env[i];
|
const char* s = env[i];
|
||||||
if (_mi_strnicmp(name, s, len) == 0 && s[len] == '=') { // case insensitive
|
if (_mi_strnicmp(name, s, len) == 0 && s[len] == '=') { // case insensitive
|
||||||
// found it
|
// found it
|
||||||
|
@ -39,12 +39,16 @@ static void strdup_test(); // issue #445
|
|||||||
static void bench_alloc_large(void); // issue #xxx
|
static void bench_alloc_large(void); // issue #xxx
|
||||||
static void test_large_migrate(void); // issue #691
|
static void test_large_migrate(void); // issue #691
|
||||||
static void heap_thread_free_huge();
|
static void heap_thread_free_huge();
|
||||||
|
static void test_std_string(); // issue #697
|
||||||
|
|
||||||
static void test_stl_allocators();
|
static void test_stl_allocators();
|
||||||
|
|
||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
mi_stats_reset(); // ignore earlier allocations
|
mi_stats_reset(); // ignore earlier allocations
|
||||||
|
|
||||||
|
// test_std_string();
|
||||||
|
// heap_thread_free_huge();
|
||||||
/*
|
/*
|
||||||
heap_thread_free_huge();
|
heap_thread_free_huge();
|
||||||
heap_thread_free_large();
|
heap_thread_free_large();
|
||||||
@ -237,6 +241,13 @@ static void heap_no_delete() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Issue #697
|
||||||
|
static void test_std_string() {
|
||||||
|
std::string path = "/Users/xxxx/Library/Developer/Xcode/DerivedData/xxxxxxxxxx/Build/Intermediates.noindex/xxxxxxxxxxx/arm64/XX_lto.o/0.arm64.lto.o";
|
||||||
|
std::string path1 = "/Users/xxxx/Library/Developer/Xcode/DerivedData/xxxxxxxxxx/Build/Intermediates.noindex/xxxxxxxxxxx/arm64/XX_lto.o/1.arm64.lto.o";
|
||||||
|
std::cout << path + "\n>>> " + path1 + "\n>>> " << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
// Issue #204
|
// Issue #204
|
||||||
static volatile void* global_p;
|
static volatile void* global_p;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user