Chinaunix首页 | 论坛 | 博客
  • 博客访问: 252643
  • 博文数量: 58
  • 博客积分: 2241
  • 博客等级: 大尉
  • 技术积分: 522
  • 用 户 组: 普通用户
  • 注册时间: 2009-08-07 09:53
文章分类
文章存档

2012年(4)

2011年(19)

2010年(31)

2009年(4)

分类:

2010-03-15 11:33:54

一、简介

在一个程序崩溃时,它一般会在指定目录下生成一个core文件。core文件仅仅是一个内存映象(同时加上调试信息),主要是用来调试的。

GDB就是查看core文件的工具。

二、操作步骤

1. 设置core文件大小

系统默认core文件大小为0,既不生产core文件,我们这里把core文件大小设为unlimited,也就是不限制其大小。

ulimit -c unlimited

2. 设置core生成目录及名字

    若系统生成的core文件不带其它任何扩展名称,则全部命名为core。新的core文件生成将覆盖原来的core文件。
1)/proc/sys/kernel/core_uses_pid可以控制core文件的文件名中是否添加pid作为扩展。文件内容为1,表示添加pid作为扩展名,生成的core文件格式为core.xxxx;为0则表示生成的core文件同一命名为core。
可通过以下命令修改此文件:
echo "1" > /proc/sys/kernel/core_uses_pid
2)proc/sys/kernel/core_pattern可以控制core文件保存位置和文件名格式。
可通过以下命令修改此文件:
echo "/corefile/core-%e-%p-%t" > core_pattern,可以将core文件统一生成到/corefile目录下,产生的文件名为core-命令名-pid-时间戳
以下是参数列表:
    %p - insert pid into filename 添加pid
    %u - insert current uid into filename 添加当前uid
    %g - insert current gid into filename 添加当前gid
    %s - insert signal that caused the coredump into the filename 添加导致产生core的信号
    %t - insert UNIX time that the coredump occurred into filename 添加core文件生成时的unix时间
    %h - insert hostname where the coredump happened into filename 添加主机名
    %e - insert coredumping executable name into filename 添加命令名

系统默认core文件和应用程序在同一目录,且文件名为core;我们可以通过修改配置把core放在优盘下,例如/mnt/usb/sda1/,文件名规则为core-命令名-pid-时间戳。

echo "/mnt/usb/sda1/core-%e-%p-%t" > /proc/sys/kernel/core_pattern

以上两条命令也可以写在脚本里,用在自动启动时的调试。

3.GDB调试

拷贝core文件到虚拟机下的应用程序目录(目前只能通过U盘),然后通过如下命令查看core中调试信息。

例子应用程序名为:dvbs2;core文件名为:core-xxx

mipsel-uclibc-gdb dvbs2 /*启动GDB*/

(gdb)core core-xxx 

(gdb)bt

或者

mipsel-uclibc-gdb dvbs2 core-xxx

(gdb)bt

----------------------------------------------------------------

注意:待调试的可执行文件,在编译的时候需要加-g,core文件才能正常显示出错信息!

----------------------------------------------------------------

阅读(1710) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~