Hi, I am seeing a crash in the debugger module. It looks similar to http://sip-router.org/tracker/index.php?do=details&task_id=423 but is reproducible on shutdown. I am running latest 4.2.4. It looks like the 'get_debug_level' function is called after the debugger module has been destroyed. Do we need to unset the per-module callback from the mod_destroy function (e.g. with set_module_debug_level_cb(NULL))?
Details of crash:
loadmodule "debugger.so" # ----- debugger params ----- modparam("debugger", "mod_level_mode", 1) modparam("debugger", "mod_hash_size", 5)
(gdb) bt full #0 0x00007f24e9572990 in dbg_get_mod_debug_level (mname=0x6f9974 "core", mnlen=4, mlevel=0x7fffe76051ac) at debugger_api.c:1224 idx = 14 hid = 1863578990 it = 0x0 #1 0x000000000046dd00 in get_debug_level (mname=0x6f9974 "core", mnlen=4) at dprint.c:137 mlevel = 3 #2 0x000000000049f6f0 in handle_sigs () at main.c:803 chld = -1 chld_status = 0 memlog = -748755048 __FUNCTION__ = "handle_sigs" #3 0x00000000004a6fbf in main_loop () at main.c:1757 i = 4 pid = 20691 si = 0x0 si_desc = "udp receiver child=3 sock=10.62.18.63:5060\000\000\000\000\000\000\016\b\000\000\377\177\000\000\260\344^\323$\177\000\000\000\000\000\020\004\000\000\000\260\344^\323$\177\000\000\060SA\000\000\000\000\000\000W`\347\001\000\000\000\220T`\347\377\177\000\000>dN\000\000\000\000\000\210q(\352z\000\000\000~~p\000\000\000\000" nrprocs = 4 __FUNCTION__ = "main_loop" #4 0x00000000004ab8e3 in main (argc=13, argv=0x7fffe7605708) at main.c:2581 cfg_stream = 0xc56010 c = -1 r = 0 tmp = 0x7fffe7605f64 "" tmp_len = 0 port = 0 proto = 32767 options = 0x6fccc0 ":f:cm:M:dVIhEeb:l:L:n:vKrRDTN:W:w:t:u:g:P:G:SQ:O:a:A:" ret = -1 seed = 1220709785 rfd = 4 debug_save = 0 debug_flag = 0 dont_fork_cnt = 0 n_lst = 0xbf p = 0x7fffe76055de "" __FUNCTION__ = "main" (gdb) list 1219 * - use fprintf(stderr, ...) if need for troubleshooting 1220 * - it will loop otherwise */ 1221 if(_dbg_mod_table==NULL) 1222 return -1; 1223 1224 if(cfg_get(dbg, dbg_cfg, mod_level_mode)==0) 1225 return -1; 1226 1227 if(_dbg_get_mod_debug_level!=0) 1228 return -1; (gdb) p dbg_cfg $1 = (void *) 0x7f24d386298c (gdb) p *(struct cfg_group_dbg*)dbg_cfg Cannot access memory at address 0x7f24d386298c ________________________________ This e-mail and any attachment is for authorised use by the intended recipient(s) only. It may contain proprietary material, confidential information and/or be subject to legal privilege. It should not be copied, disclosed to, retained or used by, any other party. If you are not an intended recipient then please promptly delete this e-mail and any attachment and all copies and inform the sender. Thank you for understanding.