2020-03-08 12:14:49 +08:00
|
|
|
#ifndef JEMALLOC_INTERNAL_PA_H
|
|
|
|
#define JEMALLOC_INTERNAL_PA_H
|
|
|
|
|
2020-03-09 04:08:15 +08:00
|
|
|
#include "jemalloc/internal/ecache.h"
|
|
|
|
#include "jemalloc/internal/edata_cache.h"
|
2020-03-10 01:40:37 +08:00
|
|
|
#include "jemalloc/internal/lockedint.h"
|
2020-03-09 04:08:15 +08:00
|
|
|
|
2020-03-08 12:14:49 +08:00
|
|
|
/*
|
|
|
|
* The page allocator; responsible for acquiring pages of memory for
|
|
|
|
* allocations.
|
|
|
|
*/
|
|
|
|
|
2020-03-10 02:26:15 +08:00
|
|
|
/*
|
|
|
|
* The stats for a particular pa_shard. Because of the way the ctl module
|
|
|
|
* handles stats epoch data collection (it has its own arena_stats, and merges
|
|
|
|
* the stats from each arena into it), this needs to live in the arena_stats_t;
|
|
|
|
* hence we define it here and let the pa_shard have a pointer (rather than the
|
|
|
|
* more natural approach of just embedding it in the pa_shard itself).
|
|
|
|
*
|
|
|
|
* We follow the arena_stats_t approach of marking the derived fields. These
|
|
|
|
* are the ones that are not maintained on their own; instead, their values are
|
|
|
|
* derived during those stats merges.
|
|
|
|
*/
|
2020-03-10 01:40:37 +08:00
|
|
|
typedef struct pa_shard_decay_stats_s pa_shard_decay_stats_t;
|
|
|
|
struct pa_shard_decay_stats_s {
|
|
|
|
/* Total number of purge sweeps. */
|
|
|
|
locked_u64_t npurge;
|
|
|
|
/* Total number of madvise calls made. */
|
|
|
|
locked_u64_t nmadvise;
|
|
|
|
/* Total number of pages purged. */
|
|
|
|
locked_u64_t purged;
|
|
|
|
};
|
|
|
|
|
2020-03-09 04:08:15 +08:00
|
|
|
typedef struct pa_shard_stats_s pa_shard_stats_t;
|
|
|
|
struct pa_shard_stats_s {
|
2020-03-10 01:40:37 +08:00
|
|
|
pa_shard_decay_stats_t decay_dirty;
|
|
|
|
pa_shard_decay_stats_t decay_muzzy;
|
2020-03-09 04:08:15 +08:00
|
|
|
/* VM space had to be leaked (undocumented). Normally 0. */
|
|
|
|
atomic_zu_t abandoned_vm;
|
|
|
|
};
|
|
|
|
|
2020-03-09 01:35:56 +08:00
|
|
|
typedef struct pa_shard_s pa_shard_t;
|
|
|
|
struct pa_shard_s {
|
|
|
|
/*
|
|
|
|
* Collections of extents that were previously allocated. These are
|
|
|
|
* used when allocating extents, in an attempt to re-use address space.
|
|
|
|
*
|
|
|
|
* Synchronization: internal.
|
|
|
|
*/
|
|
|
|
ecache_t ecache_dirty;
|
|
|
|
ecache_t ecache_muzzy;
|
|
|
|
ecache_t ecache_retained;
|
2020-03-09 02:41:19 +08:00
|
|
|
|
|
|
|
/* The source of edata_t objects. */
|
|
|
|
edata_cache_t edata_cache;
|
2020-03-09 04:08:15 +08:00
|
|
|
|
2020-03-09 04:47:02 +08:00
|
|
|
/* The grow info for the retained ecache. */
|
|
|
|
ecache_grow_t ecache_grow;
|
|
|
|
|
2020-03-10 02:10:43 +08:00
|
|
|
/* Extent serial number generator state. */
|
|
|
|
atomic_zu_t extent_sn_next;
|
|
|
|
|
2020-03-09 04:08:15 +08:00
|
|
|
pa_shard_stats_t *stats;
|
2020-03-09 01:35:56 +08:00
|
|
|
};
|
|
|
|
|
2020-03-09 02:19:41 +08:00
|
|
|
/* Returns true on error. */
|
2020-03-09 04:08:15 +08:00
|
|
|
bool pa_shard_init(tsdn_t *tsdn, pa_shard_t *shard, base_t *base, unsigned ind,
|
|
|
|
pa_shard_stats_t *stats);
|
2020-03-10 02:10:43 +08:00
|
|
|
size_t pa_shard_extent_sn_next(pa_shard_t *shard);
|
2020-03-09 02:19:41 +08:00
|
|
|
|
2020-03-08 12:14:49 +08:00
|
|
|
#endif /* JEMALLOC_INTERNAL_PA_H */
|