Add JEMALLOC_COLD, and mark some functions cold.
This hints to the compiler that it should care more about space than CPU (among other things). In cases where the compiler lacks profile-guided information, this can be a substantial space savings. For now, we mark the mallctl or atexit driven profiling and stats functions that take up the most space.
This commit is contained in:
committed by
David Goldblatt
parent
5d8e70ab26
commit
a9fa2defdb
@@ -321,6 +321,7 @@ x2s(uintmax_t x, bool alt_form, bool uppercase, char *s, size_t *slen_p) {
|
||||
return s;
|
||||
}
|
||||
|
||||
JEMALLOC_COLD
|
||||
size_t
|
||||
malloc_vsnprintf(char *str, size_t size, const char *format, va_list ap) {
|
||||
size_t i;
|
||||
|
@@ -200,6 +200,7 @@ prof_log_thr_index(tsd_t *tsd, uint64_t thr_uid, const char *name) {
|
||||
}
|
||||
}
|
||||
|
||||
JEMALLOC_COLD
|
||||
void
|
||||
prof_try_log(tsd_t *tsd, size_t usize, prof_info_t *prof_info) {
|
||||
cassert(config_prof);
|
||||
@@ -411,6 +412,7 @@ prof_log_dummy_set(bool new_value) {
|
||||
prof_log_dummy = new_value;
|
||||
}
|
||||
|
||||
JEMALLOC_COLD
|
||||
bool
|
||||
prof_log_start(tsdn_t *tsdn, const char *filename) {
|
||||
cassert(config_prof);
|
||||
@@ -593,6 +595,7 @@ prof_log_emit_metadata(emitter_t *emitter) {
|
||||
}
|
||||
|
||||
#define PROF_LOG_STOP_BUFSIZE PROF_DUMP_BUFSIZE
|
||||
JEMALLOC_COLD
|
||||
bool
|
||||
prof_log_stop(tsdn_t *tsdn) {
|
||||
cassert(config_prof);
|
||||
@@ -681,7 +684,9 @@ prof_log_stop(tsdn_t *tsdn) {
|
||||
}
|
||||
#undef PROF_LOG_STOP_BUFSIZE
|
||||
|
||||
bool prof_log_init(tsd_t *tsd) {
|
||||
JEMALLOC_COLD
|
||||
bool
|
||||
prof_log_init(tsd_t *tsd) {
|
||||
cassert(config_prof);
|
||||
if (malloc_mutex_init(&log_mtx, "prof_log",
|
||||
WITNESS_RANK_PROF_LOG, malloc_mutex_rank_exclusive)) {
|
||||
|
@@ -528,6 +528,7 @@ prof_recent_alloc_dump_node(emitter_t *emitter, prof_recent_t *node) {
|
||||
}
|
||||
|
||||
#define PROF_RECENT_PRINT_BUFSIZE 65536
|
||||
JEMALLOC_COLD
|
||||
void
|
||||
prof_recent_alloc_dump(tsd_t *tsd, write_cb_t *write_cb, void *cbopaque) {
|
||||
cassert(config_prof);
|
||||
|
@@ -281,6 +281,7 @@ mutex_stats_emit(emitter_t *emitter, emitter_row_t *row,
|
||||
header_##column_name.str_val = human ? human : #column_name;
|
||||
|
||||
|
||||
JEMALLOC_COLD
|
||||
static void
|
||||
stats_arena_bins_print(emitter_t *emitter, bool mutex, unsigned i, uint64_t uptime) {
|
||||
size_t page;
|
||||
@@ -488,6 +489,7 @@ stats_arena_bins_print(emitter_t *emitter, bool mutex, unsigned i, uint64_t upti
|
||||
}
|
||||
}
|
||||
|
||||
JEMALLOC_COLD
|
||||
static void
|
||||
stats_arena_lextents_print(emitter_t *emitter, unsigned i, uint64_t uptime) {
|
||||
unsigned nbins, nlextents, j;
|
||||
@@ -576,6 +578,7 @@ stats_arena_lextents_print(emitter_t *emitter, unsigned i, uint64_t uptime) {
|
||||
}
|
||||
}
|
||||
|
||||
JEMALLOC_COLD
|
||||
static void
|
||||
stats_arena_extents_print(emitter_t *emitter, unsigned i) {
|
||||
unsigned j;
|
||||
@@ -841,6 +844,7 @@ stats_arena_mutexes_print(emitter_t *emitter, unsigned arena_ind, uint64_t uptim
|
||||
emitter_json_object_end(emitter); /* End "mutexes". */
|
||||
}
|
||||
|
||||
JEMALLOC_COLD
|
||||
static void
|
||||
stats_arena_print(emitter_t *emitter, unsigned i, bool bins, bool large,
|
||||
bool mutex, bool extents, bool hpa) {
|
||||
@@ -1168,6 +1172,7 @@ stats_arena_print(emitter_t *emitter, unsigned i, bool bins, bool large,
|
||||
}
|
||||
}
|
||||
|
||||
JEMALLOC_COLD
|
||||
static void
|
||||
stats_general_print(emitter_t *emitter) {
|
||||
const char *cpv;
|
||||
@@ -1445,6 +1450,7 @@ stats_general_print(emitter_t *emitter) {
|
||||
emitter_json_object_end(emitter); /* Close "arenas" */
|
||||
}
|
||||
|
||||
JEMALLOC_COLD
|
||||
static void
|
||||
stats_print_helper(emitter_t *emitter, bool merged, bool destroyed,
|
||||
bool unmerged, bool bins, bool large, bool mutex, bool extents, bool hpa) {
|
||||
|
Reference in New Issue
Block a user