首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

使用GDB调试Linux内核

GDB可以让你在被调试程序执行时看到它的”内部“情况,观察程序在特定断点上的状态,并逐行运行代码GDB还提供了“远程”模式,使用GDB协议通过网络或串行设备与被调试程序进行通信。...类似的,Linux内核开发者可以使用GDB的远程模式,与调试应用程序几乎相同的方式来调试Linux内核。...KGDB是Linux内核的源代码级调试器,你可以使用GDB作为KGDB的前端,在我们熟悉且功能强大的GDB调试界面中调试内核。...为了方便在调试过程中查看源代码,我们可以将虚拟机的/usr/src/linux-source-5.4.0整个目录都拷贝到宿主机上来。...写在最后 在本机搭建Linux内核调试环境的步骤有点繁杂,但使用GDB能调试内核,会成为我们学习内核的利器,进程管理、内存管理、文件系统,对源码有什么困惑就可以debug一下。 Enjoy it!

74210
您找到你想要的搜索结果了吗?
是的
没有找到

利用QEMU+GDB调试Linux内核

前言 对用户态进程,利用gdb调试代码是很方便的手段。而对于内核态的问题,可以利用crash等工具基于coredump文件进行调试。...其实我们也可以利用一些手段对Linux内核代码进行gdb调试,qemu就是一种。 qemu是一款完全软件模拟(Binary translation)的虚拟化软件,在虚拟化的实现中性能相对较差。...但利用它在测试环境中gdb调试Linux内核代码,是熟悉Linux内核代码的一个好方法。...本文实验环境: ubuntu 20.04 busybox-1.32.1 Linux kernel 4.9.3 QEMU GDB 10.1 编译内核源码 git clone git://git.kernel.org...出现该问题的原因是:编译 的是64 位模式的内核代码,但是运行是在 32 位保护模式下。64 位代码将无法在该环境中正常运行。 终于在stackflow上找到了修复方法:具体可以参考下面两篇文章。

3K20

linux内核调试工具-addr2line和gdb定位问题

