news 2026/6/11 17:14:10

OpenOCD简明指南

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
OpenOCD简明指南

一、OpenOCD 简介

OpenOCD(Open On-Chip Debugger)是一个开源的片上调试工具,支持多种调试器和目标芯片。它通过 JTAG、SWD 等接口与目标设备通信,提供固件烧录、调试、内存操作等功能。

二、快速烧录固件

2.1 基本烧录命令

openocd -f interface/stlink-v2.cfg -f target/stm32f1x.cfg -c "program Project.hex verify reset exit"

命令解析:

-f interface/stlink-v2.cfg:指定 ST-Link V2 调试器接口

-f target/stm32f1x.cfg:指定 STM32F1 系列目标芯片

program Project.hex:烧录 Project.hex 固件

verify:验证烧录结果

reset:复位芯片

exit:退出 OpenOCD

2.2 适用场景

适用于 STM32F1 系列芯片的快速固件烧录,一次性完成烧录→验证→复位全流程。

三、Telnet 调试模式

3.1 启动调试服务

openocd -f interface/cmsis-dap.cfg -f target/stm32g4x.cfg

服务说明:

监听 3333 端口(GDB 调试)

监听 4444 端口(Telnet 交互)

保持终端运行以维持连接

3.2 连接 Telnet

telnet 127.0.0.1 4444

连接成功后进入交互模式,可直接输入 OpenOCD 指令操作目标芯片。

四、基本控制指令

4.1 基本控制指令汇总

指令名称 命令格式 示例 说明

init init init 初始化调试接口和目标芯片

reset reset reset 简单复位芯片

reset run reset run reset run 复位后立即运行程序

reset halt reset halt reset halt 复位后暂停执行(调试常用)

reset init reset init reset init 复位并初始化芯片状态

halt halt halt 暂停目标执行

resume resume resume 从当前地址恢复执行

resume 地址 resume [address] resume 0x08000000 从指定地址开始执行

step step step 单步执行(进入函数)

五、常用操作指令

5.1 内存操作指令

指令名称 命令格式 示例 说明

读 32 位 mdw [addr] [count] mdw 0x08000000 4 读取 4 个 32 位数据

读 16 位 mdh [addr] [count] mdh 0x20000000 5 读取 5 个 16 位数据

读 8 位 mdb [addr] [count] mdb 0x08001000 8 读取 8 个 8 位数据

写 32 位 mww [addr] [value] mww 0x20000000 0x12345678 写入 32 位数据

写 16 位 mwh [addr] [value] mwh 0x20000004 0xABCD 写入 16 位数据

写 8 位 mwb [addr] [value] mwb 0x20000006 0xEF 写入 8 位数据

保存内存 dump_image [file] [addr] [size] dump_image ram.bin 0x20000000 0x1000 保存内存数据到文件

5.2 Flash 操作指令

指令名称 命令格式 示例 说明

探测 Flash flash probe [num] flash probe 0 探测 Flash 设备

显示信息 flash info [num] flash info 0 显示 Flash 详细信息

地址擦除 flash erase_address [addr] [size] flash erase_address 0x08000000 0x1000 按地址范围擦除

扇区擦除 flash erase_sector [num] [first] [last] flash erase_sector 0 0 3 按扇区擦除

烧录固件 flash write_image [erase] [file] [addr] flash write_image erase firmware.bin 0x08000000 烧录固件到 Flash

5.3 程序加载与执行

指令名称 命令格式 示例 说明

程序烧录 program [file] [addr] [verify] [reset] program Project.bin 0x08000000 verify reset 烧录并验证程序

加载到内存 load_image [file] [addr] load_image test.elf 0x20000000 加载程序到 RAM

验证固件 verify_image [file] [offset] verify_image Project.hex 0x00 验证烧录结果

复位运行 reset run reset run 复位后运行程序

指定地址执行 resume [address] resume 0x20000000 从指定地址执行

5.4 调试指令

指令名称 命令格式 示例 说明

显示寄存器 reg reg 显示所有 CPU 寄存器

设置寄存器 reg [name] [value] reg R1 0x1234 设置寄存器值

硬件断点 bp [addr] [length] hw bp 0x08000100 0x01 hw 设置硬件断点

移除断点 rbp [addr] rbp 0x08000100 移除断点

数据监视点 wp [addr] [length] r/w wp 0x20000000 0x04 r 设置数据监视点

单步执行 step step 单步执行(进入函数)

步过执行 next next 单步执行(跳过函数)

六、总结

OpenOCD 是嵌入式开发中强大的调试工具,掌握基本控制指令是有效调试的基础。建议按照标准调试流程操作,结合实际项目多加练习,逐步掌握各种调试场景的应用技巧。

核心要点:

始终以 init开始调试会话

使用 reset halt获得可控的调试起点

善用 step进行精细调试

调试完成后用 reset run恢复正常执行

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 15:47:28

我为什么当博主

文章目录前言一. 我的知识库,不能只喂给领导二. 我的脚本工具,在硬盘里快要“抑郁”了三. 我想找个地方,说点“人话”总结前言 时间过得真快,还记得我的第一帖发表时间是2025.10.18,转眼间已经二个月了,从…

作者头像 李华
网站建设 2026/6/10 23:16:15

微服务灰度发布实战:从理论到落地的完整解决方案

微服务灰度发布实战:从理论到落地的完整解决方案 【免费下载链接】pig 项目地址: https://gitcode.com/gh_mirrors/pig/pig 在微服务架构日益普及的今天,如何安全、平滑地发布新版本功能成为每个技术团队必须面对的挑战。灰度发布作为降低发布风…

作者头像 李华
网站建设 2026/6/11 2:32:14

Easy Dataset使用手册:从零开始构建LLM微调数据集

Easy Dataset使用手册:从零开始构建LLM微调数据集 【免费下载链接】easy-dataset A powerful tool for creating fine-tuning datasets for LLM 项目地址: https://gitcode.com/gh_mirrors/ea/easy-dataset 还在为LLM微调数据准备而头疼吗?Easy D…

作者头像 李华
网站建设 2026/6/10 10:00:45

包依赖分析工具终极指南:快速解决版本冲突

包依赖分析工具终极指南:快速解决版本冲突 【免费下载链接】rushstack Monorepo for tools developed by the Rush Stack community 项目地址: https://gitcode.com/gh_mirrors/ru/rushstack 在大型monorepo项目中,包依赖管理往往成为开发者的噩梦…

作者头像 李华
网站建设 2026/6/10 14:51:29

性能测试转型指南:从传统工具到k6的5步成功路径

性能测试转型指南:从传统工具到k6的5步成功路径 【免费下载链接】k6 A modern load testing tool, using Go and JavaScript - https://k6.io 项目地址: https://gitcode.com/GitHub_Trending/k6/k6 在现代软件开发中,性能测试已成为确保应用稳定…

作者头像 李华