Subject: CVS commit: pkgsrc/devel/jemalloc
From: Adam Ciarcinski
Date: 2019-04-24 19:11:00
Message id: 20190424171100.2AC72FB16@cvs.NetBSD.org

Log Message:
jemalloc: updated to 5.2.0

5.2.0:
This release includes a few notable improvements, which are summarized below: 1) \ 
improved fast-path performance from the optimizations by @djwatson; 2) reduced \ 
virtual memory fragmentation and metadata usage; and 3) bug fixes on setting the \ 
number of background threads. In addition, peak / spike memory usage is improved \ 
with certain allocation patterns. As usual, the release and prior dev versions \ 
have gone through large-scale production testing.

New features:
Implement oversize_threshold, which uses a dedicated arena for allocations \ 
crossing the specified threshold to reduce fragmentation.
Add extents usage information to stats.
Log time information for sampled allocations.
Support 0 size in sdallocx.
Output rate for certain counters in malloc_stats.
Add configure option --enable-readlinkat, which allows the use of readlinkat \ 
over readlink.
Add configure options --{enable,disable}-{static,shared} to allow not building \ 
unwanted libraries.
Add configure option --disable-libdl to enable fully static builds.
Add mallctl interfaces:
opt.oversize_threshold
stats.arenas.<i>.extent_avail
stats.arenas.<i>.extents.<j>.n{dirty,muzzy,retained}
stats.arenas.<i>.extents.<j>.{dirty,muzzy,retained}_bytes

Portability improvements:
Update MSVC builds.
Workaround a compiler optimizer bug on s390x.
Make use of pthread_set_name_np(3) on FreeBSD.
Implement malloc_getcpu() to enable percpu_arena for windows.
Link against -pthread instead of -lpthread.
Make background_thread not dependent on libdl.
Add stringify to fix a linker directive issue on MSVC.
Detect and fall back when 8-bit atomics are unavailable.
Fall back to the default pthread_create(3) if dlsym(3) fails.

Optimizations and refactors:
Refactor the TSD module.
Avoid taking extents_muzzy mutex when muzzy is disabled.
Avoid taking large_mtx for auto arenas on the tcache flush path.
Optimize ixalloc by avoiding a size lookup.
Implement opt.oversize_threshold which uses a dedicated arena for requests \ 
crossing the threshold, also eagerly purges the oversize extents. Default the \ 
threshold to 8 MiB.
Clean compilation with -Wextra.
Refactor the size class module.
Refactor the stats emitter.
Optimize pow2_ceil.
Avoid runtime detection of lazy purging on FreeBSD.
Optimize mmap(2) alignment handling on FreeBSD.
Improve error handling for THP state initialization.
Rework the malloc() fast path.
Rework the free() fast path.
Refactor and optimize the tcache fill / flush paths.
Optimize sync / lwsync on PowerPC.
Bypass extent_dalloc() when retain is enabled.
Optimize the locking on large deallocation.
Reduce the number of pages committed from sanity checking in debug build.
Deprecate OSSpinLock.
Lower the default number of background threads to 4 (when the feature is enabled).
Optimize the trylock spin wait.
Use arena index for arena-matching checks.
Avoid forced decay on thread termination when using background threads.
Disable muzzy decay by default.
Only initialize libgcc unwinder when profiling is enabled.

Bug fixes (all only relevant to jemalloc 5.x):
Fix background thread index issues with max_background_threads.
Fix stats output for opt.lg_extent_max_active_fit.
Fix opt.prof_prefix initialization.
Properly trigger decay on tcache destroy.
Fix tcache.flush.
Detect whether explicit extent zero out is necessary with huge pages or custom \ 
extent hooks, which may change the purge semantics.
Fix a side effect caused by extent_max_active_fit combined with decay-based \ 
purging, where freed extents can accumulate and not be reused for an extended \ 
period of time.
Fix a missing unlock on extent register error handling.

Testing:
Simplify the Travis script output.
Update the test scripts for FreeBSD.
Add unit tests for the producer-consumer pattern.
Add Cirrus-CI config for FreeBSD builds.
Add size-matching sanity checks on tcache flush.

Incompatible changes:
Remove --with-lg-page-sizes.

Documentation:
Attempt to build docs by default, however skip doc building when xsltproc is missing.

Files:
RevisionActionfile
1.14modifypkgsrc/devel/jemalloc/Makefile
1.13modifypkgsrc/devel/jemalloc/distinfo
1.1addpkgsrc/devel/jemalloc/patches/patch-include_jemalloc_internal_quantum.h
1.1removepkgsrc/devel/jemalloc/patches/patch-include_jemalloc_internal_jemalloc_internal_types.h