0
0
mirror of https://gitlab.nic.cz/labs/bird.git synced 2025-01-08 18:11:54 +00:00

If debugging, store a malloc circular log for easier debugging

This commit is contained in:
Maria Matejka 2024-05-31 15:16:41 +02:00 committed by Katerina Kubecova
parent 102cea56f2
commit 1371661156
2 changed files with 30 additions and 1 deletions

View File

@ -179,7 +179,7 @@ void resource_sys_init(void);
#define xrealloc bird_xrealloc #define xrealloc bird_xrealloc
void *xmalloc(unsigned); void *xmalloc(unsigned);
void *xrealloc(void *, unsigned); void *xrealloc(void *, unsigned);
#define xfree(x) free(x) void xfree(void *);
#endif #endif
#endif #endif

View File

@ -10,9 +10,25 @@
#include "nest/bird.h" #include "nest/bird.h"
#include "lib/resource.h" #include "lib/resource.h"
#include "lib/timer.h"
#ifndef HAVE_LIBDMALLOC #ifndef HAVE_LIBDMALLOC
#if DEBUGGING
struct minfo {
void *ptr;
uint size;
uint action;
uint thread_id;
btime time;
} minfo_block[65536];
_Atomic uint minfo_pos;
#define MINFO(p, s, a) minfo_block[atomic_fetch_add_explicit(&minfo_pos, 1, memory_order_acq_rel) % 65536] = (struct minfo) { .ptr = p, .size = s, .action = a, .thread_id = THIS_THREAD_ID, .time = current_time_now(), }
#else
#define MINFO(...)
#endif
/** /**
* xmalloc - malloc with checking * xmalloc - malloc with checking
* @size: block size * @size: block size
@ -26,7 +42,10 @@
void * void *
xmalloc(uint size) xmalloc(uint size)
{ {
void *p = malloc(size); void *p = malloc(size);
MINFO(p, size, 1);
if (p) if (p)
return p; return p;
die("Unable to allocate %d bytes of memory", size); die("Unable to allocate %d bytes of memory", size);
@ -47,9 +66,19 @@ void *
xrealloc(void *ptr, uint size) xrealloc(void *ptr, uint size)
{ {
void *p = realloc(ptr, size); void *p = realloc(ptr, size);
MINFO(ptr, 0, 2);
MINFO(p, size, 3);
if (p) if (p)
return p; return p;
die("Unable to allocate %d bytes of memory", size); die("Unable to allocate %d bytes of memory", size);
} }
void xfree(void *p)
{
MINFO(p, 0, 4);
free(p);
}
#endif #endif