0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

STM32CubeIDE SWV功能介绍

STM32单片机 来源:STM32单片机 作者: STM32单片机 2021-10-13 14:20 3919次阅读

01

引言

STM32CubeIDE是ST官方推出的集成开发环境,集成了很多STM32的调试与开发工具。本文主要介绍如何使用SWV功能来打印输出。

02

问题描述

客户使用STM32CubeIDE开发环境,将Printf定位到串口上是正常的,但是在重定位到SWO上却出现了无法打印的问题。客户也参考了网上的教程,仍然无法实现,不知道是什么原因。

STM32CubeIDE 版本:V1.6.1

硬件环境:Nucleo-G431RB

03

问题分析与定位

首先,我们需要查找资料,在《UM2609 STM32CubeIDE user guide》的第4章中,对SWV有比较详细的介绍。此处推荐先查看官网文档,这个文档本身是非常权威的。可能你在网上也会找到关于SWV功能的介绍,但是这个文档还是必须要看的,因为这个是源头。

通过查看这个文档,知道了实现SWV的简单步骤如下:

第一步:在Pinout & Configuration选项中打开SWO的功能,此步骤是必须的。

第二步:重定位printf的接口函数。

这里有个简单的方法,直接在syscalls.c文件中,改写_write()函数的内容,代码如下所示。再在此文件中包含ITM_SendChar 实现的头文件core_cmX.h,此文件一般都是已经被包含在你所选择的器件型号的头文件中。

此处我们选择的是stm32g431xx.h,直接放在此文件的开始处即可。

78cc469c-1566-11ec-8fb8-12bb97331649.png

第三步:在main.c文件中包含stdio.h这个头文件,并尝试打印printf,此处注意,打印不能很频繁,所以需要增加延时。

78ee44fe-1566-11ec-8fb8-12bb97331649.png

全局编译一下,查看是否有错误,如果有错误,请对应提示信息修改。编译没有错误之后,我们就可以进行下一步了。

78fe975a-1566-11ec-8fb8-12bb97331649.png

编译成功正确界面

第四步:配置仿真调试参数。打开SWV的调试功能。此处注意:Core Clock必须与你配置的时钟是一致的。此处我配置是170MHz,与我的系统时钟一致。

79169daa-1566-11ec-8fb8-12bb97331649.png

仿真调试配置界面

第五步:开始进入调试界面,并在调试界面中打开Windows--》Show;View--》SWV的ITM data Console窗口。注意,整个SWV其实是共用一个配置文件的,所以,当你打开SWV内的任意一个窗口都可以进行SWV 的配置。在这里我们只是为了查看Printf的内容,所以就选择了SWV ITM Data Console窗口。关于这里边其他几个部分的详细说明参考UM2609的4.3章节的内容。

此窗口打开后,需要新增一个Port端口。默认TIM中使用的就是0端口,所以我们直接选0即可。

选择点击配置按钮对参数进行配置。配置情况如下:

794ef0c4-1566-11ec-8fb8-12bb97331649.png

SWV窗口配置界面

推荐先复位一下工程(可选项),然后“启动跟踪/start trace”。注意:此处是先启动跟踪,之后再让程序运行起来,不能反序。

启动跟踪和开始运行

此时即可看到打印出来的内容了。

79896858-1566-11ec-8fb8-12bb97331649.png

最后打印输出的状态

04

小结

其实很多的内容都已经在手册中有详细的描述,但是因为英文或者是时间的问题,我们大部分人没有时间和精力阅读完所有的文档的。所以在遇到问题时候,会阻塞你比较长时间。希望本文在你遇到困难的时候能够给你一点启示,帮你快速解决手中的问题。

编辑:jq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 接口函数
    +关注

    关注

    0

    文章

    11

    浏览量

    8248
  • Printf
    +关注

    关注

    0

    文章

    83

    浏览量

    13849

原文标题:工程师笔记 | STM32CubeIDE SWV功能简介

文章出处:【微信号:STM32_STM8_MCU,微信公众号:STM32单片机】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    相关推荐

    请问STM32CubeIDE v1.16.1支持代码补全功能吗?如何开启呢?

    STM32CubeIDE v1.16.1支持代码补全功能吗?如何开启呢?
    发表于 03-14 06:47

    使用STM32CubeIDE调试STM32MP157D的M4内核时报了错误怎么解决?

    我使用STM32CubeIDE调试STM32MP157D的M4内核时报了下图这个错误: 经过我的排除后发现,应该是STM32CubeIDE上传"
    发表于 03-14 06:01

    STM32CubeIDE在线调试时,如何配置擦除Flash的部分Page?

    STM32CubeIDE在线调试时,如何配置擦除Flash的部分Page
    发表于 03-13 08:02

    STM32CubeIDE为什么无法生成工程和代码?

    各位大佬好,我是一名新手小白,当我在使用STM32CubeIDE时,出现了1图弹窗,显示我缺少必要固件包,而导致我无法生成工程和代码,但我已经正常登录,且在创建工程时STM32CubeIDE就已经
    发表于 03-12 06:00

    请问STM32CUBEIDE如何开启代码联想功能

    STM32CUBEIDE如何开启代码联想功能
    发表于 03-10 08:23

    stm32cubeide编译的时候报错,无法生成hex文件怎么解决?

    stm32cubeide编译的时候报错,并且无法生成hex文件怎么办急急急!
    发表于 03-07 08:17

    stm32cubeIDE烧录报错Error是怎么回事?

    请问各位前辈 , stm32cubeIDE 烧录报错Error!
    发表于 07-03 06:42

    请问STM32CubeIDE如何加载外部bin文件?

    我有一个外部的bin文件,想要编译、链接到stm32工程里,如何用stm32cubeide来实现呢? 我知道在keil中可以添加一个.s文件可以实现,但是keil中用汇编指令INCBIN,在stm32cubeide中如何实现呢?
    发表于 05-30 06:41

    stm32cubeide有keil中的逻辑分析仪功能吗?

    stm32cubeide有keil中的逻辑分析仪功能吗?想查看输出PWM波形
    发表于 05-22 06:56

    stm32cubeIDE代码运行时间如何查看?

    stm32cubeIDE 代码运行时间,如何查看?就如 keil 调试时候那样,可以测试代码的运行时间。但是在stm32cubeIDE 中,一直没有找到这个功能,不知道哪位高人可以提示下在哪里查看的?
    发表于 04-16 08:10

    STM32CubeIDE如何调试中修改变量值?

    使用STM32CubeIDE中发现调试部分功能不能满足。目前调试中最不方便的就是,不断点,在运行状态时,不能实时修改全局变量值。 但是目前没法找到该功能,最多只有live expression,只能看不能改。 而keilMDK
    发表于 04-15 06:44

    stm32CubeIDE如何能生成Lib?

    请问stm32CubeIDE如何能生成 Lib?
    发表于 04-12 07:57

    请问如何把keil工程导入Stm32CubeIDE ?

    如何把keil工程导入Stm32CubeIDE ?
    发表于 04-09 08:30

    STM32CUBEIDE软件生成工程怎么使用CCRAM型号?

    求助STM32CUBEIDE软件生成工程怎么使用CCRAM 型号:STM32G474VE
    发表于 04-08 08:20

    STM32CubeMX生成stm32cubeide工程报错的原因?怎么解决?

    使用STM32CubeMX,建立了STM32F103VC的工程文件,能够生成IAR工程,正常使用没有问题。由于IAR调试时老是闪退,想换STM32CubeIDE用用,安装了最新的1.42版本。但就是
    发表于 04-07 07:14