【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保姆级调试指南

相关推荐
硅农深芯1 天前
什么时候要用开漏输出(open drain output)?
单片机·嵌入式硬件·gpio·开漏输出·open drain
wdfk_prog1 天前
[Linux]学习笔记系列 -- [fs]dcache
linux·数据库·笔记·学习·ubuntu
fufu03111 天前
Linux环境下的C语言编程(四十三)
linux·c语言·算法
_F_y1 天前
Linux:多线程
linux·运维·服务器
电子工程师-C511 天前
基于51单片机的家居环境监测系统
单片机·嵌入式硬件·51单片机
__lai1 天前
iflow cli一键安装脚本运行了,也正常安装了,但是无法通过iflow命令进入软件。在termux安装iflow-cli AI工具
linux·人工智能·termux
Ha_To1 天前
2025.12.18 NAT地址转换、PAT
linux·服务器·网络
爱吃番茄鼠骗1 天前
Linux操作系统———I/O多路复用
linux
Big_潘大师1 天前
十轴IMU模块-AHRS角度姿态、加速度计、磁力计、气压陀螺仪传感器
stm32·单片机·嵌入式硬件·arduino·陀螺仪
vortex51 天前
Linux 命令行入门:命令的构成与选项用法
linux·运维·服务器