STM32 的 SWD调试模式

发布者:创新驿站最新更新时间:2019-01-30 来源: eefocus关键字:STM32  SWD  调试模式 手机看文章 扫描二维码
随时随地手机看文章

   SWD:Serial Wire Debug 串行线调试

   我们比较常用的是Jlink下载器 ,这种下载器有一个缺点就是使用的Jtag 20PIN接口,太多的PIN会导致一些小型的PCB板很拥挤,也会增加布线的难度。 而使用SWD接口下载调试,只需要要使用4个PIN:  GND, RST, SWDIO, SWDCLK ,而且下载速度可以达到10M/s,优势显而易见。

 

    以下转自:http://www.openedv.com/posts/list/187.htm

    

    

对于JTAG和SWD的使用区别,觉得下面这篇文章讲的比较清晰了,所以转帖到这里,希望对新手有所帮助。

 SWD与JTAG区别及使用情况[转载]

    上图是SEGGER说明书中给出的Jlink引脚图,可以对照着看SWD引脚与JTAG引脚的关系。

 




   这是我手边开发板上的JTAG连接图,这个肯定是能用的。

 

    这个是从网上找来的标准的JTAG连接图,供对照参考。

    调试方式既可以用JTAG,也可以用SWD。


以下是一段转自:(http://showvi.com/Blog/ViewAirticle/186)

SWD 仿真模式概念简述


一、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 (注:下面有我自己用JTAGV8的实际连线及相应实验结果)
(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 模式, 这个时候我们忽略这个设置后会仿真常常连接不上的。



 


/////转载结束


下面是我自己的试验(用JTAG V8)


(1)按SW方式来调试,实际需要接1,7,9,15,20脚,某些资料上说的需要6个脚(第13脚SWO也需要连上)是不对的,SWO不需要连接。

    按上所述连接5个引脚时出现的画面



   1脚不接时出现的画面


 


(2)用两种方式的速度没有太大的区别。


再次测试:


(1)不接第15脚,即RESET脚,仅接4条引线,即Vref,SWDIO,SWCLK,GND。

(2)设置时Reset位选择:AutoDetect,可以正常下载,仿真。

(3)如果Reset位选选择:HW Reset ,则不能正常下载。

(4)速度远没有上面转载中说的那样快,擦除和写入ucosDemo工程约需40多s。以下是这个工程的代码量:

Program Size: Code=96830 RO-data=143650 RW-data=1016 ZI-data=16440

   但是有个现象,即下载一次后退出,然后再次进入(没有重编译时),似乎没有擦除和下载的过程,时间飞快。也许这就是上面所说的时间快的原因?


////以下来自21icbbs// http://bbs.21ic.com/icview-127364-1-1.html


    问:一直在核心板上玩 103ZE,都是些小程序 都是在RAM中调试的,而且只接三根线GND SWDIO SWCLK (VCC 直接接JTAG内部的),很爽利。不过今天要试IIS 要放一个大的数据进去,于是要烧到FLASH中去, 发现很快进度条走完, 然后显示失败,放狗一搜,说要接RESET,于是接上,果然下进去了...惨了,我PCB都画好了,都只有4线(VCC SWDIO SWCLK GND),以后怎么办呢?

    答:可以不接,可以在MDK仿真器的设置里面不使用硬件复位,而是用system reset或者vect reset,前者适用的范围更广

/////转载结束


    JTAG引脚可以被复用为IO口,但是这样一来,JTAG就不能够连上芯片了。解决的方法有两种:

    (1)另写一段程序,不要将JTAG复用为I/O口,然后将这段程序用串口工具写入芯片中;

    (2)将BOOT0/BOOT1设置成为内部RAM启动,那么上电后就不会执行FLASH中的程序,这样JTAG就能顺利“接管”JTAG引脚。


关键字:STM32  SWD  调试模式 引用地址:STM32 的 SWD调试模式

上一篇:STM32的下载及调试模式 接口
下一篇:在RAM中调试STM32程序的配置方法

推荐阅读最新更新时间:2024-03-16 16:23

STM32编译错误Error:A1067E
tartup_stm32f10x_hd.s: Error: A1067E: Output file specified as 'startup\startup_stm32f10x_hd.s', but it has already been specified as '.\obj\startup_stm32f10x_hd.o' 只需在Device中选定你所用的芯片,如果显示Device已经选定过,还出现该错误,就更新一下。
[单片机]
<font color='red'>STM32</font>编译错误Error:A1067E
STM32中断与事件
关于事件、中断事件 、中断三个概念的比喻 比如一老师在教室里给学生们上课。课堂上的学生可能做出各种行为动作,比方做笔记、打哈气、翻书包、讲小话等,我们把这些行为统称为事件,其中有些行为老师往往只是视而不见,继续他的上课;而有些行为可能导致老师的上课中止,比方讲小话,并对学生的相关行为予以警告、批评或纠正等,然后继续上课。我们把老师因为学生的某些行为而中止授课,并产生后续动作,之后接着上课的这个过程理解为中断或中断响应。我们把可能导致老师上课中断的学生行为理解为中断事件。 结合具体的ST MCU运行过程 ST MCU运行过程,其中会有许多各种各样的事件,比方管脚电平变化、计数器溢出、DMA空、FIFO非空、AD转换结束、超时、
[单片机]
关于STM32的GPIO输入输出的位带操作
支持位带操作的两个内存区的范围是: 0x2000_0000‐0x200F_FFFF(SRAM 区中的最低 1MB) 0x4000_0000‐0x400F_FFFF(片上外设区中的最低 1MB) 位带操作可以在不加任何特殊指令时实现位操作。在对一个外设寄存器或者SRAM进行位操作时,需要计算与其对应的位带别名区中的地址。计算公式如下: 位带别名区地址 = 位带别名区基地址 + 字偏移地址 字偏移地址 = 字节相对位带区的偏移 0X20 +位数目 4 这里只针对GPIO的输入输出寄存器操作 GPIO 端口输入数据寄存器 (GPIOx_IDR)(x = A..I): 偏移地
[单片机]
关于<font color='red'>STM32</font>的GPIO输入输出的位带操作
STM32学习笔记:CAN总线的过滤器
STM32 CAN控制器,提供了28个可配置的筛选器组(F1仅互联型才有28个,其他的只有14个), STM32 CAN控制器每个筛选器组由2个32位寄存器组成(CAN_FxR1和CAN_FxR2,x=0~27)。根据位宽不同,每个筛选器组可提供: ● 1个32位筛选器,包括:STDID 、EXTID 、IDE和RTR位 ● 2个16位筛选器,包括:STDID 、IDE、RTR和EXTID 位 对于过滤器组, 可以将其配置成屏蔽位模式, 这样 CAN_FxR0中保存的就是标识符匹配值, CAN_FxR1中保存的是屏蔽码,即 CAN_FxR1中如果某一位为1,则 CAN_FxR0中相应 的位必须与收到的帧的标志符中的相应位吻合才能通
[单片机]
<font color='red'>STM32</font>学习笔记:CAN总线的过滤器
关于STM32_IO口的基本操作
一、IO口的基本操作 (1)IO口模式: GPIO_Mode_IN输入模式,输入3.3V或0V 的高低电平。例如按键程序就是配置称输入模式 GPIO_Mode_OUT输出模式,输出3.3V或0V 的高低电平。例如LED闪烁程序配置成输出模式。 GPIO_Mode_AF复用工作模式。例如I2C,SPI,USART。GPIO就必须配成AF模式。 GPIO_Mode_AN模拟输入模式。例如ADC程序必须配置成AN模拟量输入模式。 (2)当配置成输出模式或者AF模式时,输出类型有两种: GPIO_OType_PP推挽输出,即可输出高电平,也可以输出低电平。 GPIO_Otype_OD开漏输出,只能输出低电平
[单片机]
关于STM32_IO口的基本操作
为何修改BASEPRI寄存器无效?
有STM32用户发现在操作BASEPRI特殊功能寄存器时,根本不起作用。比方,它目前配置了几个中断,优先级各不相同,按照STM32CubeMx里的配置分别为2、3、4不等,当他在BASEPRI寄存器里写这几个数字中的任意一个时,发现BASEPRI的数字始终是0,没有任何效果。 我们知道,通过配置 BASEPRI寄存器非0值来给系统中的中断响应设置门槛,当中断优先级低于某个级别时将不会得到CPU的响应执行,也就是说只有中断优先级高于某个级别时才能得到响应。下面截图是来自ARM CORTEX M4技术手册中有关BASEPRI寄存器的描述。 从这里可以看到该寄存器的有效配置位有8位,对其写0无意义,或者说放弃设置中断响应门槛功
[单片机]
为何修改BASEPRI寄存器无效?
关于STM32的四类嵌入式软件(库)
1写在前面 陆续收到一些朋友的问题: 1.我是选择寄存器开发STM32,还是标准外设库呢? 2.你有STM32L0标准外设库吗? 3.HAL库和LL库有什么差异? 。。。 针对STM32开发使用的嵌入式软件,或者我们说的库,可以分为四类: STM32Snippets Standard Peripheral Library STM32Cube HAL STM32Cube LL 下面就写一下关于这四种库的相关内容、以及对比应用等。 2 STM32Snippets 什么是STM32Snippets? STM32Snippets是高度优化的代码示例集合,使用符合CMSIS的直接寄存器访问来减少代码开销,从
[单片机]
关于<font color='red'>STM32</font>的四类嵌入式软件(库)
STM32 开发板入门教程 (一) GPIO
这个章节我们将学习最基本的 STM32 的 GPIO 的应用. 我们将分为两个章节来学习. 第一部份: GPIO 的基本应用和 IO 口的配置 第二部份: 外部中断的使用 -------------------------------------------------------------------------- 1: 设计要求: 开发板上有 2 个 LED, 我们的目的为有规律的点亮 LED1 和 LED2. 当按键按下去的时候所有的灯灭, 等待 2 秒钟后恢复有规律的点亮. 2: 硬件电路: 3: 软件程序设计: (1) 根据要求配置 GPIOA 中的 PA0,PA1 为输出, PA3, PA
[单片机]
<font color='red'>STM32</font> 开发板入门教程 (一) GPIO
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved