summaryrefslogtreecommitdiffstats
path: root/src/arena.c
diff options
context:
space:
mode:
authorJason Evans <jasone@canonware.com>2017-02-13 01:03:46 (GMT)
committerJason Evans <jasone@canonware.com>2017-02-16 17:39:46 (GMT)
commitfa2d64c94b07ee21a0f6f44b9fe6e3bbefa51c6c (patch)
tree3b2e28716d705f3298c6bf7cd74ff0e9ff018bce /src/arena.c
parentb779522b9b81f8a53a1f147968a890af8664b213 (diff)
downloadjemalloc-fa2d64c94b07ee21a0f6f44b9fe6e3bbefa51c6c.zip
jemalloc-fa2d64c94b07ee21a0f6f44b9fe6e3bbefa51c6c.tar.gz
jemalloc-fa2d64c94b07ee21a0f6f44b9fe6e3bbefa51c6c.tar.bz2
Convert arena->prof_accumbytes synchronization to atomics.
Diffstat (limited to 'src/arena.c')
-rw-r--r--src/arena.c18
1 files changed, 4 insertions, 14 deletions
diff --git a/src/arena.c b/src/arena.c
index 345c57d..40db9d1 100644
--- a/src/arena.c
+++ b/src/arena.c
@@ -1148,19 +1148,7 @@ arena_prof_promote(tsdn_t *tsdn, extent_t *extent, const void *ptr,
extent_usize_set(extent, usize);
- /*
- * Cancel out as much of the excessive prof_accumbytes increase as
- * possible without underflowing. Interval-triggered dumps occur
- * slightly more often than intended as a result of incomplete
- * canceling.
- */
- malloc_mutex_lock(tsdn, &arena->lock);
- if (arena->prof_accumbytes >= LARGE_MINCLASS - usize) {
- arena->prof_accumbytes -= LARGE_MINCLASS - usize;
- } else {
- arena->prof_accumbytes = 0;
- }
- malloc_mutex_unlock(tsdn, &arena->lock);
+ prof_accum_cancel(tsdn, &arena->prof_accum, usize);
assert(isalloc(tsdn, extent, ptr) == usize);
}
@@ -1574,7 +1562,9 @@ arena_new(tsdn_t *tsdn, unsigned ind, extent_hooks_t *extent_hooks) {
}
if (config_prof) {
- arena->prof_accumbytes = 0;
+ if (prof_accum_init(tsdn, &arena->prof_accum)) {
+ goto label_error;
+ }
}
if (config_cache_oblivious) {