svn merge -r36583:36603 https://svn.blender.org/svnroot/bf-blender/trunk/blender
[blender.git] / intern / guardedalloc / MEM_guardedalloc.h
1 /*
2  * $Id$
3  * ***** BEGIN GPL LICENSE BLOCK *****
4  *
5  * This program is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU General Public License
7  * as published by the Free Software Foundation; either version 2
8  * of the License, or (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program; if not, write to the Free Software Foundation,
17  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18  *
19  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
20  * All rights reserved.
21  *
22  * The Original Code is: all of this file.
23  *
24  * Contributor(s): none yet.
25  *
26  * ***** END GPL LICENSE BLOCK *****
27  */
28
29 /** \file MEM_guardedalloc.h
30  *  \ingroup MEM
31  *
32  *  \author Copyright (C) 2001 NaN Technologies B.V.
33  *  \brief Read \ref MEMPage
34  */
35
36 /** 
37  * \page MEMPage Guarded memory(de)allocation
38  *
39  * \section aboutmem c-style guarded memory allocation
40  *
41  * \subsection memabout About the MEM module
42  *
43  * MEM provides guarded malloc/calloc calls. All memory is enclosed by
44  * pads, to detect out-of-bound writes. All blocks are placed in a
45  * linked list, so they remain reachable at all times. There is no
46  * back-up in case the linked-list related data is lost.
47  *
48  * \subsection memissues Known issues with MEM
49  *
50  * There are currently no known issues with MEM. Note that there is a
51  * second intern/ module with MEM_ prefix, for use in c++.
52  * 
53  * \subsection memdependencies Dependencies
54  * - stdlib
55  * - stdio
56  * 
57  * \subsection memdocs API Documentation
58  * See \ref MEM_guardedalloc.h
59  */
60
61 #ifndef MEM_MALLOCN_H
62 #define MEM_MALLOCN_H
63
64 #include <stdio.h> /* needed for FILE* */
65 #include "MEM_sys_types.h" /* needed for uintptr_t */
66
67 #ifndef WARN_UNUSED
68 #  ifdef __GNUC__
69 #    define WARN_UNUSED  __attribute__((warn_unused_result))
70 #  else
71 #    define WARN_UNUSED
72 #  endif
73 #endif
74
75 #ifdef __cplusplus
76 extern "C" {
77 #endif
78
79         /** Returns the length of the allocated memory segment pointed at
80          * by vmemh. If the pointer was not previously allocated by this
81          * module, the result is undefined.*/
82         size_t MEM_allocN_len(void *vmemh) WARN_UNUSED;
83
84         /**
85          * Release memory previously allocatred by this module. 
86          */
87         short MEM_freeN(void *vmemh);
88         short WMEM_freeN(void *vmemh);
89         
90         short _MEM_freeN(void *vmemh, const char *file, int line);
91         #define MEM_freeN(vmemh)        _MEM_freeN(vmemh, __FILE__, __LINE__)
92         
93
94         /**
95          * Return zero if memory is not in allocated list
96          */
97         short MEM_testN(void *vmemh);
98
99         /**
100          * Duplicates a block of memory, and returns a pointer to the
101          * newly allocated block.  */
102         void *MEM_dupallocN(void *vmemh) WARN_UNUSED;
103
104         /**
105           * Reallocates a block of memory, and returns pointer to the newly
106           * allocated block, the old one is freed. this is not as optimized
107           * as a system realloc but just makes a new allocation and copies
108           * over from existing memory. */
109         void *MEM_reallocN(void *vmemh, size_t len) WARN_UNUSED;
110
111         /**
112          * Allocate a block of memory of size len, with tag name str. The
113          * memory is cleared. The name must be static, because only a
114          * pointer to it is stored ! */
115         void *MEM_callocN(size_t len, const char * str) WARN_UNUSED;
116         
117         /** Allocate a block of memory of size len, with tag name str. The
118                 * name must be a static, because only a pointer to it is stored !
119                 * */
120         void *MEM_mallocN(size_t len, const char * str) WARN_UNUSED;
121         
122         /** Same as callocN, clears memory and uses mmap (disk cached) if supported.
123                 Can be free'd with MEM_freeN as usual.
124                 * */
125         void *MEM_mapallocN(size_t len, const char * str) WARN_UNUSED;
126
127         /** Print a list of the names and sizes of all allocated memory
128          * blocks. as a python dict for easy investigation */ 
129         void MEM_printmemlist_pydict(void);
130
131         /** Print a list of the names and sizes of all allocated memory
132          * blocks. */ 
133         void MEM_printmemlist(void);
134
135         /** calls the function on all allocated memory blocks. */
136         void MEM_callbackmemlist(void (*func)(void*));
137
138         /** Print statistics about memory usage */
139         void MEM_printmemlist_stats(void);
140         
141         /** Set the callback function for error output. */
142         void MEM_set_error_callback(void (*func)(const char *));
143
144         /**
145          * Are the start/end block markers still correct ?
146          *
147          * @retval 0 for correct memory, 1 for corrupted memory. */
148         int MEM_check_memory_integrity(void);
149
150         /** Set thread locking functions for safe memory allocation from multiple
151             threads, pass NULL pointers to disable thread locking again. */
152         void MEM_set_lock_callback(void (*lock)(void), void (*unlock)(void));
153         
154         /** Attempt to enforce OSX (or other OS's) to have malloc and stack nonzero */
155         void MEM_set_memory_debug(void);
156
157         /** Memory usage stats
158          * - MEM_get_memory_in_use is all memory
159          * - MEM_get_mapped_memory_in_use is a subset of all memory */
160         uintptr_t MEM_get_memory_in_use(void);
161         /** Get mapped memory usage. */
162         uintptr_t MEM_get_mapped_memory_in_use(void);
163         /** Get amount of memory blocks in use. */
164         int MEM_get_memory_blocks_in_use(void);
165
166         /** Reset the peak memory statistic to zero. */
167         void MEM_reset_peak_memory(void);
168
169         /** Get the peak memory usage in bytes, including mmap allocations. */
170         uintptr_t MEM_get_peak_memory(void) WARN_UNUSED;
171
172 /* all memory chunks are put in linked lists */
173 typedef struct localLink
174 {
175         struct localLink *next,*prev;
176 } localLink;
177
178 typedef struct localListBase
179 {
180         void *first, *last;
181 } localListBase;
182
183         /* note: keep this struct aligned (e.g., irix/gcc) - Hos */
184 typedef struct MemHead {
185         int tag1;
186         size_t len;
187         struct MemHead *next,*prev;
188         const char * name;
189         const char * nextname;
190         int tag2;
191         int mmap;       /* if true, memory was mmapped */
192 #ifdef DEBUG_MEMCOUNTER
193         int _count;
194 #endif
195 } MemHead;
196
197 typedef struct MemTail {
198         int tag3, tag4;
199 } MemTail;
200
201 /*memory bias to hopefully account 
202   for allocation overhead from
203   the system allocator.*/
204 #define MEM_OVERHEADBIAS        32
205
206 #define MEM_OVERHEAD    (sizeof(MemHead) + sizeof(MemTail) + MEM_OVERHEADBIAS)
207
208 /*reset the peak memory statistic to zero*/
209 void MEM_reset_peak_memory(void);
210
211 /*get the peak memory usage in bytes, including mmap allocations*/
212 uintptr_t MEM_get_peak_memory(void);
213
214 #ifndef NDEBUG
215 const char *MEM_name_ptr(void *vmemh);
216 #endif
217         
218 #ifdef __cplusplus
219 }
220 #endif
221
222 #endif
223