2022-10-20 17:13:02 +08:00
|
|
|
/**
|
|
|
|
******************************************************************************
|
|
|
|
* @file bsp_dwt.h
|
|
|
|
* @author Wang Hongxi
|
2023-06-22 21:52:46 +08:00
|
|
|
* @author modified by NeoZng
|
|
|
|
* @version V1.2.0
|
2022-10-20 17:13:02 +08:00
|
|
|
* @date 2022/3/8
|
|
|
|
* @brief
|
|
|
|
******************************************************************************
|
|
|
|
* @attention
|
|
|
|
*
|
|
|
|
******************************************************************************
|
|
|
|
*/
|
|
|
|
#ifndef _BSP_DWT_H
|
|
|
|
#define _BSP_DWT_H
|
|
|
|
|
|
|
|
#include "main.h"
|
|
|
|
#include "stdint.h"
|
2023-06-22 21:52:46 +08:00
|
|
|
#include "bsp_log.h"
|
2022-10-20 17:13:02 +08:00
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
uint32_t s;
|
|
|
|
uint16_t ms;
|
|
|
|
uint16_t us;
|
|
|
|
} DWT_Time_t;
|
|
|
|
|
2023-06-22 21:52:46 +08:00
|
|
|
/**
|
|
|
|
* @brief 该宏用于计算代码段执行时间,单位为秒/s,返回值为float类型
|
|
|
|
* 首先需要创建一个float类型的变量,用于存储时间间隔
|
|
|
|
* 计算得到的时间间隔同时还会通过RTT打印到日志终端,你也可以将你的dt变量添加到查看
|
|
|
|
*/
|
|
|
|
#define TIME_ELAPSE(dt, code) \
|
|
|
|
do \
|
|
|
|
{ \
|
|
|
|
float tstart = DWT_GetTimeline_s(); \
|
|
|
|
code; \
|
|
|
|
dt = DWT_GetTimeline_s() - tstart; \
|
|
|
|
LOGINFO("[DWT] " #dt " = %f s\r\n", dt); \
|
|
|
|
} while (0)
|
2022-10-20 17:13:02 +08:00
|
|
|
|
2023-02-04 22:48:53 +08:00
|
|
|
/**
|
|
|
|
* @brief 初始化DWT,传入参数为CPU频率,单位MHz
|
2023-06-22 21:52:46 +08:00
|
|
|
*
|
2023-02-04 22:48:53 +08:00
|
|
|
* @param CPU_Freq_mHz c板为168MHz,A板为180MHz
|
|
|
|
*/
|
2022-10-20 17:13:02 +08:00
|
|
|
void DWT_Init(uint32_t CPU_Freq_mHz);
|
2023-02-04 22:48:53 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief 获取两次调用之间的时间间隔,单位为秒/s
|
2023-06-22 21:52:46 +08:00
|
|
|
*
|
2023-02-04 22:48:53 +08:00
|
|
|
* @param cnt_last 上一次调用的时间戳
|
|
|
|
* @return float 时间间隔,单位为秒/s
|
|
|
|
*/
|
2022-10-20 17:13:02 +08:00
|
|
|
float DWT_GetDeltaT(uint32_t *cnt_last);
|
2023-02-04 22:48:53 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief 获取两次调用之间的时间间隔,单位为秒/s,高精度
|
2023-06-22 21:52:46 +08:00
|
|
|
*
|
2023-02-04 22:48:53 +08:00
|
|
|
* @param cnt_last 上一次调用的时间戳
|
|
|
|
* @return double 时间间隔,单位为秒/s
|
|
|
|
*/
|
2022-10-20 17:13:02 +08:00
|
|
|
double DWT_GetDeltaT64(uint32_t *cnt_last);
|
2023-02-04 22:48:53 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief 获取当前时间,单位为秒/s,即初始化后的时间
|
2023-06-22 21:52:46 +08:00
|
|
|
*
|
2023-02-04 22:48:53 +08:00
|
|
|
* @return float 时间轴
|
|
|
|
*/
|
2022-10-20 17:13:02 +08:00
|
|
|
float DWT_GetTimeline_s(void);
|
2023-02-04 22:48:53 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief 获取当前时间,单位为毫秒/ms,即初始化后的时间
|
2023-06-22 21:52:46 +08:00
|
|
|
*
|
|
|
|
* @return float
|
2023-02-04 22:48:53 +08:00
|
|
|
*/
|
2022-10-20 17:13:02 +08:00
|
|
|
float DWT_GetTimeline_ms(void);
|
2023-02-04 22:48:53 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief 获取当前时间,单位为微秒/us,即初始化后的时间
|
2023-06-22 21:52:46 +08:00
|
|
|
*
|
|
|
|
* @return uint64_t
|
2023-02-04 22:48:53 +08:00
|
|
|
*/
|
2022-10-20 17:13:02 +08:00
|
|
|
uint64_t DWT_GetTimeline_us(void);
|
2023-02-04 22:48:53 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief DWT延时函数,单位为秒/s
|
|
|
|
* @attention 该函数不受中断是否开启的影响,可以在临界区和关闭中断时使用
|
|
|
|
* @note 禁止在__disable_irq()和__enable_irq()之间使用HAL_Delay()函数,应使用本函数
|
2023-06-22 21:52:46 +08:00
|
|
|
*
|
2023-02-04 22:48:53 +08:00
|
|
|
* @param Delay 延时时间,单位为秒/s
|
|
|
|
*/
|
2022-10-20 17:13:02 +08:00
|
|
|
void DWT_Delay(float Delay);
|
2023-02-04 22:48:53 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief DWT更新时间轴函数,会被三个timeline函数调用
|
|
|
|
* @attention 如果长时间不调用timeline函数,则需要手动调用该函数更新时间轴,否则CYCCNT溢出后定时和时间轴不准确
|
|
|
|
*/
|
2022-10-20 17:13:02 +08:00
|
|
|
void DWT_SysTimeUpdate(void);
|
|
|
|
|
|
|
|
#endif /* BSP_DWT_H_ */
|