STM32F4 DWT功能 实现程序运行时间精确测试

时间戳相关寄存器定义
/*
在Cortex-M里面有一个外设叫DWT(Data Watchpoint and Trace),
该外设有一个32位的寄存器叫CYCCNT,它是一个向上的计数器,
记录的是内核时钟运行的个数,最长能记录的时间为:
10.74s=2的32次方/400000000
(假设内核频率为400M,内核跳一次的时间大概为1/400M=2.5ns)
当CYCCNT溢出之后,会清0重新开始向上计数。
使能CYCCNT计数的操作步骤:
1、先使能DWT外设,这个由另外内核调试寄存器DEMCR的位24控制,写1使能
2、使能CYCCNT寄存器之前,先清0
3、使能CYCCNT寄存器,这个由DWT_CTRL(代码上宏定义为DWT_CR)的位0控制,写1使能
*/

#define  DWT_CR      *(__IO uint32_t *)0xE0001000
#define  DWT_CYCCNT  *(__IO uint32_t *)0xE0001004
#define  DEM_CR      *(__IO uint32_t *)0xE000EDFC


#define  DEM_CR_TRCENA                   (1 << 24)
#define  DWT_CR_CYCCNTENA                (1 <<  0)

//初始化时间戳
void HAL_InitTick()
{
    /* 使能DWT外设 */
    DEM_CR |= (uint32_t)DEM_CR_TRCENA;                

    /* DWT CYCCNT寄存器计数清0 */
    DWT_CYCCNT = (uint32_t)0u;

    /* 使能Cortex-M DWT CYCCNT寄存器 */
    DWT_CR |= (uint32_t)DWT_CR_CYCCNTENA;
}

/**
  * @brief  读取当前时间戳
  * @param  无
  * @retval 当前时间戳,即DWT_CYCCNT寄存器的值
  */
uint32_t CPU_TS_TmrRd(void)
{        
  return ((uint32_t)DWT_CYCCNT);
}

测试:

STM32F407 168M

HAL_InitTick();
delay_ms(1);
uint32_t time_= CPU_TS_TmrRd();//168260

HAL_InitTick();
delay_ms(2);
time_= CPU_TS_TmrRd();//336258

HAL_InitTick();
delay_us(100);
time_= CPU_TS_TmrRd();//16964

HAL_InitTick();
delay_us(200);
time_= CPU_TS_TmrRd();//33816

HAL_InitTick();
delay_us(300);
time_= CPU_TS_TmrRd();//50576

//延时100us 计数值大概16800

参考链接:
https://segmentfault.com/a/1190000020712516

你可能感兴趣的:(keil,STM32,stm32,单片机,嵌入式硬件)