最近自己焊接了STM32的板子(以前一直用的开发板),参照网上的一些资料,阴差阳错的采用了SWD的接法连接JLINk,结果上电之后发现下载不了程序,弹出以下错误。

* JLink Info: TotalIRLen = ?, IRPrint = 0x..000000000000000000000000
**JLink Warning: CPU core not found.

一开始还以为自己没焊好芯片,可把我急坏了,最后经过多方查找资料,才发现自己采用了SWD的接法,这样的话在下载程序的设置里就要将Debug-Settings里的Port选项由JTAG改为SWD,修改之后程序果然下载成功了。

附上收集到的一些JTAG和SW接法的资料。
(转)http://www.cnblogs.com/jeakon/archive/2012/10/07/2813683.html
JTAG有10pin的、14pin的和20pin的,尽管引脚数和引脚的排列顺序不同,但是其中有一些引脚是一样的,各个引脚的定义如下。
一、引脚定义

Test Clock Input (TCK) -----强制要求1
TCK在IEEE1149.1标准里是强制要求的。TCK为TAP的操作提供了一个独立的、基本的时钟信号,TAP的所有操作都是通过这个时钟信号来驱动的。

Test Mode Selection Input (TMS) -----强制要求2
TMS信号在TCK的上升沿有效。TMS在IEEE1149.1标准里是强制要求的。TMS信号用来控制TAP状态机的转换。通过TMS信号,可以控制TAP在不同的状态间相互转换。

Test Data Input (TDI) -----强制要求3
TDI在IEEE1149.1标准里是强制要求的。TDI是数据输入的接口。所有要输入到特定寄存器的数据都是通过TDI接口一位一位串行输入的(由TCK驱动)。

Test Data Output (TDO) -----强制要求4
TDO在IEEE1149.1标准里是强制要求的。TDO是数据输出的接口。所有要从特定的寄存器中输出的数据都是通过TDO接口一位一位串行输出的(由TCK驱动)。

Test Reset Input (TRST) ----可选项1
这个信号接口在IEEE 1149.1标准里是可选的,并不是强制要求的。TRST可以用来对TAPController进行复位(初始化)。因为通过TMS也可以对TAP Controll进行复位(初始化)。所以有四线JTAG与五线JTAG之分。

(VTREF) -----强制要求5
接口信号电平参考电压一般直接连接Vsupply。这个可以用来确定ARM的JTAG接口使用的逻辑电平(比如3.3V还是5.0V?)

Return Test Clock ( RTCK) ----可选项2
可选项,由目标端反馈给仿真器的时钟信号,用来同步TCK信号的产生,不使用时直接接地。

System Reset ( nSRST)----可选项3
可选项,与目标板上的系统复位信号相连,可以直接对目标系统复位。同时可以检测目标系统的复位情况,为了防止误触发应在目标端加上适当的上拉电阻。

USER IN
用户自定义输入。可以接到一个IO上,用来接受上位机的控制。

USER OUT
用户自定义输出。可以接到一个IO上,用来向上位机的反馈一个状态

由于JTAG经常使用排线连接,为了增强抗干扰能力,在每条信号线间加上地线就出现了这种20针的接口。但事实上,RTCK、USER IN、USER OUT一般都不使用,于是还有一种14针的接口。对于实际开发应用来说,由于实验室电源稳定,电磁环境较好,干扰不大。

二、20、14、10pin JTAG的引脚名称与序号对应关系

值得注意的是,不同的IC公司会自己定义自家产品专属的Jtag头,来下载或调试程序。嵌入式系统中常用的20、14、10pin JTAG的信号排列如下:

需要说明的是,上述Jtag头的管脚名称是对IC而言的。例如TDI脚,表示该脚应该与IC上的TDI脚相连,而不是表示数据从该脚进入download cable。

实际上10针的只需要接4根线,4号是自连回路,不需要接,1,2接的都是1管脚,而8,10接的是GND,也可以不接。

(转)http://www.51hei.com/mcu/1955.html

SWD连接方式的接口定义如下,除了电源和地之外,需要连接到只要三根线,分别为SWDIO、SWCLK和RESET,即7、9、15脚。

一、SWD 和传统的调试方式区别

1. SWD 模式比 JTAG 在高速模式下面更加可靠。 在大数据量的情况下面 JTAG 下载程序会失败, 但是 SWD 发生的几率会小很多。基本使用 JTAG 仿真模式的情况下是可以直接使用 SWD 模式的, 只要你的仿真器支持。 所以推荐大家使用这个模式。

