news 2026/4/17 12:40:48

OpenOCD JTAG协议开发完全指南

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
OpenOCD JTAG协议开发完全指南

OpenOCD JTAG协议开发完全指南

版本: 1.0
日期: 2026年1月
适用范围: RISC-V调试、FPGA开发、嵌入式系统调试


目录

  1. JTAG基础概念
  2. OpenOCD架构
  3. JTAG协议层次
  4. JTAG状态机
  5. IR/DR扫描操作
  6. OpenOCD API详解
  7. RISC-V调试规范
  8. 实际应用案例
  9. 常见问题排查

JTAG基础概念

什么是JTAG?

JTAG (Joint Test Action Group) 是一个工业标准接口,用于:

  • 芯片测试- 制造后验证芯片功能
  • 边界扫描- 访问芯片内部逻辑
  • 在系统编程- 无需特殊编程器的固件烧写
  • 调试- 实时访问处理器状态和内存

JTAG的四线接口

TCO (Test Clock Out) ← 时钟信号,由主控端驱动 TDI (Test Data In) ← 数据输入线 TDO (Test Data Out) → 数据输出线 TMS (Test Mode Select) ← 控制线,选择状态机状态 (可选) TRST (Test Reset) ← 异步复位信号

JTAG链

┌─────────────────────────────────────┐ │ PC/主控设备 (USB-JTAG适配器) │ │ (OpenOCD运行于此) │ └─────────────┬───────────────────────┘ │ TCO, TDI, TDO, TMS │ ┌─────────────▼───────────────────────┐ │ TAP 1 (device 1) │ │ ┌──────────────────────────────┐ │ │ │ TAP Controller │ │ │ │ (状态机) │ │ │ │ ┌────────────────────────┐ │ │ │ │ │ IR (指令寄存器) │ │ │ │ │ │ DR (数据寄存器) │ │ │ │ │ └────────────────────────┘ │ │ │ └──────────────────────────────┘ │ └──────────────┬──────────────────────┘ │ 级联到下一个设备 ┌──────────────▼──────────────────────┐ │ TAP 2 (device 2) │ │ ... │ └─────────────────────────────────────┘

在我们的KU060系统中

  • TAP 1: FPGA本身 (Xilinx Kintex UltraScale)
  • TAP 2: Nuclei RISC-V处理器

OpenOCD架构

分层架构

┌──────────────────────────────────────────────┐ │ 用户接口层 │ │ ├─ TCL命令 (mdw, mww, halt, resume等) │ │ ├─ GDB协议 (arm-none-eabi-gdb) │ │ └─ 远程调试接口 (TCP/IP) │ └────────────────┬─────────────────────────────┘ │ ┌────────────────▼─────────────────────────────┐ │ 目标相关层 (Target Layer) │ │ ├─ RISC-V调试器 (riscv.c) │ │ ├─ ARM调试器 │ │ ├─ 通用内存访问接口 │ │ └─ 寄存器管理 │ └────────────────┬─────────────────────────────┘ │ ┌────────────────▼─────────────────────────────┐ │ JTAG核心层 (JTAG Core) │ │ ├─ TAP扫描处理 │ │ ├─ 队列管理 (command queue) │ │ ├─ 状态机管理 │ │ └─ IR/DR操作 │ └────────────────┬─────────────────────────────┘ │ ┌────────────────▼─────────────────────────────┐ │ 驱动层 (Adapter Layer) │ │ ├─ FTDI驱动 (USB-JTAG适配器) │ │ ├─ 并口JTAG驱动 │ │ ├─ 网络JTAG驱动 │ │ └─ 其他调试接口驱动 │ └────────────────┬─────────────────────────────┘ │ └────────────────▼─────────────────────────────┘ 物理JTAG接口 (TCO, TDI, TDO, TMS)

关键文件位置

文件/目录说明
src/jtag/JTAG核心实现
src/jtag/core.cJTAG队列和TAP管理
src/jtag/drivers/硬件接口驱动
src/target/目标处理器支持
src/target/riscv/RISC-V支持 (riscv.c, riscv-013.c)
tcl/TCL脚本和配置
tcl/interface/接口配置文件
tcl/target/目标配置文件

JTAG协议层次

物理层 (Physical Layer)

