单片机 SWD 下载通信底层原理

💡 原文中文,约1900字,阅读约需5分钟。
📝

内容提要

在微控制器领域,常用的编程接口是JTAG和SWD。SWD只需要两条线,是一种理想的选择。常见的Cortex-M处理器都集成了SWD和JTAG调试端口。SWD类似普通外设,有对应的寄存器进行编程操作。

🎯

关键要点

  • 在Cortex-M内核微控制器领域,常用的编程接口是JTAG和SWD。
  • JTAG接口包含多个信号端,包括TDI、TDO、TCK、TMS和TRST。
  • SWD接口仅需两条线(SWCLK和SWDIO),适合引脚资源有限的场合。
  • SWD是ARM设计的串行线调试协议,用于微控制器的编程和调试。
  • 市面上有多种支持SWD调试接口的下载器,如ST-Link、J-Link等。
  • SWDIO是双向数据引脚,需在电路板上进行上拉。
  • 切换调试接口时,默认使用JTAG,需通过特定序列切换到SWD。
  • SW协议序列包括数据包请求、确认响应和数据传输阶段。
  • SW-DP状态机有复位、空闲状态和ID代码等主要状态。
  • SWD类似普通外设,开发者的编程操作实际上是对寄存器的操作。
➡️

继续阅读