2. 在大家 GPIO 刚好缺一个的时候, 可以使用 SWD 仿真, 这种模式支持更少的引脚。

3. 在大家板子的体积有限的时候推荐使用 SWD 模式, 它需要的引脚少, 当然需要的 PCB 空间就小啦! 比如你可以选择一个很小的 2.54 间距的 5 芯端子做仿真接口。

二、仿真器对 SWD 模式支持情况

1. 市面上的常用仿真器对 SWD 模式支持情况

(1) JTAGV6 支持 SWD 仿真模式, 速度较慢。
(2) JTAGV7 比较好的支持 SWD 仿真模式, 速度有了明显的提高,速度是 JTAGV6 的 6 倍。
(3) JTAGV8 非常好的支持 SWD 仿真模式, 速度可以到 10M。
(4) ULINK1 不支持 SWD 模式。
(5) 盗版 ULINK2 非常好的支持 SWD 模式, 速度可以达到 10M。
(6) 正版 ULINK2 非常好的支持 SWD 模式, 速度可以达到 10M。

2. SWD 硬件接口上的不同

(1) JTAGV6 需要的硬件接口为: GND, RST, SWDIO, SWDCLK
(2) JTAGV7 需要的硬件接口为: GND, RST, SWDIO, SWDCLK
(3) JTAGV8 需要的硬件接口为: VCC, GND, RST, SWDIO, SWDCLK (我用的JTAG8)
(4) ULINK1 不支持 SWD 模式
(5) 盗版 ULINK2 需要的硬件接口为: GND, RST, SWDIO, SWDCLK
(6) 正版 ULINK2 需要的硬件接口为: GND, RST, SWDIO, SWDCLK

由此可以看到只有 JTAGV8 需要 5 个引脚, 即多了一个VCC引脚,其好处是: 仿真器对目标板子的仿真需要用到 RST 引脚, 使用仿真器内部的 VCC 作这个功能其实并不是非常美妙。 因此,JTAGV8 选择了只和目标板共 GND, 但不共 VCC。 因此我觉得这种模式最合理, 当然通常情况下仿真器和目标板共 GND 和 VCC 是没有错的。

三、在 MDK 中SWD 模式的设置

在调试仿真的时候用JTAG的Cortex-M3方式已经足够,并且在MDK下他的功能已经做得非常的好,用标准20脚的JTAG下载,速度是非常的快,一般初学者都是这样做的。但是SWD方式似乎速度更快、更加方便、简捷、,对于项目中对板子空间要求严格、I/O口资源紧张的用户来说更加的有利,正常的JTAG需要20管脚,而J-Link 的SWD只需要2根线(PA13/JTMS/SWDIO、PA14/JTCK/SWCLK)就够了(加上电源线也就4根),这样就节省了3个I/O口(PA15/JTDI、PB3/JTDO、PB4/JNTRST)为其它所用,并且可节省一部分板子的空间(只需4个口就可以了)。

下面我说一下SWD两线仿真的一些步骤、注意事项及需要注意的问题。

接口的连接如下:将JTAG的1、7、9、20分别与自己的开发板上JTAG的VCC、JTMS、JTCK、GND用杜邦线相连即可!

接下来告诉大家怎么使用SWD设置:

打开工程OPTION设置:

在设置中按照上图设置成 SWD 模式, 速度你可以按照你的实际需求来设置, 如果你的板子供电系统不是特别稳定, 纹波比较大或者仿真线比较长可以设置成 500K 或者 1M,如果环境很好当然可以选择 10M , 当然速度会飞起来。

记得不要忽略了左下方的那个USB还是 TCP 模式, 当然我们是 USB 模式, 因为有的时候默认是 TCP 模式, 这个时候我们忽略这个设置后会仿真常常连接不上的。

————————————————
版权声明:本文为CSDN博主「PHD_孤岛」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/zhaopengdt/article/details/50454793

