Merge branch 'dev' into dev-slice
This commit is contained in:
commit
542f577c81
@ -359,7 +359,7 @@ static void mi_heap_absorb(mi_heap_t* heap, mi_heap_t* from) {
|
|||||||
// turns out to be ok as `_mi_heap_delayed_free` only visits the list and calls a
|
// turns out to be ok as `_mi_heap_delayed_free` only visits the list and calls a
|
||||||
// the regular `_mi_free_delayed_block` which is safe.
|
// the regular `_mi_free_delayed_block` which is safe.
|
||||||
_mi_heap_delayed_free(from);
|
_mi_heap_delayed_free(from);
|
||||||
mi_assert_internal(from->thread_delayed_free == NULL);
|
mi_assert_internal(mi_atomic_load_ptr_relaxed(mi_block_t,&from->thread_delayed_free) == NULL);
|
||||||
|
|
||||||
// and reset the `from` heap
|
// and reset the `from` heap
|
||||||
mi_heap_reset_pages(from);
|
mi_heap_reset_pages(from);
|
||||||
|
@ -151,7 +151,7 @@ static void mi_printf_amount(int64_t n, int64_t unit, mi_output_fun* out, void*
|
|||||||
const int64_t tens = (n / (divider/10));
|
const int64_t tens = (n / (divider/10));
|
||||||
const long whole = (long)(tens/10);
|
const long whole = (long)(tens/10);
|
||||||
const long frac1 = (long)(tens%10);
|
const long frac1 = (long)(tens%10);
|
||||||
snprintf(buf, len, "%ld.%ld %s%s", whole, frac1, magnitude, suffix);
|
snprintf(buf, len, "%ld.%ld %s%s", whole, (frac1 < 0 ? -frac1 : frac1), magnitude, suffix);
|
||||||
}
|
}
|
||||||
_mi_fprintf(out, arg, (fmt==NULL ? "%11s" : fmt), buf);
|
_mi_fprintf(out, arg, (fmt==NULL ? "%11s" : fmt), buf);
|
||||||
}
|
}
|
||||||
@ -172,6 +172,7 @@ static void mi_stat_print(const mi_stat_count_t* stat, const char* msg, int64_t
|
|||||||
mi_print_amount(stat->peak, unit, out, arg);
|
mi_print_amount(stat->peak, unit, out, arg);
|
||||||
mi_print_amount(stat->allocated, unit, out, arg);
|
mi_print_amount(stat->allocated, unit, out, arg);
|
||||||
mi_print_amount(stat->freed, unit, out, arg);
|
mi_print_amount(stat->freed, unit, out, arg);
|
||||||
|
mi_print_amount(stat->current, unit, out, arg);
|
||||||
mi_print_amount(unit, 1, out, arg);
|
mi_print_amount(unit, 1, out, arg);
|
||||||
mi_print_count(stat->allocated, unit, out, arg);
|
mi_print_count(stat->allocated, unit, out, arg);
|
||||||
if (stat->allocated > stat->freed)
|
if (stat->allocated > stat->freed)
|
||||||
@ -183,6 +184,7 @@ static void mi_stat_print(const mi_stat_count_t* stat, const char* msg, int64_t
|
|||||||
mi_print_amount(stat->peak, -1, out, arg);
|
mi_print_amount(stat->peak, -1, out, arg);
|
||||||
mi_print_amount(stat->allocated, -1, out, arg);
|
mi_print_amount(stat->allocated, -1, out, arg);
|
||||||
mi_print_amount(stat->freed, -1, out, arg);
|
mi_print_amount(stat->freed, -1, out, arg);
|
||||||
|
mi_print_amount(stat->current, -1, out, arg);
|
||||||
if (unit==-1) {
|
if (unit==-1) {
|
||||||
_mi_fprintf(out, arg, "%22s", "");
|
_mi_fprintf(out, arg, "%22s", "");
|
||||||
}
|
}
|
||||||
@ -198,6 +200,8 @@ static void mi_stat_print(const mi_stat_count_t* stat, const char* msg, int64_t
|
|||||||
else {
|
else {
|
||||||
mi_print_amount(stat->peak, 1, out, arg);
|
mi_print_amount(stat->peak, 1, out, arg);
|
||||||
mi_print_amount(stat->allocated, 1, out, arg);
|
mi_print_amount(stat->allocated, 1, out, arg);
|
||||||
|
_mi_fprintf(out, arg, "%11s", " "); // no freed
|
||||||
|
mi_print_amount(stat->current, 1, out, arg);
|
||||||
_mi_fprintf(out, arg, "\n");
|
_mi_fprintf(out, arg, "\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -217,7 +221,7 @@ static void mi_stat_counter_print_avg(const mi_stat_counter_t* stat, const char*
|
|||||||
|
|
||||||
|
|
||||||
static void mi_print_header(mi_output_fun* out, void* arg ) {
|
static void mi_print_header(mi_output_fun* out, void* arg ) {
|
||||||
_mi_fprintf(out, arg, "%10s: %10s %10s %10s %10s %10s\n", "heap stats", "peak ", "total ", "freed ", "unit ", "count ");
|
_mi_fprintf(out, arg, "%10s: %10s %10s %10s %10s %10s %10s\n", "heap stats", "peak ", "total ", "freed ", "current ", "unit ", "count ");
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MI_STAT>1
|
#if MI_STAT>1
|
||||||
|
Loading…
Reference in New Issue
Block a user