SEGGER | 基于STM32F405 + Keil - RTT组件07 - J-Scope数据可视化,RTT方式 + DWT定时器时间戳

导言


在上一章节SEGGER | 基于STM32F405 + Keil - RTT组件06 - J-Scope数据可视化,使用RTT方式的第4.3章节提到,如果消息包不包含时间戳的话,那么J-Scope的横坐标的单位时间默认是100us,说白了时间戳是假的。会导致如下问题:

  1. 数据不具有时间关联性:没有时间戳的情况下,显示的数据点仅按接收到的顺序排列,而没有明确的时间信息。这意味着你无法知道每个数据点发生的精确时间,可能会导致无法有效分析数据的时序关系。
  2. 无法精确判断事件的发生顺序:如果系统有多任务或者时间敏感的操作,缺少时间戳意味着你无法清晰地区分不同事件之间的时间间隔,从而影响对系统运行状况的诊断。
  3. 数据分析困难:在进行系统性能分析、故障排查或优化时,时间戳非常重要。没有时间戳,可能会让你很难评估数据变化的趋势,无法有效关联系统内部的各项操作。

为解决上述问题,参考官方提供的时间戳例程,消息包添加上时间戳。

效果如下:

项目源码:https://github.com/q164129345/MCU_Develop/tree/main/jlink_scope_rtt_dwt_timestamp

一、代码


1.1、tim.c

如上图所示,定时器14的中断周期改为1ms。

1.2、main.c


二、观察时间戳与数据



从上面两图可以看到,正弦波的周期是100ms。因为定时器的中断周期是1ms,数据长度是100。波形很准。

从上两图可以看到,变量每隔1ms翻转一次,也很准确。

三、细节补充


3.1、消息包的类型,注意一下是4个字节

如上图所示,刚开始,msg1与msg2的变量类型用uint8_t,目的是减少消息包的字节数,毕竟msg1与msg2的值的范围在0 ~ 255。但是,J-Scope的波形显示不正常。后来,我改用uint32_t后,J-Scope的波形显示正常了。

相关推荐
十六宿舍8 分钟前
【MCAL】TC397+EB-tresos之I2c配置实战(同步、异步)
单片机·汽车·autosar·嵌入式开发·mcal·基础软件
Ronin-Lotus19 分钟前
嵌入式硬件篇---麦克纳姆轮(简单运动实现)
单片机·嵌入式硬件·麦克纳姆轮·运动解算
小智学长 | 嵌入式3 小时前
单片机-STM32部分:10-2、逻辑分析仪
stm32·单片机·嵌入式硬件
喜欢下雨t5 小时前
【嵌入式———SPI的基本操作——实验需求:案列1:软件模拟实现SPI协议和STM32的SPI模块实现(硬件实现)】
stm32·单片机·嵌入式硬件
金色光环5 小时前
1.stm32使用SSD1322 驱动3.12寸OLED
stm32·单片机·嵌入式硬件
腾飞的信仰11 小时前
51单片机同一个timer 作为定时器和波特率发生器么?
网络·单片机·51单片机
猿饵块16 小时前
STM32--PWM--函数
stm32·单片机·嵌入式硬件
学习噢学个屁17 小时前
基于51单片机步进电机控制—9个等级
c语言·单片机·嵌入式硬件·51单片机
LaoZhangGong12318 小时前
分析rand()和srand()函数的功能
c语言·经验分享·stm32·单片机
国科安芯19 小时前
自研MCU芯片闪存驱动的实现:OpenOCD详细过程记录与操作指南
单片机·嵌入式硬件·架构