STM32CubeIDE + ITM SWV实现printf调试信息的打印

STM32开发时,使用printf函数来打印信息是一种方便的调试方法。不需要像使用断点来中断程序运行即可方便地查看想要的信息。一般,可以通过串口输出调试信息,或将printf重定向到串口输出上,但是这样就占用了串口的硬件资源,而且接线上比较麻烦。而ITM就是一种特别方便用于调试诊断的工具,不需要占用额外的硬件资源即可方便地实现跟踪监控。


什么是ITM

ITM是cortex中的一种硬件设计,Cortex M3、M4、M7系列内核的芯片都支持该接口(M0系列内核不支持)。ITM仅支持SWD调试接口,不支持JTAG接口。相较于传统SWD接口的SWCLK和SWDIO两根数据线,使用ITM功能时还需要增加一根额外的线连接到SWO接口。

硬件连接

  1. 使用ITM调试功能时,使用的线比SWD接口多一条SWO线,某宝上的非官方版本的ST-link V2调试器大多不支持SWO接口。我最后选购了J-OB V2和ST-link V2.1这两款调试工具。 以下以ST-link V2工具进行说明。

  2. 连接到STM32f103芯片开发板
  • 正常连接SWD接口;
  • 将调试器端的SWO pin针脚连接到开发板的PB3口上,因为查看datasheet可知,PB3接口可复用为SWO输出功能;

软件配置

  1. 使用STM32CubeIDE新建STM32工程,选择对应的芯片型号;
  2. 配置HSE时钟。将调试模式设置为Trace Asynchronous Sw模式;
  3. 根据需要配置时钟树。这里将系统时钟配置为36MHz;
  4. 保存配置,生产代码;
  5. main.c文件中添加_write函数来重定向printf,并添加stdio.h头文件.接下来就可以使用printf函数来打印信息了;
#include <stdio.h>int _write(int file, char *ptr, int len)
{int DataIdx;for (DataIdx = 0; DataIdx < len; DataIdx++){ITM_SendChar(*ptr++);       // 把printf函数重定向到ITM_SendChar}return len;
}
  1. 在main函数中使用printf,测试一下效果;
int main(void)
{uint32_t count = 0;HAL_Init();SystemClock_Config();MX_GPIO_Init();while (1){printf("Hello world! ");printf("I'm in Cycle %ld\n", count);count++;HAL_Delay(500);                                // delay for 500 ms}}
  1. 项目Debug设置,打开SWV。SWV时钟需与之前时钟树配置中的FClk一致;
  2. 点击“Debug”,开始调试;
  3. 开始调试后, 打开下图这两个窗口;
  4. 设置SWV, 打开0号端口
  5. 运行程序,可以看到SWV监视窗口正常地输出打印信息和数据跟踪信息。

【STM32CubeIDE和ITM SWV实现printf调试信息的打印】相关推荐

  1. Linux宏定义屏蔽打印信息,宏定义实现调试信息的打印

    #include #define DEBUG_SWITCH1/* 打开调试信息打印功能 */ #define ERR_DEBUG_SWITCH1/* 打印错误信息打印功能 */ #define EXA ...

  2. am335x UART1输入u-boot 调试信息代码修改

    AM335x 调试信息UART1输出代码修改 1. 关于pin_mux  的配置 代码修改位置: /board/forlinx/ok335x/mux.c 1 void enable_uart0_pin ...

  3. 关于Linux 驱动以及应用调试信息打印方式总结

    1.应用打印调试 1.1 printf printf 是最简单的应用调试打印方式,默认打印在调试串口上,如果有telnet ssh 这些伪终端运行程序,printf 就打印在当前终端上.printf ...

  4. 如何打开pr_debug调试信息

    转载:http://blog.csdn.net/helloanthea/article/details/25330809 以DMA的调试为例,先来看看一个pr_debug函数调用 pr_debug(& ...

  5. STM32 使用 ITM 输出调试信息

    本文开发环境: MCU型号:STM32F103ZE IDE环境: MDK 5.27 调试器:ST-LINK 本文内容: 使用 ITM 输出调试信息 文章目录 一.ITM 简介 二.ITM 输出功能的配 ...

  6. J-Link、ST-Link、DAPLink、ULink仿真器区别?以及支持的JTAG、SWD、SWIM下载模式、SWV、串口Printf调试差异?

    参考文章 什么是下载调试器? 简单来说,下载调试器是将PC(例如通过USB协议)发送的命令转换为MCU(负责MCU内部外围设备))理解的语言(例如SWD或JTAG协议)的设备,加载代码并精确控制执行. ...

  7. MDK硬件调试_在Debug printf Viewer窗口显示打印信息_ITM

    平时调试代码的时候大家都喜欢用printf函数来输出一些打印信息,来提示自己代码的执行情况.在刚开始接触这个调试方法的时候,我采用的方式就是浪费一个芯片的串口,然后利用TTL转USB模块,在PC端的串 ...

  8. MDK硬件调试打印调试信息的实现方式---ITM机制的实现

    时调试代码的时候大家都喜欢用printf函数来输出一些打印信息,来提示自己代码的执行情况.在刚开始接触这个调试方法的时候,我采用的方式就是浪费一个芯片的串口,然后利用TTL转USB模块,在PC端的串口 ...

  9. STM32M CUBE实现printf打印调试信息以及实现单字节接收

    在写单片机程序时我们一般喜欢使用printf来通过串口打印调试信息,但这个函数是不能够直接使用的.必须做点对库函数的修改. 具体project下载地址: http://download.csdn.ne ...

最新文章

  1. 数据库事务的ACID特性及含义
  2. 了解大脑的“小情绪”,轻松成为“效率达人”
  3. 全景视频的跟踪与合成方法
  4. 普林斯顿大学算法课 Algorithm Part I Week 3 自我总结
  5. c++从入门到进阶--引用与常量
  6. about hamout cloudra
  7. lpc1768的gpio库函数_LPC1768之GPIO流水灯的实验例程
  8. Linux社区关于链表的bug讨论我们要看一下
  9. 下运行maven命令_如何在批处理模式下运行 top 命令
  10. python dll文件丢失_python34.dll
  11. Windows 操作小技巧 之一(持续更新)
  12. php 计算签名,php – 计算Amazon Marketplace API的签名问题
  13. 怎么把word转换ppt?
  14. 简明Python教程链接
  15. mac自带的词典不能用
  16. 数据库课程设计-NBA球队信息管理系统
  17. Linux之压缩详解
  18. -D指定db登陆失败ERROR 1044 (42000): Access denied for user ‘lzldb‘@‘%‘ to database ‘lzldb‘
  19. 将秒数转换为时分秒的c语言程序,秒数换算(c语言输入秒转化为时分秒)
  20. 跟美团API对接,以及生成签名,同步数据到数据库

热门文章

  1. 用Windows Live Writer发布日志到BlogBus
  2. java转盘旋转算法,转盘抽奖算法(java)
  3. 强大、优秀的文件管理软件评测:图片管理、书籍管理、文献管理
  4. 一篇不错的文章--项目开发经验谈之:设计失败的挫败感
  5. xmind 8 安装后启动失败
  6. cassandra(scylladb)数据备份和还原
  7. Blender 烘焙贴图 导入Unity
  8. 几种Transformer+CNN(U-net)网络
  9. math: 卡尔曼滤波算法原理以及python实例
  10. sqlserver通过日志恢复删除数据(只能恢复小数据量)