问一个问题,如果需要测量一个函数的执行时间,一般使用什么办法?我想各位看官应该都有自己的方法吧。
那我自己来说,只要有示波器,我肯定使用GPIO翻转,然后用示波器测量的方法。如果没有示波器,则使用Systick中的Count或则是定时器的Count来计数的方法。但是经过好友的提醒,原来Cortex-M3中还有另外一个方法。
大家都应该知道Cortex-M3中有很多的调试组件,什么ITM,ETM,DWT等等。如果可以的话,您看看DWT的寄存器,就可以发现,原来DWT(Data Watchpoint and Trace),中有一个CYCCNT。周期计数器。
Cortex-M3内核的调试组件,如要要详细说,还是需要一些技术功底的。但是秉承拿来主义,我们先学会如何去使用这样的一个功能,例程代码如下:
#include "efm32.h"
#include "em_emu.h"
#include "em_cmu.h"
#include "em_chip.h"
unsigned int time;
void main(void)
{
CHIP_Init();
/* Enable DWT */
CoreDebug->DEMCR |= CoreDebug_DEMCR_TRCENA_Msk;
/* Make sure CYCCNT is running */
DWT->CTRL |= 1;
while(1)
{
time = DWT->CYCCNT;
unsigned int delay = 1000;
while(delay--);
time = DWT->CYCCNT - time;
}
}
PS:有关的参考资料,可以从这里下: