前一两年就调试过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