【RT Thread】使用QEMU模拟器结合GDB调试RT Thread内核

在 RT-Thread 中使用 QEMU 模拟环境并通过 GDB 调试,流程相对简单(无需硬件,纯软件模拟)。核心思路是:让 QEMU 以调试模式启动 RT-Thread 固件,并等待 GDB 连接,然后通过 GDB 进行断点设置、单步执行等操作。建议直接使用RTT官方的ENV工具,集成了QEMU和常见架构的gdb,文档详解【ENV工具文档中心】

  1. 确保支持 QEMU 模拟

确认你的 RT-Thread 工程已配置为 QEMU 目标平台(如 qemu-vexpress-a9 或 qemu-virt64-aarch64 等)。一般进到对应的bsp然后配置QEMU就可以

  1. 启动 QEMU 并进入调试模式

QEMU 支持以 "等待 GDB 连接" 的模式启动,命令格式如下:
qemu-system-<架构> -M <机器型号> -kernel <固件路径> -s -S [其他选项]

  • -s:等价于 -gdb tcp::1234,表示在 1234 端口开启 GDB 服务器,等待连接。
  • -S:启动后立即暂停 CPU(不执行任何指令),等待 GDB 发送 "继续" 命令。
  • -M:指定 QEMU 模拟的机器型号(如 vexpress-a9 对应 ARM 平台)。
  • -kernel:指定要运行的 RT-Thread 固件(rtthread.elf)。

示例

复制代码
qemu-system-arm -M vexpress-a9 -kernel build/rtthread.elf -s -S -serial stdio

此时 QEMU 会启动并显示黑屏(因 -S 参数暂停执行),等待 GDB 连接。

  1. 启动 GDB 并连接 QEMU

打开新的终端 / ENV 窗口,进入工程目录。启动对应架构的 GDB(RT-Thread ENV 通常自带,或者自行配置,如 ARM 平台用 arm-none-eabi-gdb):

复制代码
arm-none-eabi-gdb build/rtthread.elf  # 加载调试固件
(gdb) target remote localhost:1234

接下来连接成功后可以直接开始调试

最后附上GDB调试详解【Linux】GDB保姆级调试指南

相关推荐
q***064711 分钟前
SocketTool、串口调试助手、MQTT中间件基础
单片机·嵌入式硬件·中间件
西风未眠1 小时前
高效编辑之vi/vim常用快捷键汇总
linux·编辑器·vim
_Stellar1 小时前
Linux 服务器管理 根目录文件夹权限设置 基于用户组实现安全共享
linux·服务器·安全
洋九八1 小时前
电路基础和 PCB 制作
单片机·嵌入式硬件·pcb工艺
LUCIFER1 小时前
驱动开发:详细分析 DTB、DTS、DTSI、DTBO 的区别、用途及它们之间的关系
linux·服务器·驱动开发
liuyao_xianhui3 小时前
版本控制器git--gdb/cgdb
linux·运维·服务器·git
CS_浮鱼3 小时前
【Linux进阶】mmap实战:文件映射、进程通信与LRU缓存
linux·运维·c++·缓存
chuxinweihui3 小时前
应用层协议 HTTP
linux·服务器·网络·网络协议·http
xu_yule3 小时前
Linux_16(多线程)信号量+基于环形队列的生成消费模型+自选锁+读写锁
linux·运维·服务器
4t4run4 小时前
25、Linux 特殊权限
linux·运维