How to get time intervals on STM32?

痞子三分冷 提交于 2019-12-17 19:54:29

问题


I want to measure how long does a single function take on STM32. The only thing I could find is SysTick_Handler. However, that is an periodic interrupt, but what I need is get time interval like:

long t1 = mcu_clock();
sleep(20);
long t2 = mcu_clock();
long diff = (t2 - t1);

I've tried C clock(), but it didn't work and always return -1. How can I make it?


回答1:


First, enable the cycle counter once at startup:

CoreDebug->DEMCR |= CoreDebug_DEMCR_TRCENA_Msk;
DWT->CYCCNT = 0;
DWT->CTRL |= DWT_CTRL_CYCCNTENA_Msk;

then, you can access its value:

unsigned long t1 = DWT->CYCCNT;
/* do something */
unsigned long t2 = DWT->CYCCNT;
unsigned long diff = t2 - t1;

It counts the elapsed cpu cycles, you have to divide it with the cpu clock frequency to get a value in seconds.

As it's a 32 bit value, it can overflow quite fast at higher clock frequencies, e.g in 19.88 seconds at 216 MHz.



来源:https://stackoverflow.com/questions/42246125/how-to-get-time-intervals-on-stm32

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!