HPA: make the hugification threshold configurable.
This commit is contained in:
parent
b3df80bc79
commit
4790db15ed
@ -15,11 +15,18 @@ struct hpa_shard_opts_s {
|
|||||||
* any allocation request.
|
* any allocation request.
|
||||||
*/
|
*/
|
||||||
size_t slab_max_alloc;
|
size_t slab_max_alloc;
|
||||||
|
/*
|
||||||
|
* When the number of active bytes in a hugepage is >=
|
||||||
|
* hugification_threshold, we force hugify it.
|
||||||
|
*/
|
||||||
|
size_t hugification_threshold;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define HPA_SHARD_OPTS_DEFAULT { \
|
#define HPA_SHARD_OPTS_DEFAULT { \
|
||||||
/* slab_max_alloc */ \
|
/* slab_max_alloc */ \
|
||||||
64 * 1024 \
|
64 * 1024, \
|
||||||
|
/* hugification_threshold */ \
|
||||||
|
HUGEPAGE * 95 / 100, \
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* JEMALLOC_INTERNAL_HPA_OPTS_H */
|
#endif /* JEMALLOC_INTERNAL_HPA_OPTS_H */
|
||||||
|
@ -94,6 +94,7 @@ CTL_PROTO(opt_trust_madvise)
|
|||||||
CTL_PROTO(opt_confirm_conf)
|
CTL_PROTO(opt_confirm_conf)
|
||||||
CTL_PROTO(opt_hpa)
|
CTL_PROTO(opt_hpa)
|
||||||
CTL_PROTO(opt_hpa_slab_max_alloc)
|
CTL_PROTO(opt_hpa_slab_max_alloc)
|
||||||
|
CTL_PROTO(opt_hpa_hugification_threshold)
|
||||||
CTL_PROTO(opt_hpa_sec_max_alloc)
|
CTL_PROTO(opt_hpa_sec_max_alloc)
|
||||||
CTL_PROTO(opt_hpa_sec_max_bytes)
|
CTL_PROTO(opt_hpa_sec_max_bytes)
|
||||||
CTL_PROTO(opt_hpa_sec_nshards)
|
CTL_PROTO(opt_hpa_sec_nshards)
|
||||||
@ -396,6 +397,8 @@ static const ctl_named_node_t opt_node[] = {
|
|||||||
{NAME("confirm_conf"), CTL(opt_confirm_conf)},
|
{NAME("confirm_conf"), CTL(opt_confirm_conf)},
|
||||||
{NAME("hpa"), CTL(opt_hpa)},
|
{NAME("hpa"), CTL(opt_hpa)},
|
||||||
{NAME("hpa_slab_max_alloc"), CTL(opt_hpa_slab_max_alloc)},
|
{NAME("hpa_slab_max_alloc"), CTL(opt_hpa_slab_max_alloc)},
|
||||||
|
{NAME("hpa_hugification_threshold"),
|
||||||
|
CTL(opt_hpa_hugification_threshold)},
|
||||||
{NAME("hpa_sec_max_alloc"), CTL(opt_hpa_sec_max_alloc)},
|
{NAME("hpa_sec_max_alloc"), CTL(opt_hpa_sec_max_alloc)},
|
||||||
{NAME("hpa_sec_max_bytes"), CTL(opt_hpa_sec_max_bytes)},
|
{NAME("hpa_sec_max_bytes"), CTL(opt_hpa_sec_max_bytes)},
|
||||||
{NAME("hpa_sec_nshards"), CTL(opt_hpa_sec_nshards)},
|
{NAME("hpa_sec_nshards"), CTL(opt_hpa_sec_nshards)},
|
||||||
@ -2091,6 +2094,8 @@ CTL_RO_NL_GEN(opt_trust_madvise, opt_trust_madvise, bool)
|
|||||||
CTL_RO_NL_GEN(opt_confirm_conf, opt_confirm_conf, bool)
|
CTL_RO_NL_GEN(opt_confirm_conf, opt_confirm_conf, bool)
|
||||||
CTL_RO_NL_GEN(opt_hpa, opt_hpa, bool)
|
CTL_RO_NL_GEN(opt_hpa, opt_hpa, bool)
|
||||||
CTL_RO_NL_GEN(opt_hpa_slab_max_alloc, opt_hpa_opts.slab_max_alloc, size_t)
|
CTL_RO_NL_GEN(opt_hpa_slab_max_alloc, opt_hpa_opts.slab_max_alloc, size_t)
|
||||||
|
CTL_RO_NL_GEN(opt_hpa_hugification_threshold,
|
||||||
|
opt_hpa_opts.hugification_threshold, size_t)
|
||||||
CTL_RO_NL_GEN(opt_hpa_sec_max_alloc, opt_hpa_sec_max_alloc, size_t)
|
CTL_RO_NL_GEN(opt_hpa_sec_max_alloc, opt_hpa_sec_max_alloc, size_t)
|
||||||
CTL_RO_NL_GEN(opt_hpa_sec_max_bytes, opt_hpa_sec_max_bytes, size_t)
|
CTL_RO_NL_GEN(opt_hpa_sec_max_bytes, opt_hpa_sec_max_bytes, size_t)
|
||||||
CTL_RO_NL_GEN(opt_hpa_sec_nshards, opt_hpa_sec_nshards, size_t)
|
CTL_RO_NL_GEN(opt_hpa_sec_nshards, opt_hpa_sec_nshards, size_t)
|
||||||
|
@ -137,10 +137,12 @@ hpa_alloc_ps(tsdn_t *tsdn, hpa_shard_t *shard) {
|
|||||||
static bool
|
static bool
|
||||||
hpa_good_hugification_candidate(hpa_shard_t *shard, hpdata_t *ps) {
|
hpa_good_hugification_candidate(hpa_shard_t *shard, hpdata_t *ps) {
|
||||||
/*
|
/*
|
||||||
* For now, just use a static check; hugify a page if it's <= 5%
|
* Note that this needs to be >= rather than just >, because of the
|
||||||
* inactive. Eventually, this should be a malloc conf option.
|
* important special case in which the hugification threshold is exactly
|
||||||
|
* HUGEPAGE.
|
||||||
*/
|
*/
|
||||||
return hpdata_nactive_get(ps) >= (HUGEPAGE_PAGES) * 95 / 100;
|
return hpdata_nactive_get(ps) * PAGE
|
||||||
|
>= shard->opts.hugification_threshold;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
|
@ -1414,6 +1414,29 @@ malloc_conf_init_helper(sc_data_t *sc_data, unsigned bin_shard_sizes[SC_NBINS],
|
|||||||
"hpa_slab_max_alloc", PAGE, HUGEPAGE,
|
"hpa_slab_max_alloc", PAGE, HUGEPAGE,
|
||||||
CONF_CHECK_MIN, CONF_CHECK_MAX, true);
|
CONF_CHECK_MIN, CONF_CHECK_MAX, true);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Accept either a ratio-based or an exact hugification
|
||||||
|
* threshold.
|
||||||
|
*/
|
||||||
|
CONF_HANDLE_SIZE_T(opt_hpa_opts.hugification_threshold,
|
||||||
|
"hpa_hugification_threshold", PAGE, HUGEPAGE,
|
||||||
|
CONF_CHECK_MIN, CONF_CHECK_MAX, true);
|
||||||
|
if (CONF_MATCH("hpa_hugification_threshold_ratio")) {
|
||||||
|
fxp_t ratio;
|
||||||
|
char *end;
|
||||||
|
bool err = fxp_parse(&ratio, v,
|
||||||
|
&end);
|
||||||
|
if (err || (size_t)(end - v) != vlen
|
||||||
|
|| ratio > FXP_INIT_INT(1)) {
|
||||||
|
CONF_ERROR("Invalid conf value",
|
||||||
|
k, klen, v, vlen);
|
||||||
|
} else {
|
||||||
|
opt_hpa_opts.hugification_threshold =
|
||||||
|
fxp_mul_frac(HUGEPAGE, ratio);
|
||||||
|
}
|
||||||
|
CONF_CONTINUE;
|
||||||
|
}
|
||||||
|
|
||||||
CONF_HANDLE_SIZE_T(opt_hpa_sec_max_alloc, "hpa_sec_max_alloc",
|
CONF_HANDLE_SIZE_T(opt_hpa_sec_max_alloc, "hpa_sec_max_alloc",
|
||||||
PAGE, 0, CONF_CHECK_MIN, CONF_DONT_CHECK_MAX, true);
|
PAGE, 0, CONF_CHECK_MIN, CONF_DONT_CHECK_MAX, true);
|
||||||
CONF_HANDLE_SIZE_T(opt_hpa_sec_max_bytes, "hpa_sec_max_bytes",
|
CONF_HANDLE_SIZE_T(opt_hpa_sec_max_bytes, "hpa_sec_max_bytes",
|
||||||
|
@ -1464,6 +1464,7 @@ stats_general_print(emitter_t *emitter) {
|
|||||||
OPT_WRITE_SIZE_T("oversize_threshold")
|
OPT_WRITE_SIZE_T("oversize_threshold")
|
||||||
OPT_WRITE_BOOL("hpa")
|
OPT_WRITE_BOOL("hpa")
|
||||||
OPT_WRITE_SIZE_T("hpa_slab_max_alloc")
|
OPT_WRITE_SIZE_T("hpa_slab_max_alloc")
|
||||||
|
OPT_WRITE_SIZE_T("hpa_hugification_threshold")
|
||||||
OPT_WRITE_SIZE_T("hpa_sec_max_alloc")
|
OPT_WRITE_SIZE_T("hpa_sec_max_alloc")
|
||||||
OPT_WRITE_SIZE_T("hpa_sec_max_bytes")
|
OPT_WRITE_SIZE_T("hpa_sec_max_bytes")
|
||||||
OPT_WRITE_SIZE_T("hpa_sec_nshards")
|
OPT_WRITE_SIZE_T("hpa_sec_nshards")
|
||||||
|
Loading…
Reference in New Issue
Block a user