当前位置: 首页 > news >正文

qemu基础篇——VSCode 配置 GDB 调试

文章目录

  • VSCode 配置 GDB 调试
    • 安装 VSCode 插件
    • 调试文件创建
    • 调试配置
      • 配置脚本
      • qemu 启动脚
    • 启动调试
      • 报错情况一
      • 报错情况二
      • 报错情况三
    • 调试界面
    • 运行 GDB 命令
    • 查看反汇编
    • 断点
    • 查看内核寄存器
    • 查看变量
    • 参考链接

VSCode 配置 GDB 调试

qemu-基础篇——arm 裸机调试环境搭建
上一节中直接使用 GDB 命令行调试,本节介绍如何使用 VSCode 来进行调试

安装 VSCode 插件

在这里插入图片描述

调试文件创建

在这里插入图片描述
选择 Node.js,此时在当前工作区域会新建一个 launch.json 文件
在这里插入图片描述

调试配置

配置脚本

{"version": "0.2.0","configurations": [{"name": "qemu_bare","type": "cppdbg","request": "launch","program": "${workspaceFolder}/qemu_code/bare/example/0020_mmu/bsp.elf","args": [],"stopAtEntry": true,"cwd": "${workspaceFolder}/qemu_code/bare","environment": [],"externalConsole": false,"MIMode": "gdb","miDebuggerPath": "/home/tyustli/cross_tool/gcc-arm-10.3-2021.07-x86_64-arm-none-linux-gnueabihf/bin/arm-none-linux-gnueabihf-gdb","miDebuggerServerAddress": "localhost:1234",}]
}
  • version:表示版本号,一般不用修改
  • configurations:其中包含每一项调试任务的具体配置信息。
  • name:调试任务的名称,在运行和调试下拉框可以展示出来。也就是下图位置。
  • type:指示编译器类型,如果用的 arm-none-gcc,那填的就是 cppdgb
  • request:有两种类型,分别是 launch 和 attach,前者的意思就是 VSCode 会打开这个程序然后进入调试,后者的意思是你已经打开了程序,然后接通 Node.js 的内部调试协议进行调试。一般选 launch
  • args:传递给程序的命令行参数。比如可以是debug的输入文档,建议使用绝对路径。
  • stopAtEntry:可选参数。如果为 true,则调试程序应在目标程序的入口点处停止,如果为 false,不会在在目标程序的入口点处停止,而是直接运行直到遇到断点
  • cwd:cd 到工程的顶层目录。一般是指,所要调试的程序所在目录。
  • environment:要添加到程序中的环境变量{“name”:“config”,“value”:“Debug”}。
  • externalConsole:true:启动控制台;false:在vscode的集成的控制台显示
  • MIMode:调试方式,指定调试器是gdb,又或者lldb等等。
  • miDebuggerPath:设置调试器路径
  • miDebuggerServerAddress:用于远程调试连接的调试器服务器(设备)

qemu 启动脚

qemu-system-arm -machine mcimx6ul-evk -kernel bsp.elf -serial stdio -S -s

qemu 启动选项多了 -s -S ,表示启动之后就 stop 等待 GDB 连接,在启动调试之前先启动 qemu ,让其等待 GDB 连接

启动调试

在这里插入图片描述

报错情况一

如果找不到 Node.js 模块,使用如下命令安装
Node.js 安装

 sudo apt-get install nodejs

报错情况二

error while loading shared libraries: libncursesw.so.5: cannot open shared object file: No such file or directory

解决

sudo apt install libncursesw5-dev
sudo apt install apt-file
sudo apt-file update
sudo apt-file find libncursesw.so.5
sudo apt install libncursesw5

报错情况三

error while loading shared libraries: libpython2.7.so.1.0: cannot open shared object file: No such file or directory

解决

sudo apt-get install libpython2.7

调试界面

在这里插入图片描述

运行 GDB 命令

在调试控制台输入 -exec + GDB 命令 即可,例如
在这里插入图片描述

查看反汇编

在调试控制台输入

-exec disassemble /m

在这里插入图片描述

断点

在这里插入图片描述

查看内核寄存器

在这里插入图片描述

查看变量

参考链接

  • https://code.visualstudio.com/docs/editor/debugging#_launch-configurations
http://www.lryc.cn/news/196430.html

相关文章:

  • Spark常用算子
  • day35
  • js原型链以及实现继承的手段
  • jdk8u201版本cpu.load过高问题的排查和解决
  • 【计算机网络笔记】数据交换之报文交换和分组交换
  • 【广州华锐互动】利用VR开展细胞基础实验教学有什么好处?
  • 基于SSM+Vue的咖啡销售系统
  • L2-026 小字辈
  • linux 查看系统版本
  • Python实现PDF转换文件格式
  • 【Ceph Cluster】完全删除Ceph集群
  • 4.Vue-Vue调用第三方接口
  • 大语言模型在推荐系统的实践应用
  • 第三章 交换技术及应用
  • 地震勘探原理部分问题解答
  • 两个步骤轻松搞定批量合并视频
  • VR虚拟现实在室内设计仿真教学中的应用演示
  • Python操作串口通信
  • 图详解第四篇:单源最短路径--Dijkstra算法
  • CRMEB多商户商城系统阿里云集群部署教程
  • Java第三方登录封装工具类
  • BUUCTF学习(四): 文件包含tips
  • 德国人工智能公司【Kodex AI】完成160万欧元融资
  • LeetCode 2 两数相加
  • springboot项目启动失败,不打印报错详细信息(启动打印日记问题)
  • MyBatis (where、set、foreach)标签
  • flutter开发之安装dart
  • 向量召回:深入评估离线体系,探索优质召回方法
  • 播放器缓存队列bug解决方案
  • React拖拽实践