8 /* FIXME: make allocation dynamic */
11 #ifdef IMAGER_DEBUG_MALLOC
22 static int malloc_need_init = 1;
30 malloc_entry malloc_pointers[MAXMAL];
35 /* Utility functions */
42 for(i=0; i<MAXMAL; i++) malloc_pointers[i].ptr = NULL;
53 if (malloc_pointers[i].ptr == p)
59 /* Takes a pointer to real start of array,
60 * sets the entries in the table, returns
61 * the offset corrected pointer */
65 set_entry(int i, char *buf, size_t size, char *file, int line) {
66 memset( buf, PADBYTE, UNDRRNVAL );
67 memset( &buf[UNDRRNVAL+size], PADBYTE, OVERRNVAL );
69 malloc_pointers[i].ptr = buf;
70 malloc_pointers[i].size = size;
71 sprintf(malloc_pointers[i].comm,"%s (%d)", file, line);
83 mm_log((0,"malloc_state()\n"));
85 for(i=0; i<MAXMAL; i++) if (malloc_pointers[i].ptr != NULL) {
86 mm_log((0,"%d: %d (0x%x) : %s\n", i, malloc_pointers[i].size, malloc_pointers[i].ptr, malloc_pointers[i].comm));
87 total += malloc_pointers[i].size;
89 if (total == 0) mm_log((0,"No memory currently used!\n"))
90 else mm_log((0,"total: %d\n",total));
96 mymalloc_file_line(size_t size, char* file, int line) {
99 if (malloc_need_init) malloc_init();
101 /* bndcheck_all(); Uncomment for LOTS OF THRASHING */
103 if ( (i = find_ptr(NULL)) < 0 ) {
104 mm_log((0,"more than %d segments allocated at %s (%d)\n", MAXMAL, file, line));
108 if ( (buf = malloc(size+UNDRRNVAL+OVERRNVAL)) == NULL ) {
109 mm_log((1,"Unable to allocate %i for %s (%i)\n", size, file, line));
113 buf = set_entry(i, buf, size, file, line);
114 mm_log((1,"mymalloc_file_line: slot <%d> %d bytes allocated at %p for %s (%d)\n", i, size, buf, file, line));
125 myrealloc_file_line(void *ptr, size_t newsize, char* file, int line) {
129 if (malloc_need_init) malloc_init();
130 /* bndcheck_all(); ACTIVATE FOR LOTS OF THRASHING */
133 mm_log((1, "realloc called with ptr = NULL, sending request to malloc\n"));
134 return mymalloc_file_line(newsize, file, line);
138 mm_log((1, "newsize = 0, sending request to free\n"));
139 myfree_file_line(ptr, file, line);
143 if ( (i = find_ptr(ptr)) == -1) {
144 mm_log((0, "Unable to find %p in realloc for %s (%i)\n", ptr, file, line));
148 if ( (buf = realloc(((char *)ptr)-UNDRRNVAL, UNDRRNVAL+OVERRNVAL+newsize)) == NULL ) {
149 mm_log((1,"Unable to reallocate %i bytes at %p for %s (%i)\n", newsize, ptr, file, line));
153 buf = set_entry(i, buf, newsize, file, line);
154 mm_log((1,"realloc_file_line: slot <%d> %d bytes allocated at %p for %s (%d)\n", i, newsize, buf, file, line));
165 size_t s = malloc_pointers[idx].size;
166 unsigned char *pp = malloc_pointers[idx].ptr;
168 mm_log((1, "bndcheck: No pointer in slot %d\n", idx));
172 for(i=0;i<UNDRRNVAL;i++)
173 if (pp[-(1+i)] != PADBYTE)
174 mm_log((1,"bndcheck: UNDERRUN OF %d bytes detected: slot = %d, point = %p, size = %d\n", i+1, idx, pp, s ));
176 for(i=0;i<OVERRNVAL;i++)
177 if (pp[s+i] != PADBYTE)
178 mm_log((1,"bndcheck: OVERRUN OF %d bytes detected: slot = %d, point = %p, size = %d\n", i+1, idx, pp, s ));
184 mm_log((1, "bndcheck_all()\n"));
185 for(idx=0; idx<MAXMAL; idx++)
186 if (malloc_pointers[idx].ptr)
195 myfree_file_line(void *p, char *file, int line) {
200 for(i=0; i<MAXMAL; i++) if (malloc_pointers[i].ptr == p) {
201 mm_log((1,"myfree_file_line: pointer %i (%s) freed at %s (%i)\n", i, malloc_pointers[i].comm, file, line));
203 malloc_pointers[i].ptr = NULL;
208 mm_log((1, "myfree_file_line: INCONSISTENT REFCOUNT %d at %s (%i)\n", match, file, line));
209 fprintf(stderr, "myfree_file_line: INCONSISTENT REFCOUNT %d at %s (%i)\n", match, file, line);
213 mm_log((1, "myfree_file_line: freeing address %p (real %p)\n", pp, pp-UNDRRNVAL));
220 #define malloc_comm(a,b) (mymalloc(a))
224 printf("malloc_state: not in debug mode\n");
231 if ( (buf = malloc(size)) == NULL ) {
232 mm_log((1, "mymalloc: unable to malloc %d\n", size));
233 fprintf(stderr,"Unable to malloc %d.\n", size); exit(3);
235 mm_log((1, "mymalloc(size %d) -> %p\n", size, buf));
241 mm_log((1, "myfree(p %p)\n", p));
246 myrealloc(void *block, size_t size) {
249 mm_log((1, "myrealloc(block %p, size %u)\n", block, size));
250 if ((result = realloc(block, size)) == NULL) {
251 mm_log((1, "myrealloc: out of memory\n"));
252 fprintf(stderr, "Out of memory.\n");
258 #endif /* IMAGER_MALLOC_DEBUG */
263 /* memory pool implementation */
266 i_mempool_init(i_mempool *mp) {
269 mp->p = mymalloc(sizeof(void*)*mp->alloc);
273 i_mempool_extend(i_mempool *mp) {
274 mp->p = myrealloc(mp->p, mp->alloc * 2);
279 i_mempool_alloc(i_mempool *mp, size_t size) {
280 if (mp->used == mp->alloc) i_mempool_extend(mp);
281 mp->p[mp->used] = mymalloc(size);
283 return mp->p[mp->used-1];
288 i_mempool_destroy(i_mempool *mp) {
290 for(i=0; i<mp->used; i++) myfree(mp->p[i]);
296 /* Should these really be here? */
303 if (a<b) return a; else return b;
308 if (a>b) return a; else return b;