当前位置: 首页 > article >正文

FreeRTOS和Systemview联合调试——M0内核

最近想用Systemview分析FreeRTOS,参考了网上很多大佬的教程,但是大多是armM3、M4内核的芯片,而本人用的是M0内核,systemview配置有所不同,也是踩了一些坑,在这里记录一下,也希望后来看到的小伙伴能够顺利配置;

系统环境:

  • 目标芯片:STM32G070KBT6
  • CubeMX版本:6.8.1
  • Keil版本:5.36
  • FreeRTOS版本:10.3.1
  • SystemView源码版本:3.50a
  • SystemView上位机版本:3.12

一、systemview代码嵌入

试了网上一些配置方法都不行,keil编译报一堆错,最后我参考的是这个大佬的步骤,如果用cubemx生成freertos的可以参考这个,手动移植的话我还没试过。

STM32 为CubeMX FreeRTOS项目添加Segger SystemView支持 - 四文鱼Max的博客站 (awolon.fun)

在跟着配置完之后编译出错,如下,显示在segger_sysview.c中有函数SEGGER_SYSVIEW_X_GetTimestamp()没定义:

然后再看这篇关于Systemview的文章章节7 支持的CPU - Segger SystemView使用手册(译文)_cmsis compatible projects-CSDN博客中提到:

即M0/M0+和M1内核还要我们在在segger_sysview.c中手动编写SEGGER_SYSVIEW_X_GetTimestamp(),函数形式那篇博客里面也有,这里我把我的截个图:

再次编译显示无错误;但是注意!!!只该这里还不行!我们还要在freertos的port.c文件里面加点东西,根据这两篇SEGGER官网论坛文章:

[SOLVED] SysView timestamps overflow / wrap with SysTick handler on ARM Cortex M0+ - SEGGER SystemView related - SEGGER - Forum

[SOLVED] ​Problems viewing ARM Cortex-M0+ FreeRTOS tasks in System View - SEGGER SystemView related - SEGGER - Forum

我们知道我们还要在port.c中xProtSysTickHandller()的开头增加一句话,如下:

这里我加了一个宏定义以便不用systemview的时候可以方便的将这行代码从原有代码中剔除;如果不加这行代码,用systemview调试freertos的时候会发现RTOS的任务运行时间完全不准;

二、systemview上位机使用

    到这里,我们就已经把systemview的代码嵌入到我们M0内核芯片的原有程序中去了,接下来我们只需要用jlink连接芯片,然后运行程序,再打开systemview上位机就可以观察到FreeRTOS的运行过程了。但是!又有一个坑,再本人用V3.50a版本的上位机连接jlink的时候,按理来说是这个过程:

一、选择连接方式,这里选择Jlink

二、弹出芯片选择界面,选择芯片,然后建立连接

    但是!我用3.50a版本的systemview上位机没有第二步!每次选择完jlink连接之后就没了,没有弹出芯片选择界面弹窗,我还找半天原因不知道为啥,后面又下了个3.54a版本的上位机也是一样的问题。我不知道是我的jlink是d版的还是因为后面高版本的上位机需要license才可以,反正我连不上,最后不死心下了个V3.12版本的上位机,终于可以选择芯片了,我真的哭死。

    但是到这里就完了吗?还没有结束,打开V3.12上位机后就会弹出下面这个警告,导致你选择芯片后也无法和芯片连接,说少了一个dll文件,这不巧了吗?我发现前段时间用的Ozone调试器(也是SEGGER公司的,这个调试器可以把程序变量的变化用曲线描绘出来,具体怎么使用可以百度,还蛮简单的)里面就有这个dll文件,我直接一个巧思,把该文件复制粘贴到Systemview上位机文件夹里面,警告解决。

三、结果分析

至此,在经历了重重艰难险阻之后,终于能顺利用systemview调试freertos了,我建立了三个任务,里面依次调用了1ms,2ma,3ms的HAL_Delay的死延迟,然后看看程序运行时间是否准确:

​​​​​​​

可以看出来目前的程序运行还是满准确的。


http://www.kler.cn/news/342387.html

相关文章:

  • 使用Pytorch+Numpy+Matplotlib实现手写字体分类和图像显示
  • 【分布式微服务云原生】战胜Redis脑裂:深入解析与解决方案
  • Python中的Socket魔法:如何利用socket模块构建强大的网络通信
  • “国货户外TOP1”凯乐石签约实在智能,RPA助力全域电商运营自动化提效
  • 企业如何借力AI,提升人力资源管理的效率完成组织提效变革
  • processing像素画教程
  • 高防服务器为何有时难以防御CC攻击及其对策
  • 手机控车系统是一种高科技的汽车智能控制系统?
  • VR科技云展如何以沉浸式体验引领科技成果新展示
  • Linux使用Docker部署Paperless-ngx结合内网穿透打造无纸化远程办公
  • tcpdump深入浅出
  • Java | Leetcode Java题解之第470题用Rand7()实现Rand10()
  • 最新golang语言面试题总结(四)
  • RabbitMQ消息接收类Receiver
  • 细说QT各种线程锁的特点和用法
  • JAVA学习-练习试用Java实现“反转链表 II”
  • C#中,重载(overload) 重写(override)的应用说明
  • Ubuntu安装nvidia显卡驱动
  • [云] DockerCoins 练习笔记
  • HUAWEI_HCIA_实验指南_Lib1.6_配置通过FTP进行文件操作