时钟频率: 通常 0.1MHz - 50MHz

  • 我们的系统: 1MHz (稳定性考虑)
  • 公式:clock_speed = adapter_freq / 1MHz

信号完整性

TCO (上升沿采样) └─▁▁▁▔▔▔▁▁▁▔▔▔▁▁▁ TMS/TDI (下降沿建立) └─▁▁▔▔▔▁▁▁▔▔▔▁▁▁▔ TDO (旧数据有效) └─XXXX▔▔▔XXXX▔▔▔XXXX ▲ TCO下降沿后有效

传输方向

  • MSB优先 (Most Significant Bit First)
  • 移位寄存器的工作原理类似SPI

寄存器层 (Register Level)

指令寄存器 (Instruction Register - IR)

目的: 选择要操作的数据寄存器

┌────────────────────────────┐ │ JTAG指令集 (IR) │ ├────────────────────────────┤ │ IDCODE | 0x01 │ │ DTMCS | 0x10 │ │ DMI | 0x11 │ │ BYPASS | 0x1F │ │ (其他...) | 芯片相关 │ └────────────────────────────┘

IR扫描流程

1. 进入 IR 扫描状态 2. 在32个TCO周期内串行输入指令位 3. 同时从TDO读出旧指令 4. 指令在离开JTAG扫描链时锁存到IR中
数据寄存器 (Data Register - DR)

包含类型

  • IDCODE DR: 芯片ID (32位)

    ┌─────────────────────────────────────┐ │ Bit 31-28: 版本号 (Version) │ │ Bit 27-12: 部件编号 (Part Number) │ │ Bit 11-1: 制造商代码 (Manuf ID) │ │ Bit 0: 固定为 1 │ └─────────────────────────────────────┘
  • DTMCS DR: 调试模块控制/状态 (32位)

    ┌─────────────────────────────────────┐ │ Bit 31-16: 版本 │ │ Bit 15-12: 地址位数 (abits) │ │ Bit 11-10: 访问大小 (access) │ │ Bit 9-0: 其他状态位 │ └─────────────────────────────────────┘
  • DMI DR: 调试模块接口 (34-50位,取决于配置)

    ┌──────────────────────────────────────┐ │ Bit [1:0]: 操作/响应码 (op) │ │ Bit [33:2]: 数据 (data) │ │ Bit [40:34]: 地址 (addr) │ │ (其他bits可能因实现而异) │ └──────────────────────────────────────┘

命令层 (Command Level)

通过DMI接口发送调试命令:

/* 访问调试寄存器的DMI命令 */typedefstruct{uint32_taddr;/* 目标寄存器地址 */uint32_tdata;/* 数据 (32位) */uint8_top;/* 操作码: 0=noop, 1=read, 2=write */}dmi_cmd_t;/* DMI响应 */typedefstruct{uint32_tdata;/* 返回的数据 */uint8_tresp;/* 响应码: 0=ok, 1=busy, 2=error */}dmi_resp_t;

常用调试寄存器

地址名称说明
0x04DMCONTROL调试模块控制 (halt, resume等)
0x11HARTINFO硬件线程信息
0x40SBCS系统总线控制
0x39SBDATA0系统总线数据0
0x3aSBDATA1系统总线数据1

JTAG状态机

TAP状态机 (TAP State Machine)

标准IEEE 1149.1定义的16个状态和转移:

