Stats printing: move stats_print_helper to use emitter.

This commit is contained in:
David Goldblatt 2018-03-05 12:58:24 -08:00 committed by David Goldblatt
parent 86c61d4a57
commit cbde666d9a

View File

@ -481,6 +481,10 @@ stats_arena_print(void (*write_cb)(void *, const char *), void *cbopaque,
size_t tcache_bytes; size_t tcache_bytes;
uint64_t uptime; uint64_t uptime;
if (json) {
malloc_cprintf(write_cb, cbopaque, "\n");
}
CTL_GET("arenas.page", &page, size_t); CTL_GET("arenas.page", &page, size_t);
CTL_M2_GET("stats.arenas.0.nthreads", i, &nthreads, unsigned); CTL_M2_GET("stats.arenas.0.nthreads", i, &nthreads, unsigned);
@ -1077,122 +1081,77 @@ stats_print_helper(emitter_t *emitter, bool merged, bool destroyed,
emitter_json_dict_end(emitter); /* Close "stats". */ emitter_json_dict_end(emitter); /* Close "stats". */
if (json) {
if (merged || unmerged || destroyed) {
malloc_cprintf(write_cb, cbopaque, ",\n");
} else {
malloc_cprintf(write_cb, cbopaque, "\n");
}
}
if (merged || destroyed || unmerged) { if (merged || destroyed || unmerged) {
unsigned narenas; unsigned narenas;
if (json) { emitter_json_dict_begin(emitter, "stats.arenas");
malloc_cprintf(write_cb, cbopaque,
"\t\t\"stats.arenas\": {\n");
}
CTL_GET("arenas.narenas", &narenas, unsigned); CTL_GET("arenas.narenas", &narenas, unsigned);
{ size_t mib[3];
size_t mib[3]; size_t miblen = sizeof(mib) / sizeof(size_t);
size_t miblen = sizeof(mib) / sizeof(size_t); size_t sz;
size_t sz; VARIABLE_ARRAY(bool, initialized, narenas);
VARIABLE_ARRAY(bool, initialized, narenas); bool destroyed_initialized;
bool destroyed_initialized; unsigned i, j, ninitialized;
unsigned i, j, ninitialized;
xmallctlnametomib("arena.0.initialized", mib, &miblen); xmallctlnametomib("arena.0.initialized", mib, &miblen);
for (i = ninitialized = 0; i < narenas; i++) { for (i = ninitialized = 0; i < narenas; i++) {
mib[1] = i; mib[1] = i;
sz = sizeof(bool);
xmallctlbymib(mib, miblen, &initialized[i], &sz,
NULL, 0);
if (initialized[i]) {
ninitialized++;
}
}
mib[1] = MALLCTL_ARENAS_DESTROYED;
sz = sizeof(bool); sz = sizeof(bool);
xmallctlbymib(mib, miblen, &destroyed_initialized, &sz, xmallctlbymib(mib, miblen, &initialized[i], &sz,
NULL, 0); NULL, 0);
if (initialized[i]) {
/* Merged stats. */ ninitialized++;
if (merged && (ninitialized > 1 || !unmerged)) {
/* Print merged arena stats. */
if (json) {
malloc_cprintf(write_cb, cbopaque,
"\t\t\t\"merged\": {\n");
} else {
malloc_cprintf(write_cb, cbopaque,
"\nMerged arenas stats:\n");
}
stats_arena_print(write_cb, cbopaque, json,
MALLCTL_ARENAS_ALL, bins, large, mutex);
if (json) {
malloc_cprintf(write_cb, cbopaque,
"\t\t\t}%s\n",
((destroyed_initialized &&
destroyed) || unmerged) ? "," :
"");
}
} }
}
mib[1] = MALLCTL_ARENAS_DESTROYED;
sz = sizeof(bool);
xmallctlbymib(mib, miblen, &destroyed_initialized, &sz,
NULL, 0);
/* Destroyed stats. */ /* Merged stats. */
if (destroyed_initialized && destroyed) { if (merged && (ninitialized > 1 || !unmerged)) {
/* Print destroyed arena stats. */ /* Print merged arena stats. */
if (json) { emitter_table_printf(emitter, "Merged arenas stats:\n");
malloc_cprintf(write_cb, cbopaque, emitter_json_dict_begin(emitter, "merged");
"\t\t\t\"destroyed\": {\n"); stats_arena_print(write_cb, cbopaque, json,
} else { MALLCTL_ARENAS_ALL, bins, large, mutex);
malloc_cprintf(write_cb, cbopaque, emitter_json_dict_end(emitter); /* Close "merged". */
"\nDestroyed arenas stats:\n"); }
}
stats_arena_print(write_cb, cbopaque, json,
MALLCTL_ARENAS_DESTROYED, bins, large,
mutex);
if (json) {
malloc_cprintf(write_cb, cbopaque,
"\t\t\t}%s\n", unmerged ? "," :
"");
}
}
/* Unmerged stats. */ /* Destroyed stats. */
if (unmerged) { if (destroyed_initialized && destroyed) {
for (i = j = 0; i < narenas; i++) { /* Print destroyed arena stats. */
if (initialized[i]) { emitter_table_printf(emitter,
if (json) { "Destroyed arenas stats:\n");
j++; emitter_json_dict_begin(emitter, "destroyed");
malloc_cprintf(write_cb, stats_arena_print(write_cb, cbopaque, json,
cbopaque, MALLCTL_ARENAS_DESTROYED, bins, large,
"\t\t\t\"%u\": {\n", mutex);
i); emitter_json_dict_end(emitter); /* Close "destroyed". */
} else { }
malloc_cprintf(write_cb,
cbopaque, /* Unmerged stats. */
"\narenas[%u]:\n", if (unmerged) {
i); for (i = j = 0; i < narenas; i++) {
} if (initialized[i]) {
stats_arena_print(write_cb, char arena_ind_str[20];
cbopaque, json, i, bins, malloc_snprintf(arena_ind_str,
large, mutex); sizeof(arena_ind_str), "%u", i);
if (json) { emitter_json_dict_begin(emitter,
malloc_cprintf(write_cb, arena_ind_str);
cbopaque, emitter_table_printf(emitter,
"\t\t\t}%s\n", (j < "arenas[%s]:\n", arena_ind_str);
ninitialized) ? "," stats_arena_print(write_cb,
: ""); cbopaque, json, i, bins,
} large, mutex);
} /* Close "<arena-ind>". */
emitter_json_dict_end(emitter);
} }
} }
} }
if (json) { emitter_json_dict_end(emitter); /* Close "stats.arenas". */
malloc_cprintf(write_cb, cbopaque,
"\t\t}\n");
}
} }
} }