EFM32片内外设 -- DWT

问一个问题,如果需要测量一个函数的执行时间,一般使用什么办法?我想各位看官应该都有自己的方法吧。

那我自己来说,只要有示波器,我肯定使用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:有关的参考资料,可以从这里下:

http://download.csdn.net/detail/efm32/5674463

你可能感兴趣的:(Cortex-M3,Core)