┌──────────────────┐ │ Test-Logic-Reset │ (初始状态) │ └────────┬──────────┘ │ TMS=0 ▼ ┌──────────────────────────────────┐ │ Run-Test/Idle │ │ (等待状态) │ └────────┬──────────────┬──────────┘ │ │ TMS=1 │ │ TMS=1 ▼ ▼ ┌────────────────┐ ┌─────────────────┐ │ Select-DR-Scan │ │ Select-IR-Scan │ └────────┬───────┘ └────────┬────────┘ │ │ TMS=0 TMS=0 │ ▼ ▼ ┌─────────────────┐ ┌────────────────┐ │ IR-Shift │ │ Capture-DR │ │ (输入IR指令) │ └────────┬───────┘ └────────┬────────┘ │ TMS=1 │ TMS=1 ▼ ▼ ┌────────────────┐ ┌─────────────────┐ │ Shift-DR │ │ IR-Exit1 │ │ (读写DR数据) │ └────────┬────────┘ └────────┬───────┘ │ TMS=1 │ TMS=1 ▼ ▼ ┌─────────────────┐ ┌────────────────┐ │ IR-Pause │ │ DR-Exit1 │ │ (可暂停) │ └────────┬───────┘ └────────┬────────┘ │ TMS=1 │ TMS=0 或 TMS=1 ▼ ▼ (两者都回到对应的Update) ┌────────────────┐ ┌─────────────────┐ │ DR-Pause │ │ IR-Update │ │ (可暂停) │ │ (更新IR) │ └────────┬───────┘ └────────┬────────┘ │ │ TMS=0 TMS=0 │ ▼ 或 TMS=1 │ ┌─────────────────┐ ▼ │ Run-Test/Idle │ ◄─ 循环 ┌────────────────┐ └─────────────────┘ │ DR-Update │ │ (锁存DR数据) │ └────────┬───────┘ │ TMS=0 └──► Run-Test/Idle

关键状态说明

状态说明用途
Test-Logic-Reset复位状态初始化,TAP复位
Run-Test/Idle闲置等待下一条命令
Select-DR-Scan选择DR准备DR操作
Capture-DR捕获DR并行加载移位寄存器
Shift-DR移位DR串行输入/输出数据
DR-Exit1DR退出1退出移位状态
DR-PauseDR暂停可选暂停点
DR-Update更新DR将移位结果锁存
Select-IR-Scan选择IR准备IR操作
Shift-IR移位IR输入新指令
IR-Exit1IR退出1退出移位状态
IR-PauseIR暂停
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 0:17:25

Llama 3在哪些领域有实际应用?

1.Llama 3在哪些领域有实际应用?Llama 3 凭借其开源、高性能、可微调、支持长上下文和多语言等优势,已在多个领域展现出广泛的实际应用价值。尽管原生版本对中文支持有限,但通过微调(SFT/LoRA)或结合RAG(检…

作者头像 李华
网站建设 2026/4/18 0:26:51

【Agent从入门到实践】12 记忆模块:Agent如何“记住信息”

文章目录前言一、先搞懂:记忆模块的本质——“信息的存储与调用”二、短期记忆 vs 长期记忆:一张表分清核心区别三、记忆模块的3个关键功能(通俗版拆解)1. 存储:把有用的信息“记下来”2. 检索:需要时“调出…

作者头像 李华
网站建设 2026/4/18 0:25:23

基于微信小程序的电子元器件商城系统源码文档部署文档代码讲解等

课题介绍本课题旨在开发一款基于微信小程序的电子元器件商城系统,适配电子元器件品类多、规格杂、采购场景多元的特性,解决传统采购渠道分散、比价繁琐、库存查询不便等痛点。系统以微信小程序为前端载体,依托Node.js搭建后端服务&#xff0c…

作者头像 李华
网站建设 2026/4/18 0:26:51

基于微信小程序的医院体检预约管理系统的设计和实现

前言 🌞博主介绍:✌CSDN特邀作者、全栈领域优质创作者、10年IT从业经验、码云/掘金/知乎/B站/华为云/阿里云等平台优质作者、专注于Java、小程序/APP、python、大数据等技术领域和毕业项目实战,以及程序定制化开发、文档编写、答疑辅导等。✌…

作者头像 李华
网站建设 2026/4/18 0:25:31

fastapi里面tortoise-orm的用法

1.文档地址 https://blog.csdn.net/weixin_53909748/article/details/131747197 2.创建实体类,model/models.py from tortoise.models import Model from tortoise import fieldsclass Teacher(Model):id = fields.IntField(pk=True)name = fields.CharField(max_length=25…

作者头像 李华
网站建设 2026/4/18 0:26:37

BigFoot NPP 在北美和南美地区的表面,2000-2004 年

BigFoot NPP Surfaces for North and South American Sites, 2000-2004 简介 BigFoot 项目于 2000 年至 2004 年间收集了位于阿拉斯加至巴西的九个 EOS 陆地验证站点的净初级生产力(NPP)数据。每个站点代表一到两种不同的生物群落,包括北极…

作者头像 李华