mirror of
https://codeberg.org/redict/redict.git
synced 2025-01-21 23:58:51 -05:00
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:
parent
b8beda3cf8
commit
0897c8afed
2
deps/Makefile
vendored
2
deps/Makefile
vendored
@ -106,7 +106,7 @@ endif
|
||||
|
||||
jemalloc: .make-prerequisites
|
||||
@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
|
||||
|
||||
.PHONY: jemalloc
|
||||
|
2
deps/jemalloc/VERSION
vendored
2
deps/jemalloc/VERSION
vendored
@ -1 +1 @@
|
||||
5.2.1-0-g0
|
||||
5.3.0-0-g0
|
||||
|
9742
deps/jemalloc/configure
vendored
9742
deps/jemalloc/configure
vendored
File diff suppressed because it is too large
Load Diff
@ -340,22 +340,21 @@ imalloc_fastpath(size_t size, void *(fallback_alloc)(size_t)) {
|
||||
JEMALLOC_ALWAYS_INLINE int
|
||||
iget_defrag_hint(tsdn_t *tsdn, void* ptr) {
|
||||
int defrag = 0;
|
||||
rtree_ctx_t rtree_ctx_fallback;
|
||||
rtree_ctx_t *rtree_ctx = tsdn_rtree_ctx(tsdn, &rtree_ctx_fallback);
|
||||
szind_t szind;
|
||||
bool is_slab;
|
||||
rtree_szind_slab_read(tsdn, &extents_rtree, rtree_ctx, (uintptr_t)ptr, true, &szind, &is_slab);
|
||||
if (likely(is_slab)) {
|
||||
emap_alloc_ctx_t alloc_ctx;
|
||||
emap_alloc_ctx_lookup(tsdn, &arena_emap_global, ptr, &alloc_ctx);
|
||||
if (likely(alloc_ctx.slab)) {
|
||||
/* Small allocation. */
|
||||
extent_t *slab = iealloc(tsdn, ptr);
|
||||
arena_t *arena = extent_arena_get(slab);
|
||||
szind_t binind = extent_szind_get(slab);
|
||||
unsigned binshard = extent_binshard_get(slab);
|
||||
bin_t *bin = &arena->bins[binind].bin_shards[binshard];
|
||||
edata_t *slab = emap_edata_lookup(tsdn, &arena_emap_global, ptr);
|
||||
arena_t *arena = arena_get_from_edata(slab);
|
||||
szind_t binind = edata_szind_get(slab);
|
||||
unsigned binshard = edata_binshard_get(slab);
|
||||
bin_t *bin = arena_get_bin(arena, binind, binshard);
|
||||
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 */
|
||||
if (slab != bin->slabcur) {
|
||||
int free_in_slab = extent_nfree_get(slab);
|
||||
int free_in_slab = edata_nfree_get(slab);
|
||||
if (free_in_slab) {
|
||||
const bin_info_t *bin_info = &bin_infos[binind];
|
||||
/* 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;
|
||||
/* Run on all bin shards (usually just one) */
|
||||
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;
|
||||
/* Deduct the regs in full slabs (they're not part of the game) */
|
||||
unsigned long full_slabs = bb->stats.curslabs - bb->stats.nonfull_slabs;
|
||||
curregs += bb->stats.curregs - full_slabs * bin_info->nregs;
|
||||
if (bb->slabcur) {
|
||||
/* 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;
|
||||
}
|
||||
}
|
||||
@ -383,6 +382,7 @@ iget_defrag_hint(tsdn_t *tsdn, void* ptr) {
|
||||
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);
|
||||
}
|
||||
return defrag;
|
||||
|
Loading…
Reference in New Issue
Block a user