[sr-dev] git:master:7c9a8794: mem/q_malloc: more details in the logs from qm_debug_frag()
Daniel-Constantin Mierla
miconda at gmail.com
Wed Oct 28 14:20:03 CET 2015
Module: kamailio
Branch: master
Commit: 7c9a87948d9db5be511e94877c1eb3cdc411622c
URL: https://github.com/kamailio/kamailio/commit/7c9a87948d9db5be511e94877c1eb3cdc411622c
Author: Alex Dowad <alexinbeijing at gmail.com>
Committer: Daniel-Constantin Mierla <miconda at gmail.com>
Date: 2015-10-28T14:18:59+01:00
mem/q_malloc: more details in the logs from qm_debug_frag()
- print file and line from where the memory operation was triggered
- makes it easier to troubleshoot and find the location in the code
---
Modified: mem/q_malloc.c
---
Diff: https://github.com/kamailio/kamailio/commit/7c9a87948d9db5be511e94877c1eb3cdc411622c.diff
Patch: https://github.com/kamailio/kamailio/commit/7c9a87948d9db5be511e94877c1eb3cdc411622c.patch
---
diff --git a/mem/q_malloc.c b/mem/q_malloc.c
index 0c23639..46b0c3a 100644
--- a/mem/q_malloc.c
+++ b/mem/q_malloc.c
@@ -112,32 +112,37 @@ inline static unsigned long big_hash_idx(unsigned long s)
#define END_CHECK_PATTERN2 0xabcdefed
-static void qm_debug_frag(struct qm_block* qm, struct qm_frag* f)
+static void qm_debug_frag(struct qm_block* qm, struct qm_frag* f,
+ const char* file, unsigned int line)
{
if (f->check!=ST_CHECK_PATTERN){
LOG(L_CRIT, "BUG: qm_*: fragm. %p (address %p) "
- "beginning overwritten(%lx)!\n",
+ "beginning overwritten (%lx)! Memory allocator was called "
+ "from %s:%u. Fragment marked by %s:%lu.\n",
f, (char*)f+sizeof(struct qm_frag),
- f->check);
+ f->check, file, line, f->file, f->line);
qm_status(qm);
abort();
};
if ((FRAG_END(f)->check1!=END_CHECK_PATTERN1)||
(FRAG_END(f)->check2!=END_CHECK_PATTERN2)){
- LOG(L_CRIT, "BUG: qm_*: fragm. %p (address %p)"
- " end overwritten(%lx, %lx)!\n",
+ LOG(L_CRIT, "BUG: qm_*: fragm. %p (address %p) "
+ "end overwritten (%lx, %lx)! Memory allocator was called "
+ "from %s:%u. Fragment marked by %s:%lu.\n",
f, (char*)f+sizeof(struct qm_frag),
- FRAG_END(f)->check1, FRAG_END(f)->check2);
+ FRAG_END(f)->check1, FRAG_END(f)->check2,
+ file, line, f->file, f->line);
qm_status(qm);
abort();
}
if ((f>qm->first_frag)&&
((PREV_FRAG_END(f)->check1!=END_CHECK_PATTERN1) ||
(PREV_FRAG_END(f)->check2!=END_CHECK_PATTERN2) ) ){
- LOG(L_CRIT, "BUG: qm_*: prev. fragm. tail overwritten(%lx, %lx)[%p:%p]!"
- "\n",
+ LOG(L_CRIT, "BUG: qm_*: prev. fragm. tail overwritten(%lx, %lx)[%p:%p]! "
+ "Memory allocator was called from %s:%u. Fragment marked by "
+ "%s:%lu.\n",
PREV_FRAG_END(f)->check1, PREV_FRAG_END(f)->check2, f,
- (char*)f+sizeof(struct qm_frag));
+ (char*)f+sizeof(struct qm_frag), file, line, f->file, f->line);
qm_status(qm);
abort();
}
@@ -370,7 +375,7 @@ void* qm_malloc(void* qmp, unsigned long size)
/* we found it!*/
/*detach it from the free list*/
#ifdef DBG_QM_MALLOC
- qm_debug_frag(qm, f);
+ qm_debug_frag(qm, f, file, line);
#endif
qm_detach_free(qm, f);
/*mark it as "busy"*/
@@ -453,7 +458,7 @@ void qm_free(void* qmp, void* p)
f=(struct qm_frag*) ((char*)p-sizeof(struct qm_frag));
#ifdef DBG_QM_MALLOC
- qm_debug_frag(qm, f);
+ qm_debug_frag(qm, f, file, line);
if (f->u.is_free){
LOG(L_CRIT, "BUG: qm_free: freeing already freed pointer (%p),"
" called from %s: %s(%d), first free %s: %s(%ld) - aborting\n",
@@ -487,7 +492,7 @@ void qm_free(void* qmp, void* p)
if (((char*)next < (char*)qm->last_frag_end) && (next->u.is_free)){
/* join next packet */
#ifdef DBG_QM_MALLOC
- qm_debug_frag(qm, next);
+ qm_debug_frag(qm, next, file, line);
#endif
qm_detach_free(qm, next);
size+=next->size+FRAG_OVERHEAD;
@@ -503,7 +508,7 @@ void qm_free(void* qmp, void* p)
if (prev->u.is_free){
/* join prev packet */
#ifdef DBG_QM_MALLOC
- qm_debug_frag(qm, prev);
+ qm_debug_frag(qm, prev, file, line);
#endif
qm_detach_free(qm, prev);
size+=prev->size+FRAG_OVERHEAD;
@@ -575,7 +580,7 @@ void* qm_realloc(void* qmp, void* p, unsigned long size)
#endif
f=(struct qm_frag*) ((char*)p-sizeof(struct qm_frag));
#ifdef DBG_QM_MALLOC
- qm_debug_frag(qm, f);
+ qm_debug_frag(qm, f, file, line);
MDBG("qm_realloc: realloc'ing frag %p alloc'ed from %s: %s(%ld)\n",
f, f->file, f->func, f->line);
if (f->u.is_free){
More information about the sr-dev
mailing list