Upgrade to jemalloc 5.3.0

* Regenerate configure script sccording to deps/README
* update iget_defrag_hint by following changes to arena_dalloc_no_tcache
This commit is contained in:
Oran Agra 2023-05-01 17:18:38 +03:00
parent b8beda3cf8
commit 0897c8afed
4 changed files with 6227 additions and 3547 deletions

2
deps/Makefile vendored
View File

@ -106,7 +106,7 @@ endif
jemalloc: .make-prerequisites jemalloc: .make-prerequisites
@printf '%b %b\n' $(MAKECOLOR)MAKE$(ENDCOLOR) $(BINCOLOR)$@$(ENDCOLOR) @printf '%b %b\n' $(MAKECOLOR)MAKE$(ENDCOLOR) $(BINCOLOR)$@$(ENDCOLOR)
cd jemalloc && ./configure --disable-cxx --with-version=5.2.1-0-g0 --with-lg-quantum=3 --with-jemalloc-prefix=je_ CFLAGS="$(JEMALLOC_CFLAGS)" LDFLAGS="$(JEMALLOC_LDFLAGS)" $(JEMALLOC_CONFIGURE_OPTS) cd jemalloc && ./configure --disable-cxx --with-version=5.3.0-0-g0 --with-lg-quantum=3 --with-jemalloc-prefix=je_ CFLAGS="$(JEMALLOC_CFLAGS)" LDFLAGS="$(JEMALLOC_LDFLAGS)" $(JEMALLOC_CONFIGURE_OPTS)
cd jemalloc && $(MAKE) lib/libjemalloc.a cd jemalloc && $(MAKE) lib/libjemalloc.a
.PHONY: jemalloc .PHONY: jemalloc

View File

@ -1 +1 @@
5.2.1-0-g0 5.3.0-0-g0

9742
deps/jemalloc/configure vendored

File diff suppressed because it is too large Load Diff

View File

@ -340,22 +340,21 @@ imalloc_fastpath(size_t size, void *(fallback_alloc)(size_t)) {
JEMALLOC_ALWAYS_INLINE int JEMALLOC_ALWAYS_INLINE int
iget_defrag_hint(tsdn_t *tsdn, void* ptr) { iget_defrag_hint(tsdn_t *tsdn, void* ptr) {
int defrag = 0; int defrag = 0;
rtree_ctx_t rtree_ctx_fallback; emap_alloc_ctx_t alloc_ctx;
rtree_ctx_t *rtree_ctx = tsdn_rtree_ctx(tsdn, &rtree_ctx_fallback); emap_alloc_ctx_lookup(tsdn, &arena_emap_global, ptr, &alloc_ctx);
szind_t szind; if (likely(alloc_ctx.slab)) {
bool is_slab;
rtree_szind_slab_read(tsdn, &extents_rtree, rtree_ctx, (uintptr_t)ptr, true, &szind, &is_slab);
if (likely(is_slab)) {
/* Small allocation. */ /* Small allocation. */
extent_t *slab = iealloc(tsdn, ptr); edata_t *slab = emap_edata_lookup(tsdn, &arena_emap_global, ptr);
arena_t *arena = extent_arena_get(slab); arena_t *arena = arena_get_from_edata(slab);
szind_t binind = extent_szind_get(slab); szind_t binind = edata_szind_get(slab);
unsigned binshard = extent_binshard_get(slab); unsigned binshard = edata_binshard_get(slab);
bin_t *bin = &arena->bins[binind].bin_shards[binshard]; bin_t *bin = arena_get_bin(arena, binind, binshard);
malloc_mutex_lock(tsdn, &bin->lock); malloc_mutex_lock(tsdn, &bin->lock);
arena_dalloc_bin_locked_info_t info;
arena_dalloc_bin_locked_begin(&info, binind);
/* Don't bother moving allocations from the slab currently used for new allocations */ /* Don't bother moving allocations from the slab currently used for new allocations */
if (slab != bin->slabcur) { if (slab != bin->slabcur) {
int free_in_slab = extent_nfree_get(slab); int free_in_slab = edata_nfree_get(slab);
if (free_in_slab) { if (free_in_slab) {
const bin_info_t *bin_info = &bin_infos[binind]; const bin_info_t *bin_info = &bin_infos[binind];
/* Find number of non-full slabs and the number of regs in them */ /* Find number of non-full slabs and the number of regs in them */
@ -363,14 +362,14 @@ iget_defrag_hint(tsdn_t *tsdn, void* ptr) {
size_t curregs = 0; size_t curregs = 0;
/* Run on all bin shards (usually just one) */ /* Run on all bin shards (usually just one) */
for (uint32_t i=0; i< bin_info->n_shards; i++) { for (uint32_t i=0; i< bin_info->n_shards; i++) {
bin_t *bb = &arena->bins[binind].bin_shards[i]; bin_t *bb = arena_get_bin(arena, binind, i);
curslabs += bb->stats.nonfull_slabs; curslabs += bb->stats.nonfull_slabs;
/* Deduct the regs in full slabs (they're not part of the game) */ /* Deduct the regs in full slabs (they're not part of the game) */
unsigned long full_slabs = bb->stats.curslabs - bb->stats.nonfull_slabs; unsigned long full_slabs = bb->stats.curslabs - bb->stats.nonfull_slabs;
curregs += bb->stats.curregs - full_slabs * bin_info->nregs; curregs += bb->stats.curregs - full_slabs * bin_info->nregs;
if (bb->slabcur) { if (bb->slabcur) {
/* Remove slabcur from the overall utilization (not a candidate to nove from) */ /* Remove slabcur from the overall utilization (not a candidate to nove from) */
curregs -= bin_info->nregs - extent_nfree_get(bb->slabcur); curregs -= bin_info->nregs - edata_nfree_get(bb->slabcur);
curslabs -= 1; curslabs -= 1;
} }
} }
@ -383,6 +382,7 @@ iget_defrag_hint(tsdn_t *tsdn, void* ptr) {
defrag = (bin_info->nregs - free_in_slab) * curslabs <= curregs + curregs / 8; defrag = (bin_info->nregs - free_in_slab) * curslabs <= curregs + curregs / 8;
} }
} }
arena_dalloc_bin_locked_finish(tsdn, arena, bin, &info);
malloc_mutex_unlock(tsdn, &bin->lock); malloc_mutex_unlock(tsdn, &bin->lock);
} }
return defrag; return defrag;