前言
定时器作为微控制器不可缺少的外设,在stm32中也是如此。相信不少初学者学到定时器的时候对stm32的学习热情就大打折扣甚至想要放弃了,因为这一部分知识确实比较复杂。但是,如果你在之前对gpio、串口通信、外部中断的学习中把这些外设掌握了的话,学习这个新知识并不难。
例本章共计1万余字,从stm32定时器的原理、寄存器介绍、定时器配置以及定时器的几个常用的功能(如定时器中断、定时器输出比较pwm波形、定时器输入捕获测电平长度、定时器编码器模式应用等)的使用方法来教大家掌握定时器这一外设。
一、定时器基本介绍1. stm32定时器1、上来说就是用来定时的机器,是存在于stm32单片机中的一个外设。stm32总共有8个定时器,分别是2个高级定时器(tim1、tim8),4个通用定时器(tim2、tim3、tim4、tim5)和2个基本定时器(tim5、tim6),如下图所示:
这三种定时器的区别如下:
即:高级定时器具有捕获/比较通道和互补输出,通用定时器只有捕获/比较通道,基本定时器没有以上两者。
2. 通用定时器功能和特点stm32的众多定时器中我们使用最多的是高级定时器和通用定时器,而高级定时器一般也是用作通用定时器的功能,下面我们就以通用定时器为例进行讲解,其功能和特点包括:
位于低速的apb1总线上(apb1)
16 位向上、向下、向上/向下(中心对齐)计数模式,自动装载计数器(timx_cnt)。
16 位可编程(可以实时修改)预分频器(timx_psc),计数器时钟频率的分频系数 为 1~65535 之间的任意数值。
4 个独立通道(timx_ch1~4),这些通道可以用来作为:
① 输入捕获 ② 输出比较 ③ pwm 生成(边缘或中间对齐模式) ④ 单脉冲模式输出可使用外部信号(timx_etr)控制定时器和定时器互连(可以用 1 个定时器控制另外一个定时器)的同步电路。如下事件发生时产生中断/dma(6个独立的irq/dma请求生成器):①更新:计数器向上溢出/向下溢出,计数器初始化(通过软件或者内部/外部触发) ②触发事件(计数器启动、停止、初始化或者由内部/外部触发计数) ③输入捕获 ④输出比较 ⑤支持针对定位的增量(正交)编码器和霍尔传感器电路 ⑥触发输入作为外部时钟或者按周期的电流管理stm32 的通用定时器可以被用于:测量输入信号的脉冲长度(输入捕获)或者产生输出波形(输出比较和 pwm)等。
使用定时器预分频器和 rcc 时钟控制器预分频器,脉冲长度和波形周期可以在几个微秒到几个毫秒间调整。stm32 的每个通用定时器都是完全独立的,没有互相共享的任何资源。
3. 计数器模式
通用定时器可以向上计数、向下计数、向上向下双向计数模式。
①向上计数模式:计数器从0计数到自动加载值(timx_arr),然后重新从0开始计数并且产生一个计数器溢出事件。
②向下计数模式:计数器从自动装入的值(timx_arr)开始向下计数到0,然后从自动装入的值重新开始,并产生一个计数器向下溢出事件。
③中央对齐模式(向上/向下计数):计数器从0开始计数到自动装入的值-1,产生一个计数器溢出事件,然后向下计数到1并且产生一个计数器溢出事件;然后再从0开始重新计数。
** 4. 定时器工作原理**
a.定时器框图
下面就是stm32定时器的工作款图了,是学习stm32定时器必须要掌握的。很多学习者学会了通过库函数来配置定时器,实现了简单的应用却忽略了基本原理,这就对导致在复杂应用的设计上出现低级的错误。所以建议读者认真掌握定时器的工作框图,明白内在的原理。
框图可以分为四个大部分(用红色笔表示出),分别是:①时钟产生器部分,②时基单元部分,③输入捕获部分、④输出比较部分。
b.时钟产生器部分
在第一部分时钟选择上,stm32定时器有四种时钟源选择(图中蓝色笔标识),分别是:
①内部时钟(ck_int)
②外部时钟模式:外部触发输入(etr)
③内部触发输入(itrx):使用一个定时器作为另一个定时器的预分频器,如可以配置一个定时器timer1而作为另一个定时器timer2的预分频器。
④外部时钟模式:外部输入脚(tix)
这四种情况可由右图表示:
其中,内部触发输入口1~4除了itr1/itr2/itr3/itr4之外还有一种情况:用一个定时器作为另一个定时器的分频器。
外部捕获比较引脚有两种,分别是:
引脚1:ti1fp1或ti1f_ed
引脚2:ti2fp2
c.时基单元
时基单元就是定时器框图的第二部分,它包括三个寄存器,分别是:计数器寄存器(timx_cnt)、预分频器寄存器(timx_psc)和自动装载寄存器(timx_arr)。对这三个寄存器的介绍如下:
计数器寄存器(timx_cnt)
向上计数、向下计数或者中心对齐计数;
计数器寄存器(timx_cnt)
可将时钟频率按1到65535之间的任意值进行分频,可在运行时改变其设置值;
自动装载寄存器(timx_arr)
如果timx_cr1寄存器中的arpe位为0,arr寄存器的内容将直接写入影子寄存器;如果arpe为1,arr寄存器的那日同将在每次的更新时间uev发生时,传送到影子寄存器;
如果tim1_cr1中的udis位为0,当计数器产生溢出条件时,产生更新事件。
d.输入捕获通道
ic1、2和ic3、4可以分别通过软件设置将其映射到ti1、ti2和ti3、ti4;
4个16位捕捉比较寄存器可以编程用于存放检测到对应的每一次输入捕捉时计数器的值;
当产生一次捕捉,相应的ccxif标志位被置1;同时如果中断或dma请求使能,则产生中断或dma请求。
如果当ccxif标志位已经为1,当又产生一个捕捉,则捕捉溢出标志位ccxof将被置1。
v
e.输出比较通道(pwm)
pwm模式运行产生:
定时器2、3和4可以产生4独立的信号 频率和占空比可以进行如下设定: 一个自动重载寄存器用于设定pwm的周期; 每个pwm通道有一个捕捉比较寄存器用于设定占空时间。 例如:产生一个40khz的pwm信号:在定时器2的时钟为72mhz下,占空比为50% : 预分频寄存器设置为0 (计数器的时钟为tim1clk/(o+1)),自动重载寄存器设为 1799,ccrx寄存器设为899。两种可设置pwm模式:
边沿对齐模式 中心对齐模式
二、定时器中断应用1.内部时钟选择
除非apb1的分频系数是1,否则通用定时器的时钟等于apb1时钟的2倍。
默认调用systeminit函数情况下:
sysclk=72m
ahb时钟=72m
apb1时钟=36m
所以apb1的分频系数=ahb/apb1时钟=2
所以,通用定时器时钟ck_int=2*36m=72m
2.计数器模式
向下计数模式:(时钟分频因子=1)
向下计数模式:(时钟分频因子=1)
中央对齐计数模式:(时钟分频因子=1 arr=6)
** 3.定时器中断实验相关寄存器**计数器当前值寄存器cnt
预分频寄存器timx_psc
自动重装载寄存器(timx_arr)
控制寄存器1(timx_cr1)
dma中断使能寄存器(timx_dier)
米尔ARM+FPGA架构开发板PCIE2SCREEN示例分析与测试
任正非以不成功就跳楼 逼出一个芯片女皇
一条SQL如何被MySQL架构中的各个组件操作执行的?
传感器技术在防盗技术方面的应用
苹果13.2.2系统好不好
剖析STM32-定时器1
雙極電晶體模型及電路
中国物联网行业结构及发展趋势报告
石油化工行业的自动化控制系统有哪些
上海规划2025年新能源汽车比重将在35%以上
什么是防爆对讲机,防爆对讲机的产生对一些行业造成了什么印象
3D打印机应该如何做3D打印设计
苹果获得全新家用供电途径专利
AI算力6年增长30万倍,软硬件能力增长破除深度学习“寒冬论”
历代天翼UIM手机卡图集 从一开始的32K容量到现在的512K到底发生了哪些变化
Littelfuse新推250V电信PPTC产品系列,双通道PPTC封装尺寸缩小50%
芯启源科技®射频电缆组件
浅谈PCB行业中减少碳排放的方法
数字滤波器的技术指标_数字滤波器有哪几种
车辆跟踪系统可用于实时跟踪的主动数据传输