之前没有用过addr2line和gdb内核调试工具定位问题代码,这里记录一下在将某个网络驱动从4.9内核移植到5.7内核时出现内核崩溃起不来的问题。...4.9内核到5.7内核改动了大量代码,在将驱动移植到5.7上编译到内核里时出现了很多错误,按照错误提示都解决之后(网络相关函数有变动),编译通过,系统起到一半内核崩溃,错误提示如下 [ 2.547487...我用的编译链是aarch64-linux-gnu-,所以addr2line前面也要加这个前缀,这里一开始有个问题,我使用addr2line的时候没有输出代码行号,只输出两个"??"...-linux-gnu-addr2line -e vmlinux FFFF800011AD4328 net/ethtool/common.c:346 定位问题代码在net/ethtool/common.c...2.通过gdb定位 使用 aarch64-linux-gnu-gdb vmlinux 命令进入gdb调试行,输入以下命令 (gdb) b*(0xFFFF800011AD4328) Breakpoint

1.3K10

Linux内核代码分析经验

Linux内核源码是很具吸引力的,特别是当你弄懂了一个分析了好久都没搞懂的问题;或者是被你修改过了的内核,顺利通过编译,一切运行正常的时候。 那种成就感真是油然而生!...同时,你还将从操作系统的整体结构中,体会整体设计在软件设计中的份量和作用,以及一些宏观设计的方法和技巧:Linux内核为上层应用提供一个与 具体硬件不相关的平台;同时在内核内部,它又把代码分为与体系结构和硬件相关的部分...,和可移植的部分;再例如,Linux虽然不是微内核的,但他把大部分 的设备驱动处理成相对独立的内核模块,这样减小了内核运行的开销,增强了内核代码的模块独立性。   ...由于本人所进行的分析都是基于2.2.5版本的内核;所以,如果没有特别说明,以下分析都是基于i386单处理器的2.2.5版本的Linux内核。...● Kernel/:主要的核心代码,此目录下的文件实现了大多数linux系统的内核函数,其中最重要的文件当属sched.c;同样,和体系结构相关的代 码在arch//kernel中。

2.7K20

如何切入 Linux 内核代码

毫不夸张地说,Kconfig和Makefile是我们浏览内核代码时最为依仗的两个文件。基本上,Linux内核中每一个目录下边都会有一个 Kconfig文件和一个Makefile文件。...对于一个希望能够在Linux内核的汪洋代码里看到一丝曙光的人来说,将它们放在怎么重要的地位都不过 分。   ...Linux内核代码使用了大量的GNU C扩展,以至于GNU C成为能够编译内核的唯一编译器,GNU C的这些扩展对代码优化、目标代码布局、安全检查等方面也提供了很强的支持。...而心理上的问题主要有两个,一个是盲目,就是在能够熟练适用Linux之前,对Linux为何物还说不出个道道来,就迫不及待的盲目的去研究内核的 源代码。...http://www.kernel.org/ 可以通过这个网站上下载内核的源代码和补丁、跟踪内核bug等。http://kerneltrap.org Linux和BSD内核的技术新闻。

5.8K62

Linux gdb使用基础

GDB简介 GDB(GNU Debugger)是Linux下一款C/C++程序调试工具,通过在命令行中执行相应的命令实现程序的调试,使用GDB时只需要在shell中输入gdb命令或gdb filename...执行一条程序,若为函数则进入内部执行 next n 执行一条程序,不进入函数内部 continue c 连续运行 finish - 运行到当前函数返回 kill k 终止正在调试的程序 list l 列出源代码的一部分...下面使用GDB对该可执行程序进程调试: $ gdb gdbtest 输出以下信息: GNU gdb (Ubuntu 8.1-0ubuntu3.2) 8.1.0.20180409-git Copyright...This GDB was configured as "x86_64-linux-gnu". Type "show configuration" for configuration details....参考: 《精通Linux C编程》- 程国钢 《Linux C编程完全解密》- 闫敬 吴淑坤

2.3K10

Linux调试器——gdb

gdb 什么是gdb debug与release gdb的基本操作 查看代码与断点 执行与调试 监视变量 什么是gdb 之前用的一直都是VS编译器进行调试,调试是一个非常重要的过程,在Linux中调试需要用到一个工具就是...在调试思路上VS编译器和gdb是一样的,但是调试过程的差距就很大了。 我们都知道Linux的操作都是通过命令完成的,调试也是一样的,靠的就是命令调试。...Linux环境下,gcc/g++编译出来的可执行程序默认是release模式 先来写一个程序验证一下 进入调试模式 gdb 你要调试的文件 后面的on debugging symbols...gdb的基本操作 查看代码与断点 以下指令都是在gdb环境下进行操作。 进入gdb模式发现连个代码都不知道在哪里,这怎么调试呢?...VS中F10是逐过程的运行,每次只跳过一行代码,比如调用函数的话是不会进入的,需要按F11逐语句才能进入调用的函数中查看: gdb的逐过程:n gdb的逐语句:s n没进入函数。

3.7K00

Linux GDB jump 命令介绍

,直接执行操作该对象的代码,那么可能会导致程序崩溃或其他意外行为。...jump 命令可以简写成 j,但是不可以简写成 jmp,其使用有一个注意事项,即如果 jump 跳转到的位置后续没有断点,那么 GDB 会执行完跳转处的代码会继续执行。...举个例子: 1 int somefunc() 2 { 3 //代码A 4 //代码B 5 //代码C 6 //代码D 7 //代码E 8 //代码F 9 } 假设我们的断点初始位置在行号...3 处(代码 A),这个时候我们使用 jump 6,那么程序会跳过代码 B 和 C 的执行,执行完代码 D( 跳转点),程序并不会停在代码 6 处,而是继续执行后续代码,因此如果我们想查看执行跳转处的代码后的结果...jump 命令除了跳过一些代码的执行外,还有一个妙用就是可以执行一些我们想要执行的代码,而这些代码在正常的逻辑下可能并不会执行(当然可能也因此会产生一些意外的结果,这需要读者自行斟酌使用)。

6.4K10

LinuxLinux调试器-gdb使用

前言 在前面的博客【Linux】编译器-gcc/g++使用已经分享了关于编译器的使用,而编译器的使用离不开调试,这次就来分享一下Linux调试器-gdb使用。 2....q quit/q gdb本身就是一个进程,把程序启动起来 3.2 list list来显示程序代码 list list后面直接更程序名是查不了代码的: 为了方便list可以直接简写为l。...还可以查main函数: l myprocess.c:main 想要查某一块代码可以加上行号,也可以加上对应的函数名就可以了。 发现gdb代码只能默认查10行 如果想要全部打出来怎么办?...gdb默认会记录用户最近的一条命令,直接按回车 就可以拿到全部的代码 如果查看第15行: 发现它并不是从15行开始,而15行差不多是在显示的代码中间的位置。...3.4 与断点有关操作 3.4.1 b打断点 gdb中用b来打断点 可以直接用b加程序名加函数 比如在main函数处打一个断点: b myprocess.c:main 比较一下发现,代码断点并不是打在

8910
领券