免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4436 | 回复: 5
打印 上一主题 下一主题

KLD模块崩溃使用savecore生成的vmcore文件调试无法导入symbol的问题(问题已解决) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-02-01 14:25 |只看该作者 |倒序浏览
系统是freebsd4.11
kld中出现空指针之类的异常导致内核崩溃,生成了coredump,使用gdb调试,bt命令查看栈信息,部分symbol读取不到,使用add-symbol-file加载以后仍然无法查看. 用户态程序用add-symbol-file加载以后就可以查看了. 不知道KLD模块为什么不行.加载命令如下:
add-symbol-file  xxx/xxx/xxx.ko text段起始地址
text段起始地址是 objdump -h xxx.ko | grep text 得到的.如下所示,取第4个字节00006e28.
8 .text         0000c9ac  00006e28  00006e28  00006e28  2**2

哪位高手可以指教一下问题出在哪里,没有这个symbol太不方便了,搞得我只能对着汇编查错误.

问题原因:
add-symbol-file  xxx/xxx/xxx.ko text段起始地址
这个起始地址需要是kldstat中看到的模块加载地址加上场面查到的00006e28.

[ 本帖最后由 yj1804 于 2007-2-1 15:54 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2007-02-01 14:30 |只看该作者
内核崩溃会coredump?是不是说savecore( 8 ) ?

论坛徽章:
0
3 [报告]
发表于 2007-02-01 14:31 |只看该作者
对,就是用savecore

论坛徽章:
0
4 [报告]
发表于 2007-02-01 14:42 |只看该作者
没这个调过kld,google下吧.
http://people.freebsd.org/~jmg/
上面有个脚本.
另外,ms设置某个路径后会自动加载kld的符号,有空看看.

[ 本帖最后由 mingyanguo 于 2007-2-1 14:44 编辑 ]

论坛徽章:
0
5 [报告]
发表于 2007-02-01 15:45 |只看该作者
晕倒,上面得.SH脚本下载不了了

论坛徽章:
0
6 [报告]
发表于 2007-06-15 17:34 |只看该作者
add-symbol-file  xxx/xxx/xxx.ko addr
这个addr是该模块text段起始地址,应该这样得到:
1 用kldstat查看该模块加载的初始地址
2 用objdump查看text偏移
两者相加才是这个addr
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP