2017-11-05 03:50:19 +08:00
|
|
|
#ifndef JEMALLOC_INTERNAL_ARENA_STATS_H
|
|
|
|
#define JEMALLOC_INTERNAL_ARENA_STATS_H
|
|
|
|
|
2023-06-10 08:37:47 +08:00
|
|
|
#include "jemalloc/internal/jemalloc_preamble.h"
|
2017-11-05 03:50:19 +08:00
|
|
|
#include "jemalloc/internal/atomic.h"
|
2020-03-09 11:43:41 +08:00
|
|
|
#include "jemalloc/internal/lockedint.h"
|
2017-11-05 03:50:19 +08:00
|
|
|
#include "jemalloc/internal/mutex.h"
|
|
|
|
#include "jemalloc/internal/mutex_prof.h"
|
2020-03-09 04:08:15 +08:00
|
|
|
#include "jemalloc/internal/pa.h"
|
2017-12-15 04:46:39 +08:00
|
|
|
#include "jemalloc/internal/sc.h"
|
2017-11-05 03:50:19 +08:00
|
|
|
|
2018-05-03 17:40:53 +08:00
|
|
|
JEMALLOC_DIAGNOSTIC_DISABLE_SPURIOUS
|
|
|
|
|
2017-11-05 03:50:19 +08:00
|
|
|
typedef struct arena_stats_large_s arena_stats_large_t;
|
|
|
|
struct arena_stats_large_s {
|
|
|
|
/*
|
|
|
|
* Total number of allocation/deallocation requests served directly by
|
|
|
|
* the arena.
|
|
|
|
*/
|
2020-03-09 11:43:41 +08:00
|
|
|
locked_u64_t nmalloc;
|
|
|
|
locked_u64_t ndalloc;
|
2017-11-05 03:50:19 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Number of allocation requests that correspond to this size class.
|
|
|
|
* This includes requests served by tcache, though tcache only
|
|
|
|
* periodically merges into this counter.
|
|
|
|
*/
|
2020-03-09 11:43:41 +08:00
|
|
|
locked_u64_t nrequests; /* Partially derived. */
|
2019-05-07 07:36:55 +08:00
|
|
|
/*
|
|
|
|
* Number of tcache fills / flushes for large (similarly, periodically
|
|
|
|
* merged). Note that there is no large tcache batch-fill currently
|
|
|
|
* (i.e. only fill 1 at a time); however flush may be batched.
|
|
|
|
*/
|
2020-03-09 11:43:41 +08:00
|
|
|
locked_u64_t nfills; /* Partially derived. */
|
|
|
|
locked_u64_t nflushes; /* Partially derived. */
|
2017-11-05 03:50:19 +08:00
|
|
|
|
|
|
|
/* Current number of allocations of this size class. */
|
|
|
|
size_t curlextents; /* Derived. */
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Arena stats. Note that fields marked "derived" are not directly maintained
|
|
|
|
* within the arena code; rather their values are derived during stats merge
|
|
|
|
* requests.
|
|
|
|
*/
|
|
|
|
typedef struct arena_stats_s arena_stats_t;
|
|
|
|
struct arena_stats_s {
|
2020-03-09 11:43:41 +08:00
|
|
|
LOCKEDINT_MTX_DECLARE(mtx)
|
2020-03-12 10:24:05 +08:00
|
|
|
|
2017-11-05 03:50:19 +08:00
|
|
|
/*
|
2020-03-12 10:24:05 +08:00
|
|
|
* resident includes the base stats -- that's why it lives here and not
|
|
|
|
* in pa_shard_stats_t.
|
2017-11-05 03:50:19 +08:00
|
|
|
*/
|
2020-03-12 10:24:05 +08:00
|
|
|
size_t base; /* Derived. */
|
2023-10-11 00:46:23 +08:00
|
|
|
size_t metadata_edata; /* Derived. */
|
|
|
|
size_t metadata_rtree; /* Derived. */
|
2020-03-12 10:24:05 +08:00
|
|
|
size_t resident; /* Derived. */
|
|
|
|
size_t metadata_thp; /* Derived. */
|
2020-03-13 00:36:25 +08:00
|
|
|
size_t mapped; /* Derived. */
|
2017-11-05 03:50:19 +08:00
|
|
|
|
|
|
|
atomic_zu_t internal;
|
|
|
|
|
2020-03-12 23:34:47 +08:00
|
|
|
size_t allocated_large; /* Derived. */
|
|
|
|
uint64_t nmalloc_large; /* Derived. */
|
|
|
|
uint64_t ndalloc_large; /* Derived. */
|
|
|
|
uint64_t nfills_large; /* Derived. */
|
|
|
|
uint64_t nflushes_large; /* Derived. */
|
|
|
|
uint64_t nrequests_large; /* Derived. */
|
2017-11-05 03:50:19 +08:00
|
|
|
|
2020-03-09 04:08:15 +08:00
|
|
|
/*
|
|
|
|
* The stats logically owned by the pa_shard in the same arena. This
|
|
|
|
* lives here only because it's convenient for the purposes of the ctl
|
|
|
|
* module -- it only knows about the single arena_stats.
|
|
|
|
*/
|
|
|
|
pa_shard_stats_t pa_shard_stats;
|
2019-07-16 06:56:05 +08:00
|
|
|
|
2017-11-05 03:50:19 +08:00
|
|
|
/* Number of bytes cached in tcache associated with this arena. */
|
2020-03-12 23:34:47 +08:00
|
|
|
size_t tcache_bytes; /* Derived. */
|
2021-12-01 06:39:34 +08:00
|
|
|
size_t tcache_stashed_bytes; /* Derived. */
|
2017-11-05 03:50:19 +08:00
|
|
|
|
|
|
|
mutex_prof_data_t mutex_prof_data[mutex_prof_num_arena_mutexes];
|
|
|
|
|
|
|
|
/* One element for each large size class. */
|
2017-12-15 04:46:39 +08:00
|
|
|
arena_stats_large_t lstats[SC_NSIZES - SC_NBINS];
|
2017-11-05 03:50:19 +08:00
|
|
|
|
|
|
|
/* Arena uptime. */
|
|
|
|
nstime_t uptime;
|
|
|
|
};
|
|
|
|
|
|
|
|
static inline bool
|
2018-05-03 17:40:53 +08:00
|
|
|
arena_stats_init(tsdn_t *tsdn, arena_stats_t *arena_stats) {
|
2017-11-05 03:50:19 +08:00
|
|
|
if (config_debug) {
|
|
|
|
for (size_t i = 0; i < sizeof(arena_stats_t); i++) {
|
|
|
|
assert(((char *)arena_stats)[i] == 0);
|
|
|
|
}
|
|
|
|
}
|
2020-04-15 05:52:20 +08:00
|
|
|
if (LOCKEDINT_MTX_INIT(arena_stats->mtx, "arena_stats",
|
2017-11-05 03:50:19 +08:00
|
|
|
WITNESS_RANK_ARENA_STATS, malloc_mutex_rank_exclusive)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
/* Memory is zeroed, so there is no need to clear stats. */
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void
|
2019-05-07 07:36:55 +08:00
|
|
|
arena_stats_large_flush_nrequests_add(tsdn_t *tsdn, arena_stats_t *arena_stats,
|
2017-11-05 03:50:19 +08:00
|
|
|
szind_t szind, uint64_t nrequests) {
|
2020-03-09 11:43:41 +08:00
|
|
|
LOCKEDINT_MTX_LOCK(tsdn, arena_stats->mtx);
|
2019-05-07 07:36:55 +08:00
|
|
|
arena_stats_large_t *lstats = &arena_stats->lstats[szind - SC_NBINS];
|
2020-03-09 11:43:41 +08:00
|
|
|
locked_inc_u64(tsdn, LOCKEDINT_MTX(arena_stats->mtx),
|
|
|
|
&lstats->nrequests, nrequests);
|
|
|
|
locked_inc_u64(tsdn, LOCKEDINT_MTX(arena_stats->mtx),
|
|
|
|
&lstats->nflushes, 1);
|
|
|
|
LOCKEDINT_MTX_UNLOCK(tsdn, arena_stats->mtx);
|
2017-11-05 03:50:19 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* JEMALLOC_INTERNAL_ARENA_STATS_H */
|