cyclingsensor的profile要求的。系统的timer都是1ms
This thread has been locked.
If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.
Hi tony,
给个例子, 如果你用的是32M 的clock, 则每32个"nop" 就是 1 us.
void delayUs(uint16 microSecs)
{
while(microSecs--)
{
/* 32 NOPs == 1 usecs */
asm("nop"); asm("nop"); asm("nop"); asm("nop"); asm("nop");
asm("nop"); asm("nop"); asm("nop"); asm("nop"); asm("nop");
asm("nop"); asm("nop"); asm("nop"); asm("nop"); asm("nop");
asm("nop"); asm("nop"); asm("nop"); asm("nop"); asm("nop");
asm("nop"); asm("nop"); asm("nop"); asm("nop"); asm("nop");
asm("nop"); asm("nop"); asm("nop"); asm("nop"); asm("nop");
asm("nop"); asm("nop");
}
}
hi 托尼,
ll_McuPrecisionCount() 并不是计数器.
你可以看到, 这货只是在空闲的时候通过osal_run_system() 调用osalTimeUpdate() 时被调用到,
所以, 本质上这货做的其实只是在空闲的时候去读一下timer2 的寄存器值, 读出来的值用来判断跟上一次读timer2 的时候过去了多久, 以这种方式提供给上层应用的软件timer 们计时功能. 而且, 这个只是计算过去了多少个 625us.
而timer2 是LL 层专用的计时器, 独占的.
根据你的需求, 如CZ 所建议, 你可以用另外一个系统计时器.
你可以用系统的timer1,
系统时钟32M的话, timer1 可以输出最高 1/32M 秒. 这样你只要计 32000 个就有1/1K 的了.
timer1 还可以有8, 32 或者 128 的分频, 你可以试一下.
Hi tony,
系统总共有4个timer, 分别是timer1, timer2, timer3, timer4
其中timer2 被LL 层占用, 不对用户开放, 目前timer2 也为上层应用的软件timer 提供计时, 具体实现就像我前面描述的, 上层只是去读timer2 的计时寄存器去判断时间差.
timer1 是个16位的计时器, timer3 和 timer4 都是8位的计时器.
你可以配置这3个计时器去达到你的1/1024 s 的要求.