gdb+gdbserver远程调试环境搭建及调试_gdb server(1)

cd gdb-7.12/                                                                             //进入源码目录

mkdir /usr/local/arm-gdb                                                            //创建一个安装目录

./configure --target=arm-linux --prefix=/usr/local/arm-gdb      //执行配置文件

注意:

–target: 指定编译环境,一般设置为交叉编译器前缀。

–prefix:指定安装路径,可自己任意指定合法路径

(3)编译与安装

make                //编译

make install     //安装

安装结束后会在你指定的安装目录下生成三个文件夹,里面包含可执行文件、头文件、动态库文件等,如下图所示:

(4)填加到环境变量

将生成的bin文件添加到环境变量中:

vim /etc/profile

export PATH=$PATH:/usr/local/arm-gdb/bin        //添加在文件末尾

source /etc/profile           //生效环境变量

echo $PATH         //检查环境变量

注意:

(1)你也可以放在其它环境变量下,例如:/usr/local/bin、/usr/bin等

(2)生成的文件可删除不需要用到的,比如,此处只需要使用arm-linu-gdb可执行文件,则你可只需将此文件添加到环境变量即可,其他文件可直接删除。

4、安装gdbserver

(1)生成Makefile

cd gdb-7.12/gdb/gdbserver/                                                     //进入源码目录

./configure --target=arm-linux-gnueabi --host=arm-linux    //执行配置文件

注意:

–target:指定目标平台,博主的目标平台为ARM。

–host:   指定宿主机运行的是arm-linux-gdb

(2)编译与安装

make

编译gdbserver不需要执行make install命令,因为make之后在当前目录下会生成可执行程序gdbserver。

(3)拷贝到目标平台

拷贝之前先更改gdbserver读写权限:chmod 777 gdbserver

