Blame jemalloc/include/jemalloc/internal/bin.h

Packit Service 724aca
#ifndef JEMALLOC_INTERNAL_BIN_H
Packit Service 724aca
#define JEMALLOC_INTERNAL_BIN_H
Packit Service 724aca
Packit Service 724aca
#include "jemalloc/internal/bin_stats.h"
Packit Service 724aca
#include "jemalloc/internal/bin_types.h"
Packit Service 724aca
#include "jemalloc/internal/extent_types.h"
Packit Service 724aca
#include "jemalloc/internal/extent_structs.h"
Packit Service 724aca
#include "jemalloc/internal/mutex.h"
Packit Service 724aca
#include "jemalloc/internal/sc.h"
Packit Service 724aca
Packit Service 724aca
/*
Packit Service 724aca
 * A bin contains a set of extents that are currently being used for slab
Packit Service 724aca
 * allocations.
Packit Service 724aca
 */
Packit Service 724aca
Packit Service 724aca
/*
Packit Service 724aca
 * Read-only information associated with each element of arena_t's bins array
Packit Service 724aca
 * is stored separately, partly to reduce memory usage (only one copy, rather
Packit Service 724aca
 * than one per arena), but mainly to avoid false cacheline sharing.
Packit Service 724aca
 *
Packit Service 724aca
 * Each slab has the following layout:
Packit Service 724aca
 *
Packit Service 724aca
 *   /--------------------\
Packit Service 724aca
 *   | region 0           |
Packit Service 724aca
 *   |--------------------|
Packit Service 724aca
 *   | region 1           |
Packit Service 724aca
 *   |--------------------|
Packit Service 724aca
 *   | ...                |
Packit Service 724aca
 *   | ...                |
Packit Service 724aca
 *   | ...                |
Packit Service 724aca
 *   |--------------------|
Packit Service 724aca
 *   | region nregs-1     |
Packit Service 724aca
 *   \--------------------/
Packit Service 724aca
 */
Packit Service 724aca
typedef struct bin_info_s bin_info_t;
Packit Service 724aca
struct bin_info_s {
Packit Service 724aca
	/* Size of regions in a slab for this bin's size class. */
Packit Service 724aca
	size_t			reg_size;
Packit Service 724aca
Packit Service 724aca
	/* Total size of a slab for this bin's size class. */
Packit Service 724aca
	size_t			slab_size;
Packit Service 724aca
Packit Service 724aca
	/* Total number of regions in a slab for this bin's size class. */
Packit Service 724aca
	uint32_t		nregs;
Packit Service 724aca
Packit Service 724aca
	/* Number of sharded bins in each arena for this size class. */
Packit Service 724aca
	uint32_t		n_shards;
Packit Service 724aca
Packit Service 724aca
	/*
Packit Service 724aca
	 * Metadata used to manipulate bitmaps for slabs associated with this
Packit Service 724aca
	 * bin.
Packit Service 724aca
	 */
Packit Service 724aca
	bitmap_info_t		bitmap_info;
Packit Service 724aca
};
Packit Service 724aca
Packit Service 724aca
extern bin_info_t bin_infos[SC_NBINS];
Packit Service 724aca
Packit Service 724aca
typedef struct bin_s bin_t;
Packit Service 724aca
struct bin_s {
Packit Service 724aca
	/* All operations on bin_t fields require lock ownership. */
Packit Service 724aca
	malloc_mutex_t		lock;
Packit Service 724aca
Packit Service 724aca
	/*
Packit Service 724aca
	 * Current slab being used to service allocations of this bin's size
Packit Service 724aca
	 * class.  slabcur is independent of slabs_{nonfull,full}; whenever
Packit Service 724aca
	 * slabcur is reassigned, the previous slab must be deallocated or
Packit Service 724aca
	 * inserted into slabs_{nonfull,full}.
Packit Service 724aca
	 */
Packit Service 724aca
	extent_t		*slabcur;
Packit Service 724aca
Packit Service 724aca
	/*
Packit Service 724aca
	 * Heap of non-full slabs.  This heap is used to assure that new
Packit Service 724aca
	 * allocations come from the non-full slab that is oldest/lowest in
Packit Service 724aca
	 * memory.
Packit Service 724aca
	 */
Packit Service 724aca
	extent_heap_t		slabs_nonfull;
Packit Service 724aca
Packit Service 724aca
	/* List used to track full slabs. */
Packit Service 724aca
	extent_list_t		slabs_full;
Packit Service 724aca
Packit Service 724aca
	/* Bin statistics. */
Packit Service 724aca
	bin_stats_t	stats;
Packit Service 724aca
};
Packit Service 724aca
Packit Service 724aca
/* A set of sharded bins of the same size class. */
Packit Service 724aca
typedef struct bins_s bins_t;
Packit Service 724aca
struct bins_s {
Packit Service 724aca
	/* Sharded bins.  Dynamically sized. */
Packit Service 724aca
	bin_t *bin_shards;
Packit Service 724aca
};
Packit Service 724aca
Packit Service 724aca
void bin_shard_sizes_boot(unsigned bin_shards[SC_NBINS]);
Packit Service 724aca
bool bin_update_shard_size(unsigned bin_shards[SC_NBINS], size_t start_size,
Packit Service 724aca
    size_t end_size, size_t nshards);
Packit Service 724aca
void bin_boot(sc_data_t *sc_data, unsigned bin_shard_sizes[SC_NBINS]);
Packit Service 724aca
Packit Service 724aca
/* Initializes a bin to empty.  Returns true on error. */
Packit Service 724aca
bool bin_init(bin_t *bin);
Packit Service 724aca
Packit Service 724aca
/* Forking. */
Packit Service 724aca
void bin_prefork(tsdn_t *tsdn, bin_t *bin);
Packit Service 724aca
void bin_postfork_parent(tsdn_t *tsdn, bin_t *bin);
Packit Service 724aca
void bin_postfork_child(tsdn_t *tsdn, bin_t *bin);
Packit Service 724aca
Packit Service 724aca
/* Stats. */
Packit Service 724aca
static inline void
Packit Service 724aca
bin_stats_merge(tsdn_t *tsdn, bin_stats_t *dst_bin_stats, bin_t *bin) {
Packit Service 724aca
	malloc_mutex_lock(tsdn, &bin->lock);
Packit Service 724aca
	malloc_mutex_prof_accum(tsdn, &dst_bin_stats->mutex_data, &bin->lock);
Packit Service 724aca
	dst_bin_stats->nmalloc += bin->stats.nmalloc;
Packit Service 724aca
	dst_bin_stats->ndalloc += bin->stats.ndalloc;
Packit Service 724aca
	dst_bin_stats->nrequests += bin->stats.nrequests;
Packit Service 724aca
	dst_bin_stats->curregs += bin->stats.curregs;
Packit Service 724aca
	dst_bin_stats->nfills += bin->stats.nfills;
Packit Service 724aca
	dst_bin_stats->nflushes += bin->stats.nflushes;
Packit Service 724aca
	dst_bin_stats->nslabs += bin->stats.nslabs;
Packit Service 724aca
	dst_bin_stats->reslabs += bin->stats.reslabs;
Packit Service 724aca
	dst_bin_stats->curslabs += bin->stats.curslabs;
Packit Service 724aca
	dst_bin_stats->nonfull_slabs += bin->stats.nonfull_slabs;
Packit Service 724aca
	malloc_mutex_unlock(tsdn, &bin->lock);
Packit Service 724aca
}
Packit Service 724aca
Packit Service 724aca
#endif /* JEMALLOC_INTERNAL_BIN_H */