gdbserver 移植与多线程调试

在嵌入式linux平台使用gdb调试进行远程调试需要安装gdbserver,gdbserver工作在目标板上,通过串口或者网线与主机上的gdb互联实现远程调试。

  Gdbserver需要根据不同的嵌入式平台来编译生成,首先到http://ftp.gnu.org/gnu/gdb/下载合适的版本。然后在本地进行编译。在Unbuntu下编译gdb需要安装ncurses 库,在redhat上通过yum install “Development tools” 安装依赖就可以了。

  首先编译主机端gdb,编译过程如下:

  解压源码包:

  $> tar xzvf gdb 7.3.1.tar.gz

  进入目录:

  $>cd gdb-7.3.1

  生成makefile文件:

  $>./configure --target=arm-linux --prefix=/mygdb7.3.1

或者,如果是mips平台

  $>./configure --target=mips-linux --prefix=/mygdb7.3.1

  $> make

  $> make install

  执行结束之后你就会在mygdb7.3.1文件夹下bin目录找到arm-linux-gdb 或者 mips-linux-gdb 可执行文件。

  注意:执行 configure 步骤的时候目录一定要选对,否则编译会失败,各种找到不到依赖!

  此外,由于这是生成在Linux主机上调试的可执行文件,因此不必使用交叉编译环境,换句话说在编译生成gdbserver的时候需要使用交叉编译器。

  接下来编译运行在目标板上的gdbserver。

  首先进入gdbserver目录(在gdb7.3.1目录中):

  $>cd gdb gdbserver

  生成makefile文件,这一步需要指定交叉编译器的位置,假设你交叉编译的位置在xx/yy目录下:

  $>CC=xx/yy/arm-linux-gcc ./configure  --target=arm-linux  --host=arm-linux 

  生成gdbserver

  $> make

  这里没有指定—prefix参数,因此生成的gdbserver就位于 gdb7.3.1/gdb/gdbserver目录下。

  现在可以将gdbserver移植到目标板中了,方法有很多,就看你的环境了,可以使用nfs,可以使用tftp等工具。

  进行调试:

  假设我们使用交叉编译器产生了一个helloworld可执行程序,在目标板上运行:

  $> gdbserver 192.168.1.100:2345 helloworld

  其中 192.168.1.100 是调试主机的地址,2345是调试端口,helloword是需要调试的可执行程序。

  随后在主机上运行:

  $> gdb helloworld

  $> target remote 192.168.1.10:2345

  其中 192.168.1.10 是目标板的地址,2345是gdbserver打开的用于创建调试连接的端口。

可能遇到的问题:

在调试实际模块的时候,设置了断点一运行就表现出各种找不到动态连接库(.so)
    可以这样设置:set solib-search-path PATH

         通过上面设置告诉gdb所以来的动态库在那里,其中PATH是被调试可执行程序所需的动态库的位置,多个不同路径可以使用“:”来隔开,这些路径一般都是你价差编译工具链的位置。

  2. 在调试多线程程序的时候目标板出现“gdb: error initializing thread_db library”“Child terminated with signal 5”

    出现这个问题的原因有很多,有可能是你目标板上没有thread_db 库,但是也有可能是你使用的gdb版本过低不支持多线程调试(注意gdb7.0以下就不支持! 我当时一味的追求生成的文件小就使用gdb6.3 这个问题一直没有找到原因,折腾了一阵,最好也不要使用strip裁剪生成的可执行文件)。

  3. 编译gdb失败:提示在linux-low.c中“siginfo isn’t known”

    进入到linux-low.c 中,找到相应函数(大概有两个函数),将 struct siginfo 全部换成为 siginfo_t。

  4. 多线程调试可以设置 set follow-fork-mode child/parent

    表示在多线程中产生新线程的时候gdb进入到子线程还是父线程。

Gdb多线程调试常用命令:

http://coolshell.cn/articles/3643.html

多线程调试可能是问得最多的。其实,重要就是下面几个命令:

info thread 查看当前进程的线程。
thread <ID> 切换调试的线程为指定ID的线程。
break file.c:100 thread all  在file.c文件第100行处为所有经过这里的线程设置断点。
set scheduler-locking off|on|step,这个是问得最多的。在使用step或者continue命令调试当前被调试线程的时候,其他线程也是同时执行的,怎么只让被调试程序执行呢?通过这个命令就可以实现这个需求。
off 不锁定任何线程,也就是所有线程都执行,这是默认值。
on 只有当前被调试程序会执行。
step 在单步的时候,除了next过一个函数的情况(熟悉情况的人可能知道,这其实是一个设置断点然后continue的行为)以外,只有当前线程会执行。转载自:http://www.cnblogs.com/zhuyp1015/p/3619589.html
时间: 2024-10-25 16:49:08

gdbserver 移植与多线程调试的相关文章

多线程的那点儿事(之多线程调试)

