asterisk 代码调试

阅读更多
   前一两年就调试过asterisk,记下来的资料不知道搞哪去了。
    昨天帮助公司新同事,再试了一次,发现asterisk和以前弄那会还是有一些变化。
调试详细的步骤如下:
    首先,我们需要生成有调试信息的板本。
    进入asterisk代码的目录
    ./configure
    make menuselect
这个地方要输入S
再 make 就可以生成再调试信息的板本。
 
我们要调试的模块是chan_sip.c,由于asterisk这些模块都是动态加载的,所以在
gdb asterisk 的时候是找不到chan_sip.so的调试信息的。
在以前我调试的时候的方法在,在load_dynamic_module处打断点,然后在dlopen的时候单步进入,就可以到chan_sip.c的load_modules
函数,但现在我发现,这也是不行的。
 
所以我换了一种方式:
查看chan_sip.c:load_module的代码
load_module通过调用 ast_channel_register(&sip_tech)在asterisk里面注册一个channel,而ast_channel_register在现在的调试信息里面是可以找到的。
所以从这个地方入手,在ast_channel_register处打断点。
 
在发现是chan_sip.c调用这个函数的时候停下来。
bt 一下,bt为打开函数调用堆栈信息,
看到调用他的上一层函数为chan_sip.c:load_module
然后f 1,切换函数堆栈,然后就可以在chan_sip.c里面打断点了。
 
就可以实现对chan_sip.c的调试。
 
   呵呵,这玩意技术学会了,放在这,好久不用,确实是会手生啊!
lixiaomail
2008-10-24

你可能感兴趣的:(C,C++,C#,F#)