gdbServer + gdb 调试

内容摘要 远程调试环境由宿主机GDB和目标机调试stub共同构成,两者通过串口或TCP连接。使用 GDB标准程串行协议协同工作,实现对目标机上的系统内核和上层应用的监控和调试功能。调试stub是嵌入式系统中的一段代码,作为宿主机GDB和目标机调试程序间的一个媒介而存在。 就目前而言,嵌入式Linux系统中,主要有三种远程调试方法,分别适用于不同场合的调试工作:用ROM Monitor调试目标机程序、用KGDB调试系统内核和用gdbserver调试用户空间程序。这三种调试方法的区别主要在于,目标机远程调试stub 的存在形式的不同,而其设计思路和实现方法则是大致相同的。 而我们最常用的是调试应用程序。就是采用gdb+gdbserver的方式进行调试。在很多情况下,用户需要对一个应用程序进行反复调试,特别是复杂的程序。采用GDB方法调试,由于嵌入式系统资源有限性,一般不能直接在目标系统上进行调试,通常采用gdb+gdbserver的方式进行调试。

 

gdb的简单使用

GDB是GNU开源组织发布的一个强大的UNIX下的程序调试工具。或许,各位比较喜欢那种图形界面方式的,像VC、BCB等IDE的调试,但如果你是在 UNIX平台下做软件,你会发现GDB这个调试工具有比VC、BCB的图形化调试器更强大的功能。所谓“寸有所长,尺有所短”就是这个道理。一般来说,GDB主要帮忙你完成下面四个方面的功能:      1、启动你的程序,可以按照你的自定义的要求随心所欲的运行程序。
     2、可让被调试的程序在你所指定的调置的断点处停住。(断点可以是条件表达式)
     3、当程序被停住时,可以检查此时你的程序中所发生的事。
     4、动态的改变你程序的执行环境。从上面看来,GDB和一般的调试工具没有什么两样,基本上也是完成这些功能,不过在细节上,你会发现GDB这个调试工具的强大,大家可能比较习惯了图形化的调试工具,但有时候,命令行的调试工具却有着图形化工具所不能完成的功能。让我们一一看来。
一个调试示例
—————— 源程序:tst.c       1 #include <stdio.h>
      2
      3 int func(int n)
      4 {
      5          int sum=0,i;
      6          for(i=0; i<n; i++)
      7          {
      8                  sum+=i;
      9          }
     10          return sum;
     11 }
     12
     13
     14 main()
     15 {
     16          int i;
     17          long result = 0;
     18          for(i=1; i<=100; i++)
     19          {
     20                  result += i;
     21          }
     22
     23         printf("result[1-100] = %d \\n", result );
     24         printf("result[1-250] = %d \\n", func(250) );
     25 } 编译生成执行文件:(Linux下)
     hchen/test> cc -g tst.c -o tst 使用GDB调试: hchen/test> gdb tst   <---------- 启动GDB
