
在STM32的定时器中,预分频器(Prescaler-PSC)用来将定时器时钟源进行分频输出。 预分频器的值由寄存器TIMx_PSC设定,是一个16位正整数值。 ; I0 }8 P/ w' z% f ![]() STM32CubeMX中的TIM预分频设置 , z* M% O7 M' A/ A% {& ~; y7 ^ 在STM32系统中,定时器的时钟源为内部时钟时,其频率一般都比较高,以STM32F103的TIM1为例,其总线时钟最大为72MHz,体现在16位的定时器上的效果就是从0计数到65535上溢只需要0.9毫秒。如果我们需要更长时间的定时间隔,那么就需要预分频器对时钟进行分频处理,以降低定时器时钟(CK_CNT)的频率。* w0 B6 r2 n1 M" s+ Q- W/ _ 除此之外,也可以通过配置预分频器,来获取想要的定时器时钟频率。依然以上边的TIM1为例,如果我们想获取一个精确的1ms中断,如果不分频,72MHz的时钟对应每周期1/72us,十分不利于计算。这时候使用预分频器将其72分频后为1MHz,每周期1us,1000个计时周期即为1ms,这样既便于计算,定时也更加精确。( d) H0 d" R- n5 T1 E/ N, [# g4 u 预分频器的工作的工作原理是,定时器时钟源每tick一次,预分频器计数器值+1,直到达到预分频器的设定值,然后再tick一次后计数器归零,同时,CNT计数器值+1。 由此可以看出,因为达到最大值后还要再tick一次才归零,所以定时器时钟频率应该为Fosc/(PSC+ 1)。其中Fosc是定时器的时钟源。比如想对时钟源进行72分频,那么预分频器的值就应该设置为71。 预分频器值寄存器TIMx_PSC存在影子寄存器(官方翻译为缓冲功能),所以在定时器启动后更改TIMx_PSC的值并不会立即影响当前定时器的时钟频率。要等到下一个更新事件(UEV)发生时才会生效。比如下边这张图就体现了将分频系数由1修改为2(即TIMx_PSC由0更改为1)时整个定时器的时序图。 8 v/ x+ m4 B& w [3 {! I ![]() 1 l( Y+ ]. c! W4 {7 C( l. a7 q! | 预分频器值更改时的定时器时序图/ n/ c! G" P/ x7 J 更新事件(UEV)则由TIMx_CR1寄存器中的UDIS位控制,在启用时,会通过以下两种方式触发:2 H& ]4 s, i; ` ?计数器上溢9 V p6 R/ D5 E0 O* b( K8 u5 _ ?手动将 TIMx_ ————————————————: n; ?5 [' K: I& y6 | 版权声明:华维编程猿 如有侵权请联系删除 + b7 t3 N# ?* C' H$ Y9 g- c |
基于定时器捕获测量脉宽的应用示例
狂欢三】STM32C031使用TIM定时器DMA方式实现WS2812彩灯输出(三)
【狂欢三】STM32C031使用TIM定时器DMA方式实现PWM输出(二)
【狂欢三】STM32C031使用TIM定时器PWM输出
stm32使用定时器触发dma传输,启动dma没反应的几种情况的解决方法
定时器剩余通道是否可以做PWM输出呢?
基于STM32双定时器+ADC+DMA实战经验分享
基于STM32的定时器触发ADC时可能遇到的情形
【NUCLEO-U545RE-Q评测】5. 基本计时器
基于STM32的定时器不按设定超时产生中断