JTAG和SWD接法相关推荐

  1. keil5用jlink不到芯片_你了解JLink、STLink、ULink、JTAG、SWD、SWIM的区别吗

    本文目录 1. J-Link 2. ST-Link 3. ULink 4. JTAG 5. SWD 6. SWIM 7. 小结一下 1. J-Link J-Link是德国SEGGER公司为支持仿真AR ...

  2. stm32 JTAG和SWD的使用区别简要介绍

    转载自:http://blog.csdn.net/LEON1741/article/details/72846434 搞嵌入式开发和ARM开发搞了半辈子了,调试程序是不可避免的.接触了那么多的调试规范 ...

  3. 什么是JTAG和SWD接口协议,和各类仿真器

    一.俩个协议 JTAG(Joint Test Action Group,联合测试行动小组)是一种国际标准测试协议(IEEE 1149.1兼容),主要用于芯片内部测试.现在多数的高级器件都支持JTAG协 ...

  4. 基于仿真器的两种程序烧录模式:JTAG和SWD

    关于JTAG协议 JTAG(Joint Test Action Group,联合测试行动小组)是一种国际标准测试协议(IEEE 1149.1兼容),主要用于芯片内部测试. 现在多数的高级器件都支持JT ...

  5. 浅论各种调试接口(JTAG、SWD、RDI、Jlink、Ulink、STlink)的区别

    关注.星标公众号,直达精彩内容 来源:技术让梦想更伟大 整理:李肖遥 一.JTAG协议 JTAG(Joint Test Action Group,联合测试行动小组)是一种国际标准测试协议(IEEE 1 ...

  6. 简述调试/仿真器协议(JTAG、SWD)及各类调试器(Jlink、Ulink、STlink)

    入门嵌入式编程,总会对市面上种类繁多的调试器感到困惑.本文简单介绍一下现在主流的仿真器协议(JTAG.SWD)及各类调试器(Jlink.Ulink.STlink). 一. 协议 1.JTAG协议 JT ...

  7. 你了解JLink、ST-Link、ULink、JTAG、SWD、SWIM的区别吗

    搞嵌入式的小伙伴,肯定都用过仿真器调试/下载软件,对J-Link.ST-Link,JTAG,SWD这些傻傻分不清楚,趁着空闲时刻我就写了这篇文章. 1. J-Link J-Link是德国SEGGER公 ...

  8. ARM 仿真器种类与概念(JTAG、SWD、JLink、ULink、ST-Link)

    JTAG.SWD是仿真器协议接口. JLink.ULink.ST-Link是各家公司仿真器的名字. JTAG协议 JTAG(Joint Test Action Group,联合测试行动小组)是一种国际 ...

  9. ARM仿真器的SWD接法

    ARM仿真器的SWD接法 最近接了一个项目,电路板上留有的代码下载接口是SWD接口,手头上并没有专用的SWD下载器,庆幸的是我手头有一个ARM仿真器,在接口处写着"JTAG+SWD" ...

最新文章

  1. php批量处理图片大小,word图片怎么批量调整大小
  2. .net core 程序退出事件
  3. webService的简单使用
  4. java swing点击按钮后输出结果展示_使用Eclipse编写第一个Java程序HelloWorld
  5. AAAI 2019 Oral | 让TA说你想听的—基于音/视频特征解离的讲述者人脸生成
  6. Oracle中的in 和 not in
  7. kdevelp 导入makefile工程
  8. MySQL Cluster 配置详细介绍
  9. php 正三角塔,PHP 环境塔建与数据类型转换
  10. c# mysql executenonquery_C#中ExecuteNonQuery()返回值注意点分析
  11. HTTP头域列表与解释 之 request篇
  12. 六石管理学:行政人员也要学会使用SVN保存文档
  13. java调用python脚本文件_Java实现调用jython执行python文件的方法
  14. 《css权威指南》笔记
  15. Aspen ONE Suite 11.0 软件下载及其安装教程
  16. MD5的认识,建议所有菜菜都看下
  17. ADCS relay
  18. 从零一起学Spring Boot之LayIM项目长成记(二) LayIM初体验
  19. Java执行引擎工作原理:方法调用
  20. 因网络延迟造成数据库插入相同记录,如何解决.

热门文章

  1. 来自killc的自我介绍
  2. 到底是人的位置影响了行为呢?还是行为影响了位置?--头等舱的旅客往往是在看书
  3. 深圳市各区初中学区图
  4. SHELL脚本练习(持续更新)
  5. python中文分词---jieba
  6. 求好友中互粉的好友对
  7. 个人能否有所发展,在很大程度上要看你是否重视贡献--读书笔记
  8. 把枫叶和GLOBAL3 AI 3D相机放进口袋—北京香山之旅
  9. 炁体源流 鸿蒙,《一人之下》八奇技 炁体源流
  10. 基于混合策略的改进灰狼优化算法