STM32开发,通过SWO功能输出Printf函数到Utility

STM32开发,通过SWO功能输出Printf函数到Utility

  • 1 概述
    • 1.1 资源概述
    • 1.2 SWO功能简介
    • 1.3 ITM(指令跟踪微单元)简介
    • 1.4 实现功能
  • 2 硬件连接以及CUBEMX配置
    • 2.1 硬件连接
    • 2.2 CUBEMX配置
  • 3 软件开发
    • 3.1 KEIL软件设置
    • 3.2 程序设计
  • 4 实验结果与总结
    • 4.1 实验结果
    • 4.2 总结

1 概述

1.1 资源概述

开发板:ST官方NUCLEO-F103RB开发板
CUBEMX版本:1.3.0
MDK版本:5.23
主控芯片型号:STM32F103RBT6
STM32开发,通过SWO功能输出Printf函数到Utility_第1张图片

1.2 SWO功能简介

SWO也叫做trace(跟踪)功能,通过此功能,只需要在SWD调试基础上增加一条SWO线缆,就可以实现类似串口输出功能,配合printf函数打印相应的信息到utility窗口中。此功能不占用串口资源,无需在中断中执行。

1.3 ITM(指令跟踪微单元)简介

我们此次功能实现是通过调用ITM实现的。
ITM是一应用驱动的跟踪源,它支持printf类的调试手段来跟踪操作系统(OS)和应用事件,并发布判定的系统信息。ITM以包的形式发布跟踪信息,它由以下部分组成:
● 软件跟踪:软件可以通过直接写ITM激发寄存器来发布包信息。
● 硬件跟踪:ITM会发布由DWT产生的信息包。
● 时间戳:时间戳被发布到相应的包上。ITM包含一个21位的计数器以产生时间戳。Cortex-M3的时钟或串行线观测器(Serial Wire Viewer)的位时钟率给计数器提供时钟。
由ITM发送的信息包输出到TPIU(Trace Port Interface Unit),TPIU再添加一些额外的包(参考TPIU),然后输出完整的包序列给调试器。1

1.4 实现功能

本次程序实现的功能如下
1、复位后,向Serial Wire Viewer(utility)打印信息;
2、按按键BUTTON,LED2灯实现翻转;
对于第二条实现,此次文档不详细描述。

2 硬件连接以及CUBEMX配置

2.1 硬件连接

开发板内部已经将线接好,如下图所示
STM32开发,通过SWO功能输出Printf函数到Utility_第2张图片
对于目标板与STLINK仿真器分开的情况,我们需要使用5根线进行连接,如下表所示。

序号 连接网络 备注
1 VCC 电源正,3.3V
2 GND 电源负
3 SWO SW跟踪功能
4 SWDIO SW数据输入输出
5 SWCLK SW时钟信号

2.2 CUBEMX配置

选择异步跟踪模式,此时PB3将会自动定义为SWO端口。
STM32开发,通过SWO功能输出Printf函数到Utility_第3张图片

3 软件开发

3.1 KEIL软件设置

KEIL软件设置如下,这里由于程序使用的内部HSI,系统频率是64MHz,因此填写64MHz,需要根据实际情况进行填写。
STM32开发,通过SWO功能输出Printf函数到Utility_第4张图片

3.2 程序设计

使用CUBEMX生成代码。在主函数中进行修改。
主程序中包含stdio.h函数的头文件,否则将不能识别printf函数。

#include "stdio.h"

fputc 函数宏定义。

#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)

函数定义,由于printf调用的是fputc函数,通过这么一个转换,printf函数就能调用ITM函数实现输出功能。

PUTCHAR_PROTOTYPE
{
  ITM_SendChar(ch);
  return ch;
}

TIM_Sendchar()函数在core.cm3.h头文件中有进行定义,如下所述

__STATIC_INLINE uint32_t ITM_SendChar (uint32_t ch)
{
  if (((ITM->TCR & ITM_TCR_ITMENA_Msk) != 0UL) &&      /* ITM enabled */
      ((ITM->TER & 1UL               ) != 0UL)   )     /* ITM Port #0 enabled */
  {
    while (ITM->PORT[0U].u32 == 0UL)
    {
      __NOP();
    }
    ITM->PORT[0U].u8 = (uint8_t)ch;
  }
  return (ch);
}

在主函数main()中增加printf函数,实现输出。

 printf("** Test finished successfully. ** \n\r");

4 实验结果与总结

4.1 实验结果

打开utility软件,点击printf via SWO viewer。
STM32开发,通过SWO功能输出Printf函数到Utility_第5张图片
设置频率,点击Start,将调试板复位(程序设置只运行一次printf,因此每输出一次均需要重新复位),即可发现SWV窗口输出了相应的信息。
STM32开发,通过SWO功能输出Printf函数到Utility_第6张图片

4.2 总结

在传统的调试中,我们可能偏向于断点分析或者LED灯的亮灭来判定程序运行状态,但是都不是太直观,对于程序越大越不好操作。使用这个SWO功能能很大程序解决这个问题。我们可以在各种错误处理函数增加相应的提示信息,协助我们进行软件开发工作。
STM32开发,通过SWO功能输出Printf函数到Utility_第7张图片


  1. STM中文参考手册V10 ↩︎

你可能感兴趣的:(STM32开发学习笔记)