28379中有三个系统时钟,需要研究这三个时钟和cpu12的关系及差别。可以在主函数中初始化时钟,然后在代码块前后获取计数值,计算插值,换算为时间。
这给了程序性能优化的第一个方向:cpu性能消耗优化。
初始化:
InitCpuTimers();
ConfigCpuTimer(&CpuTimer0, 200, 0xFFFFFFFF);
CpuTimer0Regs.TCR.all = 0x4000;
取值:
//程序开始处:
Uint32 startTime = CpuTimer0Regs.TIM.all;
//程序结束处:
Uint32 endTime = CpuTimer0Regs.TIM.all;
Uint32 Number=startTime-endTime;
根据周期计算时间,如上设定计时器频率是200万,那每次计数是5ns,即0.005微秒。中断频率是5000的话,周期是200微秒,那200微秒如果定时器要计数40000次,所以单次中断中定时器计数超过20000就占了50%就不太行了.如果这段程序在中断里,看这个耗时占中断周期的多少,不超过70%为宜.如果这段程序在主循环里,那么要看具体耗时,比如tcp通讯10ms,那就是20万次计数。