将可执行文件gdbserver拷贝到目标平台的**/usr/local/bin/**目录下。

至此,远程调试环境已经搭建完成。

5、gdb+gdbserver调试流程

(1)检查网络是否正常

打开MobaXterm登入虚拟机和开发板的Linux系统,执行如下操作:

开发板ping主机

开发板ping虚拟机

主机ping开发板

虚拟机ping开发板

保证相互之间均可以ping通。

注意:主机ip、开发板ip和虚拟机ip地址设置在同一个网段内。

(2)编辑和编译测试代码

1)测试代码

#include
#include

using namespace std;

void fun(int &a, int &b)
{
     a = b = 10;
}

void my_fun(int &a, int &b)
{

a > b ? (a += b) : (b -= a);

fun(a, b);
 }
 
int main()
{

int a = 13, b = 16;

my_fun(a,b);

cout<< "a = " << a << endl;
    cout<< "b = " << b << endl;

return(0);
}

2)编译代码

-g : 设置带调试信息的程序

3)设置读写权限

修改可执行二进制文件test读写权限:chmod 777 test

4)下载文件到开发板

下载可执行二进制文件到开发板的工作目录下。(自己指定一个合法的工作目录)

文件下载方法:在Linux系统编译好的可执行文件先下载到window,然后再从window下载到开发板。(下载操作方式众多,选择自己习惯的就行)

(3)启动调试环境

宿主机IP:192.168.xxx.xxx
开发板IP:192.168.xxx.xxx

1)开发板上运行gdbserver

gdbserver 192.168.xxx.xxx:2001 test

其中 192.168.xxx.xxx 是宿主机的地址,2001是调试端口(该值建议设在2000以上),test是需要调试的可执行程序。gdbserver启动之后打印出下面内容:

2)执行gdbserver脚本

以上操作也可以通过自己编写一个shell脚本去执行,如下:

该脚本执行时需要输入一个参数,即需要调试的可执行文件名。执行时如果没有输入参数会有一个提示信息打印。执行命令如下:

./gdbserver test      //这样就不需要每次都输入宿主机IP和端口号等信息了,直接执行脚本就搞定。

3)宿主机上运行arm-linux-gdb

arm-linux-gdb test

启动之后会打印如下信息:

最后一行(gdb) 表示arm-linux-gdb在等待输入指令,现在需要输入指令来连接gdbserver,如下所示:

(gdb) target remote 192.168.xxx.xxx:2001

其中 192.168.xxx.xxx 是开发板的IP地址,2001是调试端口(必须与gdbserver端保持一致)

4).gdbinit脚本

每次启动gdb时都要在gdb命令行上手动输入指令,去连接目标机,操作上显得及其麻烦。而使用.gdbinit脚本则可以轻松解决此事。

gdb在启动的时候,会在你的当前工作目录下查找 ".gdbinit" 这个文件,并把它的内容作为gdb命令进行解释,所以如果我把脚本命名为".gdbinit",这样在启动的时候就会处理一些你常用的命令。

**第一步:**在”~"目录下添加一个.gdbinit, 默认gdb初始化时会调用这个文件。

**第二步:**编辑该.gdbinit, 在文件中加上 set auto-load safe-path xxx

set auto-load safe-path  /home/tanglg/workspace_tlg/
指定了/home/tanglg/workspace_tlg/路径为gdb的安全加载路径,即后续你可在该路径下的任何子路径下均可加载.gdbinit文件并解释文件内容。

如果不在“~”目录下指定一个安全路径的话,会在使用.gdbinit时,报如下错误:

File “/home/tanglg/workspace_tlg/myapp/test/.gdbinit” auto-loading has been declined by your `auto-load safe-path’ set to “ d e b u g d i r : debugdir: debugdir:datadir/auto-load”.

**第三步:**在/home/tanglg/workspace_tlg/myapp/test/(即你要Debug的目录)下,同样添加一个.gdbinit

**第四步:**编辑该.gdbinit,添加你需要的一些指令,例如:

当然在.gdbinit文件中你还可以添加别的指令。

.gdbinit编写好并保存后,你就可以直接输入arm-linux-gdb test 开始gdb调试了,中途就不用再次主动去连接目标机的gdbserver了。如果你需要更改目标机的IP和端口号,只需修改.gdbinit文件。

至此开发板和虚拟机(宿主机)远程连接起来了。

(4)开始调试

建立链接后,就可以进行调试了。调试在宿主机端,跟gdb调试方法相同。注意的是要用“c”来执行命令,不能用“r”。因为程序已经在Target Board上面由gdbserver启动了,结果输出是在Target Board端,用SSH(或超级终端)查看。

按”c“全速运行后,在目标端查看运行结果:

至此,远程调试环境和调试步骤结束。

(5)调试常用命令

c      -->    continue的缩写,作用是程序继续往下执行。

l      -->     list的缩写,作用是查看程序代码,按回车可显示剩余未显示的代码。

b    -->      break的缩写,作用是设置断点。如:b xxx.cpp:4表示在xxx.cpp的4行设置断点。

b i  -->      break info的缩写,作用是查看所有断点信息。

q    -->     quit的缩写,作用是退出调试

6、安装调试中遇到的问题

(1)‘__NR_sigreturn’ was not declared in this scope

安装交叉编译器gdbserver 可能报该错:

解决方案:

//在这个linux-arm-low.c文件添加如下内容:

#ifndef __NR_sigreturn

#include <asm/unistd.h>

#endif

如果仍然不行,则再加上#define**__NR_sigreturn 0**

(2)Remote ‘g’ packet reply is too long: 40100100dc890000acfdffbe问题

在gdb调试过程中可能出现如下图所示错误:

解决方案:

修改gdb/remote.c文件,屏蔽process_g_packet函数中的下列两行:

if (buf_len > 2 * rsa->sizeof_g_packet)
     error (_(“Remote ‘g’ packet reply is too long: %s”), rs->buf);

在其后添加:

if (buf_len > 2 * rsa->sizeof_g_packet) {
      rsa->sizeof_g_packet = buf_len ;
      for (i = 0; i < gdbarch_num_regs (gdbarch); i++)
      {
         if (rsa->regs[i].pnum == -1)
         continue;

         if (rsa->regs[i].offset >= rsa->sizeof_g_packet)
         rsa->regs[i].in_g_packet = 0;
         else
         rsa->regs[i].in_g_packet = 1;
      }
   }

(3)arm-linux-gdb加载目标系统库出错

arm-linux-gdb在调试的时候会加载目标系统的库文件,如果出错时便无法调试,如下图所示:

解决方案:

可通过指令[set solib-search-path+库文件路径]来手动加载目标系统库文件,如下为我的设置:

set solib-search-path /usr/local/arm/4.4.3/arm-none-linux-gnueabi/lib/

(4)Reading symbols from target:/lib/ld-linux.so.3…(no debugging symbols found)…done.问题

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年嵌入式&物联网开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上嵌入式&物联网开发知识点,真正体系化!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新!!

.(img-3Xdry2qf-1715575401091)]

[外链图片转存中…(img-mjtqzCJN-1715575401092)]

[外链图片转存中…(img-flwMUpk4-1715575401092)]

[外链图片转存中…(img-ZKjQCSpF-1715575401093)]

[外链图片转存中…(img-mKvDfQvQ-1715575401094)]

[外链图片转存中…(img-t8Cc4sAJ-1715575401094)]

[外链图片转存中…(img-GEk8jsZ7-1715575401095)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上嵌入式&物联网开发知识点,真正体系化!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新!!

  • 16
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值