stm32关于通用定时器的周期、频率计算公式

本文详细介绍了STM32定时器的中断实验,包括时基单元、时钟来源、预分频器和自动装载寄存器的工作原理。定时器时钟频率通过预分频系数(psc)进行分频,计数器频率为Tclk/(psc+1)MHz。当计数器达到预设的自动装载值时,会产生溢出中断。通过计算预分频系数和重装载值,可以精确设定定时器的周期。举例说明,配置定时器在默认系统时钟下生成1ms的时钟信号。内容适合嵌入式硬件和STM32开发者参考。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

以下内容针对正点原子的定时器中断实验

定时器时基单元包含:

● 计数器寄存器(TIMx_CNT)
● 预分频器寄存器 (TIMx_PSC)——该寄存器用设置对时钟进行分频,然后提供给计数器,作为计数器的时钟。
● 自动装载寄存器 (TIMx_ARR)

定时器的时钟来源(4个):

        1)内部时钟(CK_INT)
        2)外部时钟模式 1:外部输入脚(TIx)
        3)外部时钟模式 2:外部触发输入(ETR)
        4)内部触发输入(ITRx)


Tclk是定时器时钟源,默认情况下是72Mhz 。
我们将分配的时钟进行分频,指定分频值为psc,就将我们的Tclk分了psc+1,我们定时器的最终频率就是Tclk/(psc+1) MHz
这里的频率的意思就是1s中记 Tclk/(psc+1)M个数 (1M=10的6次方) ,每记一个数的时间为(psc+1)/Tclk ,很好理解频率的倒数是周期,这里每一个数的周期就是(psc+1)/Tclk 秒

通用定时器的主要部分是一个16位计数器和相关的自动装载寄存器。
此计数器时钟由预分频器分频得到,CK_INT -> TIMx_PSC -> CK_CNT。

APB1是通过对AHB分频得到,AHB是通过对SYSCLK分频得到。
当SYSCLK=72MHz,并且AHB分频系数=1时,AHB=72MHz。
当AHB=72MHz,并且APB1分频系数=2,APB1=36MHz,同时TIMxCLK=72MHz。

这里的 CK_INT 时钟是从 APB1 倍频的来的,除非 APB1 的时钟分频数设置为 1,否则通用定时器 TIMx 的时钟 是 APB1 时钟的 2 倍,当 APB1 的时钟不分频的时候,通用定时器 TIMx 的时钟就等于 APB1 的时钟。上述APB1预分频系数=2,所以通用定时器TIM2~TIM5 = 72MHz。

图1.内部时钟选择

图2.通用定时器工作流程图

当满足以下条件时,会产生溢出事件,去触发中断或者DMA请求:

  • 向上计数:计数器从0开始计数至arr(重装载)值,产生溢出事件
  • 向下计数:计数器从arr值开始计数至0,产生溢出事件

定时器的周期计算:

psc:预分频系数 (16位寄存器,有效值1~65535)
arr:重装载数 (16位寄存器,有效值1~65535)
Tclk:定时器的输入时钟源(单位MHZ)

注:计数器的arr和时钟分频psc都要加1,因为这两个值是配置在寄存器中的,从0开始计数,故要加1输入值 = 设置值 - 1

公式:

计数器的时钟频率 f = CK_CNT = f(ck_psc) / (psc+1) = Tclk / (psc + 1)  ,对时钟源分频 。
Tout溢出时间 =  (1/f) * (arr+1)  = ((psc+1) / Tlck) * (arr+1) 

如:F103默认配置下,生成1ms的时钟:Tout = (( 1+35 ) / 36M ) * ( 1+999 ) = 1ms

参考博文:

stm32 基本定时器定时配置

STM32定时器定时计算公式

内容可能有误,欢迎评论指正更改

### STM32定时器计算公式 对于STM32定时器而言,其时间计算主要依赖于三个关键参数:自动重装载值(ARR),预分频值(PSC)以及定时器的输入时钟频率(Tclk)[^2]。 #### 定时器溢出时间计算 定时器溢出时间\(T_{out}\)可以通过下面的公式得出: \[ T_{out}=\frac{(ARR+1)\times(PSC+1)}{Tclk} \] 这里, - \(ARR\)代表的是自动重载寄存器设置的最大计数值; - \(PSC\)指的是预分频寄存器设定用于减慢内部时钟速率的除法因子; - \(Tclk\)表示进入定时器模块之前的原始时钟速度,单位为MHz[^3]。 举例来说,如果希望创建一个持续时间为1秒的延迟,并假设系统的时钟频率为72 MHz,则可以根据上述公式调整ARR和PSC使得\(T_{out}=1\text{s}\): \[ 1s = \frac{(ARR+1)(PSC+1)}{72\times10^{6}} \] 进一步简化得到具体的ARR和PSC组合方式。例如,在某些情况下可以选择\(PSC=7199\) 和 \(ARR=999\) 来满足这个条件。 #### 实现特定延时的例子 为了实现精确的延时效果,比如1毫秒(ms), 可以按照如下方法配置: - 设置`PSC`=71(即\(72-1\)) - 设置`ARR`=999(即\(1000-1\)) 这样做的目的是让定时器每隔大约1 ms触发一次中断事件: ```c HAL_TIM_Base_Start_IT(&htim3); void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim){ if(htim->Instance==TIM3){ HAL_GPIO_TogglePin(LED_GPIO_Port,LED_Pin); } } ``` 这段代码展示了如何启动定时器并定义了一个回调函数来响应定时器到期事件,每当定时器达到设定的时间间隔就会切换LED的状态。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值