13
13
along with this program; if not, write to the Free Software
14
14
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
18
* @brief Memory root declarations
21
#ifndef DRIZZLED_MEMORY_ROOT_H
22
#define DRIZZLED_MEMORY_ROOT_H
26
#include <drizzled/definitions.h>
32
* @namespace drizzled::memory
33
* Memory allocation utils
35
* NB: This namespace documentation may not seem very useful, but without a
36
* comment on the namespace Doxygen won't extract any documentation for
42
static const int KEEP_PREALLOC= 1;
43
/* move used to free list and reuse them */
44
static const int MARK_BLOCKS_FREE= 2;
50
{ /* struct for once_alloc (block) */
52
UsedMemory *next; /* Next block in use */
53
size_t left; /* memory left in block */
54
size_t size; /* size of block */
59
static const size_t ROOT_MIN_BLOCK_SIZE= (MALLOC_OVERHEAD + sizeof(internal::UsedMemory) + 8);
78
Root(size_t block_size_arg)
80
free= used= pre_alloc= 0;
82
block_size= block_size_arg - memory::ROOT_MIN_BLOCK_SIZE;
83
block_num= 4; /* We shift this with >>2 */
89
* blocks with free memory in it
91
internal::UsedMemory *free;
94
* blocks almost without free memory
96
internal::UsedMemory *used;
101
internal::UsedMemory *pre_alloc;
104
* if block have less memory it will be put in 'used' list
17
Data structures for mysys/my_alloc.c (root memory allocator)
23
#define ALLOC_MAX_BLOCK_TO_DROP 4096
24
#define ALLOC_MAX_BLOCK_USAGE_BEFORE_DROP 10
26
typedef struct st_used_mem
27
{ /* struct for once_alloc (block) */
28
struct st_used_mem *next; /* Next block in use */
29
unsigned int left; /* memory left in block */
30
unsigned int size; /* size of block */
34
typedef struct st_mem_root
36
USED_MEM *free; /* blocks with free memory in it */
37
USED_MEM *used; /* blocks almost without free memory */
38
USED_MEM *pre_alloc; /* preallocated block */
39
/* if block have less memory it will be put in 'used' list */
106
40
size_t min_malloc;
108
size_t block_size; ///< initial block size
109
unsigned int block_num; ///< allocated blocks counter
112
* first free block in queue test counter (if it exceed
113
* MAX_BLOCK_USAGE_BEFORE_DROP block will be dropped in 'used' list)
41
size_t block_size; /* initial block size */
42
unsigned int block_num; /* allocated blocks counter */
44
first free block in queue test counter (if it exceed
45
MAX_BLOCK_USAGE_BEFORE_DROP block will be dropped in 'used' list)
115
47
unsigned int first_block_usage;
117
49
void (*error_handler)(void);
118
void reset_root_defaults(size_t block_size, size_t prealloc_size);
119
void *alloc_root(size_t Size);
120
void mark_blocks_free();
121
void *memdup_root(const void *str, size_t len);
122
char *strdup_root(const char *str);
123
char *strmake_root(const char *str,size_t len);
124
void init_alloc_root(size_t block_size= ROOT_MIN_BLOCK_SIZE);
126
inline bool alloc_root_inited()
128
return min_malloc != 0;
130
void free_root(myf MyFLAGS);
131
void *multi_alloc_root(int unused, ...);
134
} /* namespace memory */
135
} /* namespace drizzled */
137
#endif /* DRIZZLED_MEMORY_ROOT_H */