You need to sign in or sign up before continuing.
malloc_impl.h 3.3 KB
Newer Older
F
Far 已提交
1 2 3 4 5 6 7 8 9 10 11 12
#ifndef MALLOC_IMPL_H
#define MALLOC_IMPL_H

#include <sys/mman.h>
#include "malloc_config.h"

hidden void *__expand_heap(size_t *);

hidden void __malloc_donate(char *, char *);

hidden void *__memalign(size_t, size_t);

13 14 15 16 17
typedef struct occupied_bin_s {
	struct chunk *head, *tail;
	volatile int lock[2];
} occupied_bin_t;
 
F
Far 已提交
18 19
struct chunk {
	size_t psize, csize;
20 21 22 23
#ifdef MUSL_ITERATE_AND_STATS_API
	occupied_bin_t *bin;
#endif

24 25 26
#ifdef MALLOC_RED_ZONE
	size_t usize;
	size_t state;
27 28 29 30
#endif
#ifdef MUSL_ITERATE_AND_STATS_API
	size_t flag;
	struct chunk *next_occupied, *prev_occupied;
31
#endif
F
Far 已提交
32 33 34 35 36 37 38 39 40 41 42 43
	struct chunk *next, *prev;
};

struct bin {
	volatile int lock[2];
	struct chunk *head;
	struct chunk *tail;
#ifdef MALLOC_FREELIST_HARDENED
	void *key;
#endif
};

44 45 46 47 48 49 50 51 52 53 54
#ifdef MUSL_ITERATE_AND_STATS_API
typedef void (*malloc_iterate_callback)(void* base, size_t size, void* arg);

hidden occupied_bin_t *__get_occupied_bin(struct __pthread *p);
hidden occupied_bin_t *__get_current_occupied_bin();
hidden void __merge_bin_chunks(occupied_bin_t *target_bin, occupied_bin_t *source_bin);
hidden void __init_occupied_bin_key_once(void);
hidden void __push_chunk(struct chunk *c);
hidden void __pop_chunk(struct chunk *c);
#endif

F
Far 已提交
55
#define SIZE_MASK (-SIZE_ALIGN)
56 57 58 59

#ifdef MUSL_ITERATE_AND_STATS_API
#define OCCUPIED_LIST_OVERHEAD (2*sizeof(void*))
#define ITERATE_AND_STATS_OVERHEAD (sizeof(size_t) + sizeof(void*) + OCCUPIED_LIST_OVERHEAD)
60
#else
61 62 63 64
#define ITERATE_AND_STATS_OVERHEAD (0)
#endif

#ifndef MALLOC_RED_ZONE
65
#define SIZE_ALIGN (8*sizeof(size_t))
66 67 68 69
#define OVERHEAD (2*sizeof(size_t) + ITERATE_AND_STATS_OVERHEAD)
#else
#define SIZE_ALIGN (16*sizeof(size_t))
#define OVERHEAD (4*sizeof(size_t) + ITERATE_AND_STATS_OVERHEAD)
70
#endif
71 72


F
Far 已提交
73
#define MMAP_THRESHOLD (0x1c00*SIZE_ALIGN)
74
#ifndef MALLOC_RED_ZONE
75
#define DONTCARE OVERHEAD
76 77 78 79
#else
#define DONTCARE OVERHEAD
#define POINTER_USAGE (2*sizeof(void *))
#endif
F
Far 已提交
80 81
#define RECLAIM 163840

82 83 84 85 86 87 88
#ifdef MALLOC_FREELIST_QUARANTINE
#define QUARANTINE_MEM_SIZE 16384
#define QUARANTINE_THRESHOLD (QUARANTINE_MEM_SIZE / QUARANTINE_NUM)
#define QUARANTINE_N_THRESHOLD 32
#define QUARANTINE_NUM 8
#endif

F
Far 已提交
89 90 91 92 93 94 95 96
#define CHUNK_SIZE(c) ((c)->csize & -2)
#define CHUNK_PSIZE(c) ((c)->psize & -2)
#define PREV_CHUNK(c) ((struct chunk *)((char *)(c) - CHUNK_PSIZE(c)))
#define NEXT_CHUNK(c) ((struct chunk *)((char *)(c) + CHUNK_SIZE(c)))
#define MEM_TO_CHUNK(p) (struct chunk *)((char *)(p) - OVERHEAD)
#define CHUNK_TO_MEM(c) (void *)((char *)(c) + OVERHEAD)
#define BIN_TO_CHUNK(i) (MEM_TO_CHUNK(&mal.bins[i].head))

97 98 99 100
#ifdef MALLOC_FREELIST_QUARANTINE
#define QUARANTINE_TO_CHUNK(i) (MEM_TO_CHUNK(&mal.quarantine[i].head))
#endif

101 102 103 104 105 106 107 108 109 110 111 112 113 114 115
#ifdef MALLOC_RED_ZONE
#define M_STATE_FREE   0x00
#define M_STATE_USED   0x01U
#define M_STATE_BRK    0x02U
#define M_STATE_MMAP   0x04U

#define M_RZ_NONE   0x00
#define M_RZ_POISON 0x10U

#define M_STATE_MASK   0xffU
#define M_CHECKSUM_SHIFT 8

#define POISON_PERIOD 31
#endif

F
Far 已提交
116 117 118 119 120 121 122 123
#define C_INUSE  ((size_t)1)

#define IS_MMAPPED(c) !((c)->csize & (C_INUSE))

hidden void __bin_chunk(struct chunk *);

hidden extern int __malloc_replaced;

124 125 126 127 128 129 130 131
hidden void *internal_malloc(size_t n);

hidden void internal_free(void *p);

hidden void *internal_calloc(size_t m, size_t n);

hidden void *internal_realloc(void *p, size_t n);

132 133 134 135 136 137
#ifdef MALLOC_RED_ZONE
hidden void chunk_checksum_set(struct chunk *c);

hidden int chunk_checksum_check(struct chunk *c);
#endif

138
#endif