GNU gdb 5.1.1
Copyright 2002 Free Software Foundation, Inc.
GDB is free software, covered by the GNU General Public License, and you are
welcome to change it and/or distribute copies of it under certain conditions.
Type "show copying" to see the conditions.
There is absolutely no warranty for GDB.   Type "show warranty" for details.
This GDB was configured as "i386-suse-linux"...
(gdb) l      <-------------------- l命令相当于list,从第一行开始例出原码。
1         #include <stdio.h>
2
3         int func(int n)
4         {
5                 int sum=0,i;
6                 for(i=0; i<n; i++)
7                 {
8                         sum+=i;
9                 }
10                return sum;
(gdb)        <-------------------- 直接回车表示,重复上一次命令
11        }
12
13
14        main()
15        {
16                int i;
17                long result = 0;
18                for(i=1; i<=100; i++)
19                {
20                        result += i;    
(gdb) break 16     <-------------------- 设置断点,在源程序第16行处。
Breakpoint 1 at 0x8048496: file tst.c, line 16.
(gdb) break func   <-------------------- 设置断点,在函数func()入口处。
Breakpoint 2 at 0x8048456: file tst.c, line 5.
(gdb) info break   <-------------------- 查看断点信息。
Num Type            Disp Enb Address     What
1    breakpoint      keep y    0x08048496 in main at tst.c:16
2    breakpoint      keep y    0x08048456 in func at tst.c:5
(gdb) r            <--------------------- 运行程序,run命令简写
Starting program: /home/hchen/test/tst Breakpoint 1, main () at tst.c:17     <---------- 在断点处停住。
17                long result = 0;
(gdb) n           <--------------------- 单条语句执行,next命令简写。
18                for(i=1; i<=100; i++)
(gdb) n
20                        result += i;
(gdb) n
18                for(i=1; i<=100; i++)
(gdb) n
20                        result += i;
(gdb) c           <--------------------- 继续运行程序,continue命令简写。
Continuing.
result[1-100] = 5050        <----------程序输出。 Breakpoint 2, func (n=250) at tst.c:5
5                 int sum=0,i;
(gdb) n
6                 for(i=1; i<=n; i++)
(gdb) p i         <--------------------- 打印变量i的值,print命令简写。
$1 = 134513808
(gdb) n
8                         sum+=i;
(gdb) n
6                 for(i=1; i<=n; i++)
(gdb) p sum
$2 = 1
(gdb) n
8                         sum+=i;
(gdb) p i
$3 = 2
(gdb) n
6                 for(i=1; i<=n; i++)
(gdb) p sum
$4 = 3
(gdb) bt         <--------------------- 查看函数堆栈。
#0   func (n=250) at tst.c:5
#1   0x080484e4 in main () at tst.c:24
#2   0x400409ed in __libc_start_main () from /lib/libc.so.6
(gdb) finish     <--------------------- 退出函数。
Run till exit from #0   func (n=250) at tst.c:5
0x080484e4 in main () at tst.c:24
24               printf("result[1-250] = %d \n", func(250) );
Value returned is $6 = 31375
(gdb) c      <--------------------- 继续运行。
Continuing.
result[1-250] = 31375     <----------程序输出。 Program exited with code 027. <--------程序退出,调试结束。
(gdb) q      <--------------------- 退出gdb
hchen/test>

gdb+gdbserver方式进行ARM程序调试

【摘要】:本文首先介绍了gdb+gdbserver相关的概念,然后介绍了其下载、编译、安装等过程;接着介绍了利用gdb+gdbserver调试应用程序的流程及实例等;最后分析了下gdb+gdbserver安装过程中的常见问题。

【关键词】:gdb,gdbserver,远程调试

目录

一、gdb+gdbserver总体介绍... 1<

  • 2
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: gdbgdbserver远程调试技术的意义在于提供了一种方便有效的方式来调试运行在远程目标设备上的程序。这对于嵌入式系统或远程服务器等分布式系统的开发和调试非常有用。 首先,gdbgdbserver远程调试技术允许开发人员在不在本地环境下的目标设备上进行调试。这意味着开发人员可以通过网络连接到远程设备,并使用本地的gdb客户端来远程控制和调试目标设备上的程序。这样,不再需要将全部的代码和调试环境放在开发人员的本地机器上,大大节省了开发人员的时间和资源。 其次,远程调试技术提供了实时调试的能力。开发人员可以监控目标设备上的程序执行过程,并在运行时观察程序的状态和变量的值。这对于发现和解决运行时错误和异常非常重要。通过远程调试,开发人员可以更直接地了解程序在实际环境下的行为,从而更有效地修复问题。 此外,远程调试技术还提供了一个更加安全且可靠的调试方法。使用gdbgdbserver进行远程调试,可以避免将敏感的代码或数据复制到本地环境中,减少了潜在的安全风险。同时,由于远程调试是通过网络进行的,即使目标设备处于远程位置,也能够进行调试,减少了物理上接触设备的需求,提高了效率。 总而言之,gdbgdbserver远程调试技术的意义在于提供了一种方便、实时、安全的方法来远程控制和调试目标设备上的程序,使开发人员能够更有效地进行嵌入式系统和分布式系统的开发和调试工作。 ### 回答2: gdb gdbserver远程调试技术是一种用于在线调试嵌入式系统的工具。它的意义在于提供了一种便捷和高效的方式来调试远程的嵌入式设备。 首先,gdb gdbserver远程调试技术可以节省时间和资源。在传统的调试方式中,如果想要调试远程的嵌入式设备,通常需要将设备连接到开发服务器并使用串口进行调试。这种方式不仅繁琐,还占用了宝贵的硬件资源。而gdb gdbserver远程调试技术可以直接在目标设备上运行gdbserver,并通过网络连接到开发服务器上的gdb,使得调试变得更加方便快捷。 其次,gdb gdbserver远程调试技术可以提高团队协作效率。在实际的嵌入式系统项目中,通常会有多个开发人员同时开展工作。使用gdb gdbserver远程调试技术,不同的开发人员可以同时连接到同一个目标设备上进行调试,而不会相互干扰。这样可以提高团队成员之间的协作效率,加快问题解决和软件开发的速度。 此外,gdb gdbserver远程调试技术还提供了更灵活的调试方式。通过gdb gdbserver的支持,开发人员可以在目标设备上进行远程程序的调试,包括断点设置、变量查看、程序运行控制等。这种方式可以更加直观地观察到程序的实际执行情况,帮助开发人员更好地理解和解决问题。 总之,gdb gdbserver远程调试技术的意义在于提供了一种便捷、高效和灵活的嵌入式系统调试方式,节省了时间和资源,提高了团队协作效率,同时也方便开发人员更好地理解和解决问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值