1) LPC_TIM0->MR0 = TimerInterval ; 这条语句指定了定时器装载的匹配值,timer0计数到这个值时就会产生中断,并且在中断函数里把timer0_counter加1.
2)LPC_TIM1->PR = 0x00; /* set prescaler to zero */ 这条语句表明timer0预分频值设为0,就是说timer0对外设时钟不分频,每个外设时钟信号到来,都会使timer0的计数值加1.
3)#define TIME_INTERVAL (9000000/100 - 1) 这条语句说明timer0的匹配值是89999.也就是经过90000个外设时钟信号后,timer0将产生一次中断。因此timer0中断一次,计时的时间是90000/PCLK。如果PCLK=25MHz的话,则计时时间为(9/2.5)毫秒。
4)路虎开发板的timer例程中,PLL0输出的频率是400MHz,经4分频后,CPU的工作频率CCLK是100MHz。外设的频率是CCLK的4分频,也即25MHz。timer0计数的时钟PCLK就是25MHz。例程中50 * counter得到的延时是180ms。
5)Keil 'MCB1700' evaluation board的timer例程中,PLL0输出的频率是288MHz,4分频后CPU频率是72MHz,再经4分频后外设时钟是18MHz,若装载TIME_INTERVAL (9000000/100 - 1),每个时钟中断得到的延时是9/1.8=5毫秒。但实际例程中没有装载此值,而是根据外设时钟分频值(4分频)设定了时钟计数的预分频值,set prescaler to get 1 M counts/sec,即每计数1000000可得到1秒延时,然后装载了匹配值TIME_INTERVALmS * 10=10000,得到了10ms的延时。
#define TIME_INTERVAL 2499//(9000000/100 - 1) //计数9000000次,180ms,每次中断9/2.5,3.6ms
// 2499计数2500次,2500/25M,=0.1ms,就是10KZ
联系客服