1.学习笔记:搭建 Linux 内核网络调试环境(vscode + gdb + qemu)
2.Linux环境使用VSCode调试简单C++代码
3.使用 Vscode 搭建 Linux Kernel 4.4.6 可视化调试环境
4.Linux环境下使用VScode调试CMake工程
5.Linux 基础学习4:gdb 的码调基本使用方法与技巧
6.Linux内核调试:kdump、vmcore、码调crash、码调kernel-debuginfo
学习笔记:搭建 Linux 内核网络调试环境(vscode + gdb + qemu)
本文主要介绍了如何搭建Linux内核网络调试环境,码调主要步骤包括: 首先,码调使用VM(虚拟机)和Ubuntu .,码调turtle库 源码配置dhcp方式的码调网络,绑定主机网卡,码调确保获得有效IP地址和DNS配置。码调 接着,码调安装和配置内核源码、码调gdb,码调进行内核的码调编译,并测试gdb是码调否能正确调试内核。 然后,码调使用qemu模拟器进行测试,特别提到一个关键问题:qemu的bzImage与gdb的vmlinux如何匹配。实际调试中,你需要确保gdb服务器与qemu的vmlinux关联正确。 对于非图形化的gdb,可以借助VSCode进行更便捷的调试。配置步骤包括设置远程连接Ubuntu、内核源码查阅和开启调试功能。 在VSCode中,创建Linux配置,安装相关插件后,可通过“运行”->“添加配置”启动调试。 在调试过程中,qemu需启用调试模式,通过输入's',VSCode可以捕获断点并进行深入调试。调研工厂源码 为了实现外网通信,需要在VM中设置网桥,将qemu接口连接到网络。 测试阶段,可以将监听地址从.0.0.1调整为VM所在网段的地址,便于telnet测试。Linux环境使用VSCode调试简单C++代码
本文通过演示一个简单C++代码的编译调试过程,介绍在VSCode中如何使用Linux环境下的GCC C++编译器(g++)和GDB 调试器(gdb)。
关于GCC、g++、gcc、gdb,这里不做详细介绍,如果感兴趣可以参考另一篇文章。
看懂这篇文章的内容,只需要知道g++用来编译C++代码,gdb用来调试C++代码即可。
示例代码内容如下:
1. 终端命令行方式编译、调试简单C++代码
如果不考虑VSCode,在Linux环境中编译调试一个简单的C++代码可以只通过命令行实现,具体过程分为两步:
第一步:将*.cpp源代码文件通过g++编译器生成一个可调试的可执行二进制文件:
指令解析:
第二步:调用gdb调试器对可执行文件进行调试:
调试的过程如下:
2. 通过VSCode对C++代码进行编译、调试
主要参考:
2.1 前提条件
2. g++编译器和gdb调试器已安装。可以在终端查看g++是否已安装
如果能输出版本信息,则已安装。
gdb调试器可以通过下面的命令安装(安装gdb会自动安装g++):
2.2 配置tasks.json
在VSCode中打开示例代码文件夹,
1. 在VSCode的主菜单中,选择Terminal>Configure Default Build Task
2. 出现一个下拉菜单,显示 C++ 编译器的各种预定义编译任务。选择C/C++: g++ build active file(如果配置了中文,会显示 "C/C++: g++ 生成活动文件")
3. 选择后,goodix指纹源码vscode会自动生成一个.vscode文件夹和 tasks.json文件,此时的代码文件夹结构如下:
tasks.json的内容如下:
tasks.json的作用是告诉VSCode如何编译程序
在本文中是希望调用g++编译器从cpp源代码创建一个可执行文件,这样就完成了第1节中所说的编译调试第一步。
从tasks.json的"command"和"args"可以看出,其实就是执行了以下命令:
其中,
2.3 执行编译
在2.2节配置完成 tasks.json 文件后,VSCode就知道应该用g++编译器对cpp文件进行编译,下面执行编译即可:
1. 回到活动文件hello.cpp(很重要,不然 ${ file} 和 ${ fileDirname}这些变量都会错)
2. 快捷键ctrl+shift+B或从菜单中选择运行:Terminal -> Run Build Task,即可执行 tasks.json中指定的编译过程
3. 编译任务完成后,会出现终端提示,对于成功的g++编译,输出如下:
这一步完成后,在代码目录下就出现了一个可执行文件hello。
4. (可选) 个性化修改 tasks.json 可以通过修改 tasks.json满足一些特定需求,比如将"${ file}"替换“${ workspaceFolder}/*.cpp”来构建多个 C++ 文件; 将“${ fileDirname}/${ fileBasenameNoExtension}” 替换为硬编码文件名(如“hello.out”)来修改输出文件名
2.4 调试hello.cpp
完成上述的编译配置后,就可以对hello.cpp进行调试了:
4. 然后就开启调试过程了,可以单步运行、添加监视等等。
2.5 个性化配置launch.json
按照2.4节的过程,已经可以简单调试一个.cpp代码,但是在某些情况下,可能希望自定义调试配置,比如指定要在运行时传递给程序的命令参数。这种情况下我们可以在launch.json中定义自定义调试配置。
下面是配置调试过程的步骤:
launch.json的作用就是在告诉VS Code应该如何调用调试器。
如果想要在调试/运行程序时添加参数,只需要把参数添加在"args"选项中即可。
2.6 总结
在VSCode中编译、调试一个简单的代码手册源码.cpp文件,所需要做的就是:
2.7 复用C++配置
上面的过程已经完成了在VSCode中调试Linux环境下的C++代码的配置,但只适用于当前工作空间。如果想要在其他的工程文件夹下复用这种配置,只需要把tasks.json和launch.json文件复制到新文件夹下的.vscode目录下,然后根据需要改变对应的源文件和可执行文件的名称即可。
3.参考教程
使用 Vscode 搭建 Linux Kernel 4.4.6 可视化调试环境
本文旨在指导如何使用Vscode搭建Linux Kernel 4.4.6的可视化调试环境,通过Qemu模拟器、Busybox和Gdb等工具进行配置和调试。首先,确保你的Linux宿主机为位,并安装好必要的编译内核工具。选择4.4.6版本的内核源代码,配置时开启debug信息和特定选项。为得到流畅的代码提示,需生成compile_commands.json文件,可能需要使用bear工具。在编译过程中,可能会遇到与PIC模式和链接器版本相关的报错,需进行相应调整。完成内核编译后,利用Qemu启动并解决可能的重启问题。使用Busybox构建initramfs,以支持内核启动时的设备驱动和基本程序。最后,通过.gdbinit和launch.json配置Vscode,实现在Kernel代码中的可视化调试,包括设置断点和启动调试过程。整个过程涉及从下载源码到成功进入Shell并进行调试的详细步骤。
Linux环境下使用VScode调试CMake工程
在本文中,我们将探讨如何在Linux环境下使用VSCode对基于CMake的m聊源码工程进行编译和调试。首先,对于C++编译和相关工具如g++、gdb的初学者,可以参考前面的教程以建立基础理解。
CMake的作用在于优化大型C++项目的编译流程。它能管理复杂的文件结构,处理依赖关系,使得原本冗长的编译命令变得简洁。以一个包含多个文件夹和源文件的工程为例,CMake能生成编译指令,降低繁琐程度。
在演示的CMake工程目录中,build文件夹用于存放编译中间文件,而源代码文件夹中包含了项目的核心内容。若在终端使用CMake编译,步骤是直接在build目录下运行cmake和make命令。
在VSCode中,配置CMake编译的过程包括创建tasks.json文件,其中包含了cmake和make的命令。执行build任务就等于执行了这两个命令,实现了CMake的编译。
接下来,调试CMake工程就变得简单了。编译完成后,VSCode会自动识别生成的可执行文件helloCMake。在launch.json中,需要配置使用gdb调试器,指定要调试的文件和断点位置。只需在helloCMake.cpp文件中设置断点,通过F5键即可启动调试。
总的来说,通过VSCode和CMake的结合,即使在Linux环境中,管理和调试C++项目也变得更加直观和高效。
Linux 基础学习4:gdb 的基本使用方法与技巧
Linux 基础学习4:深入理解gdb的实用操作与技巧
首先,让我们来解答什么是GDB。GDB,全称GNU Debugger,是一个强大的开源源代码调试器,它能帮助我们追踪和修复程序在运行时遇到的问题。在编写代码时,为了便于调试,通常会在编译阶段开启优化选项-g和警告选项-Wall,以便在编译时发现潜在问题。
进入实战阶段,GDB提供了丰富的命令行工具。启动和退出GDB是基本操作,查看代码、设置断点、使用调试命令以及清理屏幕都是调试过程中的关键步骤。特别地,遇到程序崩溃时,GDB的coredump文件管理是必不可少的。coredump文件记录了程序崩溃时的状态,通过gdb调试这些文件,我们可以分析问题发生的具体位置。
在多线程程序调试中,gdb的暂停命令需注意应在线程创建后使用,才能准确跟踪线程的执行。例如,图示展示了线程调度器锁开启后,单步执行始终在A线程进行,表明调度器锁已起作用,这对于理解多线程程序的行为至关重要。
Linux内核调试:kdump、vmcore、crash、kernel-debuginfo
本文将深入探讨 Linux 内核调试技术,主要涉及 kdump、vmcore、crash、以及 kernel-debuginfo 的应用与安装。
kdump 是 Linux 内核崩溃时生成内核转储文件(vmcore)的机制,vmcore 文件包含内核崩溃时的状态,可用于诊断内核崩溃原因。crash 是一个广泛使用的内核崩溃转储文件分析工具,通过使用 crash,我们可以从 vmcore 文件中获取详细信息,来定位和解决内核问题。
为了充分发挥 crash 的功能,需要安装 crash 工具和内核调试工具 kernel-debuginfo。确保安装的版本与 Linux 内核相匹配,可通过执行 `uname -a` 命令查看内核版本。然后,按照以下步骤安装必要的组件:
1. **安装 kexec-tools**:执行 `yum search kexec-tools` 查找 kexec-tools 包,然后使用 `yum install kexec-tools.x_` 进行安装。
2. **配置 kdump**:通过编辑 `/boot/grub/menu.lst` 设置 `crashkernel=auto`,并使用 `vim /etc/kdump.conf` 设置核心转储文件的保存路径,例如 `/var/crash`。最后,启动 kdump 服务,执行 `service kdump start`。
3. **安装 crash**:查找 crash 包,执行 `yum install crash.x_` 安装。
4. **安装 kernel-debuginfo**:安装两个相关 rpm 包,`rpm -ivh kernel-debuginfo-common-x_-2.6.-.el6.x_.rpm` 和 `rpm -ivh kernel-debuginfo-2.6.-.el6.x_.rpm`。
安装完成后,可以通过模拟内核崩溃来测试 kdump 的功能。执行 `echo c > /proc/sysrq-trigger`,这样内核就会崩溃,并在 `/var/crash` 目录下生成 vmcore 文件。接下来,使用 crash 工具分析 vmcore 文件,执行命令 `/usr/bin/crash /usr/lib/debug/lib/modules/2.6.-.el6.x_/vmlinux vmcore`。具体的分析过程可参考“Linux 内核:分析 coredump 文件 - 内核代码崩溃”。
Linux 内核源码的高级知识可以加入开发交流群获取。群内提供免费资源、公开课技术分享,入群不亏,欢迎加入。
资源免费领
学习直通车
Linux系统调试篇——Perf性能分析指南
Linux系统调试篇——Perf性能分析指南
Perf是一个强大的性能分析工具,用于监控程序运行时的性能事件,如执行时间、上下文切换和缓存命中率等。通过它,开发人员可以定位程序性能瓶颈,进行优化。安装时,可以使用apt在开发板上安装,或在内核源码目录下编译并传输至设备。 perf主要分为基础子命令和功能型子命令。基础子命令如perf list用于查看支持的性能事件,而perf stat则能实时采样并展示这些事件。tracepoint event功能强大,可针对内核中特定时刻进行采样,如sched:sched_switch,记录进程调度情况。 perf record与perf report配合使用,前者记录数据生成perf.data文件,后者解析并展示详细信息。perf script则用于生成perf.unfold文件,供FlameGraph工具生成易于理解的火焰图,展示函数调用耗时情况。 例如,perf top动态显示采样事件,而perf bench则内置了性能基准测试,如内存和调度方面的测试。要充分利用perf,需要理解性能指标的含义及其影响,这需要深入学习和实践。linux本地clion调试TVM源码环境搭建
首先,从网上下载TVM源码和LLVM,然后解压LLVM文件。
接着,使用Clion打开TVM源码以CMake工程形式,确保在CMake选项中配置了解压后的LLVM路径。
在成功加载CMake工程后,进行编译操作,点击工具栏上的编译按钮,编译结果会生成一个动态库文件,如libtvm.so。
若遇到编译错误提示“unrecognized command line option ‘-fuse-ld=lld”,检查并升级gcc版本以解决此问题。
仅需编译TVM代码即可开始调试工作,无需额外编译其他组件。
准备Python代码执行环境,调整环境变量,确保PYTHONPATH指向TVM源码中的Python包路径,同时设置LD_LIBRARY_PATH指向动态库生成路径。
尝试运行自编写的Python脚本,验证环境配置是否正确。
为了调试C++源码,创建一个CMake应用,例如命名为cppEntrance,配置程序参数为待调试的Python脚本路径,并在环境变量中保持与Python脚本相同的设置。
找到对应Python接口的C++代码入口,设置断点,启动cppEntrance调试,即可进入TVM的C++代码调试。
对于查找TVM接口对应的C++代码入口,除全局搜索外,可能存在其他方法或工具。欢迎在评论区分享您的经验或建议。