[ 声明:版权所有,欢迎转载,请勿用于商业用途.  联系信箱:feixiaoxing @163.com] 软件调试是我们软件开发过程中的重要一课.在前面,我们也讨论过程序调试,比如说这里.今天,我们还可以就软件调试多讲一些内容.比如说条件断点,数据断点,多线程断点等等. [cpp] view plain copy #include <stdio.h> int value = 0; void test() { int total; int index; total = 0; for(index 

gdb 多线程调试

gdb 多线程调试 http://hi.baidu.com/hcq11/blog/item/9f5bfc6e696209d680cb4a25.html http://hi.baidu.com/litto/blog/item/759389dd198111375882dd1e.html http://blogold.chinaunix.net/u3/94700/showart_2389432.html   <推荐阅读> 先介绍一下GDB多线程调试的基本命令. info threads 显示当前可调

GDB常用调试命令以及多进程多线程调试

转载自:http://blog.csdn.net/freeelinux/article/details/53700266 一:普通命令 1.list命令 list  linenum      显示程序第linenum行周围的程序 list  function      显示函数名为function的函数的源程序 list                      显示当前行后面的源程序 list -                    显示当前行前面的源程序 2.run(r) 运行命令. ru

GDB多线程调试分析

0x00: 在Linux系统上Gdb提供了一组多线程调试命令,如表所示: 多线程调试的主要任务是准确及时地捕捉被调试程序线程状态的变化的事件,并且GDB针对根据捕捉到的事件做出相应的操作,其实最终的结果就是维护一根叫thread list的链表.上面的调试命令都是基于thread list链表来实现的,后面会有讲到. 0x01:Gdb在linux平台多线程调试实现主要依赖下面三个文件 thread.c:文件它的任务非常简单,就是多线程调试命令子集的实现,比如info threads.当用户在gd

gdb多线程调试

死锁:一种情形,此时执行程序中两个或多个线程发生永久堵塞(等待),每个线程都在等待被 其他线程占用并堵塞了的资源.例如,如果线程A锁住了记录1并等待记录2,而线程B锁住了记录2并等待记录1,这样两个线程就发生了死锁现象. gdb调试死锁的方法: gdb attach pid thread apply all bt 找到_lll_lock_wait 锁等待的地方. 然后查找该锁被哪个线程锁住了. 例如: 查看哪个线程拥有互斥体 (gdb) print AccountA_mutex $1 = {__

GDB 多线程调试:只停止断点的线程,其他线程任然执行; 或只运行某些线程 其他线程中断

多线程调试之痛 调试器(如VS2008和老版GDB)往往只支持all-stop模式,调试多线程程序时,如果某个线程断在一个断点上,你的调试器会让整个程序freeze,直到你continue这个线程,程序中的其他线程才会继续运行.这个限制使得被调试的程序不能够像真实环境中那样运行--当某个线程断在一个断点上,让其他线程并行运行. GDBv7.0引入的non-stop模式使得这个问题迎刃而解.在这个模式下, 当某个或多个线程断在一个断点上,其他线程仍会并行运行 你可以选择某个被断的线程,并让它继续运

UART接口算法移植加密芯片的调试技巧——算法调试

算法移植加密芯片的调试包含2个部分:通讯调试和算法调试.之前讲到过通讯调试技巧,接下来本篇将对算法调试中的问题进行分析总结,来帮助客户顺利地完成调试.算法调试中的常见问题:1.不要自行建工程客户在移植算法时,无需新建工程,直接打开已有例程进行编程即可.2.切记不能在线调加密芯片属于安全芯片,不支持在线调试,只能下载算法后,通过算法指令验证功能是否正常.3.了解架构是前提 加密芯片分为驱动层和应用层两部分,用户MCU发来的指令会先在驱动层解析,所以用户要学会定位驱动层问题.芯片返回的6D00.6E

Linux学习——Gdb基本调试方法&amp;&amp;多线程调试

1.Gdb的基本调试 示例代码 //e.c #include <stdio.h> void debug(char *str) { printf("debug info :%s\n",str ); } int main(int argc,char *argv[]){ int i,j; j=0; for(i=0;i<10;i++){ j+=5; printf("now a=%d\n", j); } } 1 2 3 4 5 6 7 8 9 10 11 1

设计模式 - 单例模式之多线程调试与破坏单例

前言 在之前的 设计模式 - 单例模式(详解)看看和你理解的是否一样? 一文中,我们提到了通过Idea 开发工具进行多线程调试.单例模式的暴力破坏的问题:由于篇幅原因,现在单独开一篇文章进行演示:线程不安全的单例在多线程情况下为何被创建多个.如何破坏单例. 如果还不知道如何使用IDEA工具进行线程模式的调试,请先阅读我之前发的一篇文章: 你不知道的 IDEA Debug调试小技巧 一.线程不安全的单例在多线程情况下为何被创建多个 首先回顾简单线程不安全的懒汉式单例的代码以及测试程序代码: /**