linux 11.26

Translate Kernel Call Trace

General setup  --->   
[*] Configure standard kernel features (for small systems) --->
--- Configure standard kernel features (for small systems)
[*] Load all symbols for debugging/ksymoops
[*] Include all symbols in kallsyms
[ ] Do an extra kallsyms pass (NEW)
our configure
 [*] Load all symbols for debugging/ksymoops
[ ] Include all symbols in kallsyms
[*] Do an extra kallsyms pass

Off course, be sure you have CONFIG_DEBUG_KERNEL (Kernel Hacking->Kernel Debugging) also enabled.

http://forum.kernelnewbies.org/read.php?7,2102

 

 

使用这些方法中的任意一个来获得内核例程 的地址:

  1. 从 System.map 文件直接得到地址。
    例如,要得到 do_fork 的地址,可以在命令行执行 $grep do_fork /usr/src/linux/System.map
  2. 使用 nm 命令。
    $nm vmlinuz |grep do_fork
  3. 从 /proc/kallsyms 文件获得地址。
    $cat /proc/kallsyms |grep do_fork
  4. 使用 kallsyms_lookup_name() 例程。
    这个例程是在 kernel/kallsyms.c 文件中定义的,要使用它,必须启用 CONFIG_KALLSYMS 编译内核。 kallsyms_lookup_name() 接受一个字符串格式内核例程名, 返回那个内核例程的地址。例如: kallsyms_lookup_name("do_fork");

 

kprobe : collecting debug and performance information

http://forum.kernelnewbies.org/read.php?7,1658

Linux 下的一个全新的性能测量和调式诊断工具 Systemtap

http://www.ibm.com/developerworks/cn/linux/l-cn-systemtap3/index.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值