gdb调节和测量检验之linux pc和linux arm境遇下分分快

作者:电脑系统

(1)确保arm开发板与主机支持nfs功能,设置开发板和主机在同一网段,并设置共享目录(如/mnt/nfs)。

gcc -g test.c -o test (设置gdb调试)

(gdb)bt(backtrace信息出现)

2、设置产生**core文件大小**

arm-linux-gdb test

./gdbserver 10.10.51.47:5000 test

(默认不会现实PID信息,可通过以下命令修改此文件:  echo "1" > /proc/sys/kernel/core_uses_pid , 这样每次程序挂了之后会生成类似 core.8909(8909是当时的进程号), 效果就是后续生成的core文件不会覆盖之前生成的core文件。)

(2)将编译器对应该的gdbserver和test(可执行文件)拷贝到共享目录(/mnt/nfs),修改应用程序和 gdbserver权限为777.

set solib-absolute-prefix与set solib-search-path命令分别用于设置GDB共享库查找路径前缀与共享库查找路径,以阻止GDB查找宿主机上的库。若不指定这些路径,远程调试过程中GDB加载了宿主机的库,会出现诸如“warning: GDB can't find the start of the function at 0x******”与“Cannot find bounds of current function”等错误提示。

4、构建GDB GDB server nfs调试方法

1、查看core文件参数

4、使用gdb调试core文件之前操作

gdb --core=core.PID

文章主要主要来自参考、总结和实践。

yinkui@yinkui-desktop:~/File_unzip/cp_module$ ulimit -a

(5)在主机目录下运行可执行程序:

data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 31042
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 1024
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192        //应用程序栈大小
cpu time               (seconds, -t) unlimited
max user processes              (-u) 31042
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

3、产生段错误之后,查看进程信息

5、使用gdb调试core文件

查看core文件信息:file core

data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 31042
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 1024
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 31042
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

ulimit -c unlimited(不限制core文件的大小)

(可直接使用命令:ulimit -a; ulimit -c unlimited;ulimit -a;echo "1" > /proc/sys/kernel/core_uses_pid)

(3)通过telnet或者minicom登陆到开发板,挂在nfs文件系统:mount -t nfs 主机IP:/mnt/nfs(共享目录) /home/root/modbus_rtu_slave(开发板目录) -o nolock

Linux PC应用程序gdb调试:

(4)进入共享目录 运行gdbserver建立远程调试server(格式为: ./gdbserver 主机IP:建立连接的端口号 可执行文件【其中端口号一般1024以上没有占用即可】,如下)

(gdb)file ./a.out(运行程序)

(默认不会现实PID信息,可通过以下命令修改此文件:  echo "1" > /proc/sys/kernel/core_uses_pid , 这样每次程序挂了之后会生成类似 core.8909(8909是当时的进程号), 效果就是后续生成的core文件不会覆盖之前生成的core文件。)

core file size          (blocks, -c) 0        //产生core文件数目,不会产生core文件

3、编译程序选项

ls -l core.*

2、设置产生**core文件大小**

 

(gdb)bt(第一次不会出现堆栈信息)

注释:

core file size          (blocks, -c) 0        //产生core文件数目,不会产生core文件

 

---》target remote 10.10.51.33:5000    (进入gdb调试后运行命令,连接gdbserver)

 

1、查看core文件参数
yinkui@yinkui-desktop:~/File_unzip/cp_module$ ulimit -a

ulimit -c unlimited(不限制core文件的大小)

Linux arm应用程序arm-XXXX-gdb调试:

加入gdb可调试选项 arm-linux-XXX -g test.c -o test

本文由分分快三计划发布,转载请注明来源

关键词: 分分快三计划