你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

【经验分享】Stm32高级定时器

[复制链接]
STMCU小助手 发布时间:2022-1-18 21:44
1 定时器的用途
2 高级定时器框图
3 时基单元
4 通道
1 定时器的用途
  • 已知一个波形求另一个未知波形(信号长度和占空比)
  • 已知波形的信号长度和占空比产生一个相应的波形
  • 增量正交编码器驱动电机获得动态信息(速度、加速度)
  • 测量输入信号的脉冲宽度(输入捕获)
  • 产生输出波形(输出比较、PWM、嵌入死区时间的互补PWM等)
  • ……5 H% h7 c3 E! {3 F
我们知道,当我们需要测量一段直线的长度时,我们需要一把直尺,根据直尺上的刻度读出直线的长度,定时器也相当于直尺能够测量和产生特定的波形。
比较项
定时器
直尺
最小刻度
CNT频率
1mm/1cm
测量给定单元
输入捕获(PWM捕获)
长度测量
产生单元
输出比较(PWM输出)
划线

- m; D# w% y3 D3 W/ N! k4 a2 高级定时器框图
0 }0 _: R7 ~( ?( D9 X1 D% G9 V
847278-20160930210719141-701314717.jpg 6 X. K# e6 Y) b/ \3 X
定时器以时基单元位核心,输入捕获、输出比较和刹车功能等所有的功能运行都围绕时基单元的计数器进行。”驱动动力”指时基单元的驱动来源,主要分内外时钟。
3 时基单元
3.1 主要寄存器
计数器寄存器(TIMx_CNT)
预分频器寄存器(TIMx_PSC)
自动装载寄存器(TIMx_ARR)
重复次数寄存器(TIMx_RCR)

) p+ S! V( O2 m/ A- f
847278-20160930210720203-1195043871.png
( X7 X. E0 t4 Z5 d. j
工作流程:
内部或外部驱动时钟CK_PSC驱动预分频器PSC计数分频,产生CK_CNT驱动计数器CNT计数。自动重装载寄存器在发生更新事件时将值传到计数器CNT中作为初始计数值,REP寄存器则控制CNT溢出次数,当重复次数计数器从REP寄存器的数值递减至0是计数器CNT停止计数。
3.2 影子寄存器
  有阴影的寄存器,表示在物理上这个寄存器对应2个寄存器,一个是程序员可以写入或读出的寄存器,称为preload register(预装载寄存器),另一个是程序员看不见的、但在操作中真正起作用的寄存器,称为shadow register(影子寄存器);
3.3 计数模式
向上计数模式:
  在向上计数模式中,计数器从0计数到自动加载值(TIMx_ARR计数器的内容),然后重新从0开始计数并且产生一个计数器溢出事件。
向下计数模式:
  在向下模式中,计数器从自动装入的值(TIMx_ARR计数器的值)开始向下计数到0,然后从自动装入的值重新开始并且产生一个计数器向下溢出事件。
中央对齐模式:
  在中央对齐模式,计数器从0开始计数到自动加载的值(TIMx_ARR寄存器)-1,产生一个计数器溢出事件,然后向下计数到1并且产生一个计数器下溢事件;然后再从0开始重新计数。
3.4重复计数器功能
  如果使用了重复计数器功能,在向上计数达到设置的重复计数次数(TIMx_RCR)时,产生更新事件(UEV);否则每次计数器溢出时才产生更新事件。
4 通道
4.1 时钟选择
内部时钟(CK_INT)

+ W& X* o1 H4 A
847278-20160930210720953-2128245012.jpg

8 ^. _9 f* y! J- V. ?6 [9 ?
外部时钟模式1:外部输入引脚
. b: ?5 f: p2 ~. a3 o/ t8 _
847278-20160930210722047-92478166.png
% B8 c5 s# `8 ^+ H1 e# E
847278-20160930210723266-1412614186.jpg

! E+ z/ F& V9 D- N$ l
要配置向上计数器在T12输入端的上升沿计数,使用下列步骤:
1. 配置TIMx_CCMR1寄存器CC2S=01,配置通道2检测TI2输入的上升沿。
2. 配置TIMx_CCMR1 寄存器的 IC2F[3:0],选择输入滤波器带宽(如果不需要滤波器,保持 IC2F=0000)
3. 配置TIMx_CCER寄存器的CC2P=0,选定上升沿极性
4. 配置TIMx_SMCR寄存器的SMS=111,选择定时器外部时钟模式1
5. 配置TIMx_SMCR寄存器中的TS=110,选定TI2作为触发输入源
6. 设置TIMx_CR1寄存器的CEN=1,启动计数器
● 外部时钟模式2:外部触发输入ETR

4 V0 f- P; c5 a3 g% |
847278-20160930210724094-526851305.png

( {9 @. M6 W0 G8 P; S1 X0 e
847278-20160930210724844-1976737354.jpg

1 C5 g0 E) z. c: Z( Q! _: }
选定此模式的方法为:令TIMx_SMCR寄存器中的ECE=1
计数器能够在外部触发ETR的每一个上升沿或下降沿计数。
要配置在ETR下每2个上升沿计数一次的向上计数步骤:
1. 本例中不需要滤波器,置TIMx_SMCR寄存器中的ETF[3:0]=0000
2. 设置预分频器,置TIMx_SMCR寄存器中的ETPS[1:0]=01
3. 选择ETR的上升沿检测,置TIMx_SMCR寄存器中的ETP=0
4. 开启外部时钟模式2,写TIMx_SMCR寄存器中的ECE=1
5. 启动计数器,写TIMx_CR1寄存器中的CEN=1
注:设置ECE位与选择外部时钟模式1并将TRGI连到ETRF ( SMS=111和TS=111 ) 具有相同功效。
● 内部触发输入(ITRx)

2 }" C6 h6 y2 X: d7 g& d" j
847278-20160930210725703-1222478073.jpg
1 A% L  ~/ P* i7 I# N7 f
4.2 输入捕获通道
: d3 @. _: n' `2 r* X' q3 K
847278-20160930210726313-1077397609.png
8 H* O$ M2 v; G( k9 \! {
847278-20160930210731828-2040430519.jpg
  L5 m% t& D5 u0 Y# d: F
当触发捕获时,计数器CNT的值传到捕获寄存器中。
配置在TI1输入的上升沿时捕获计数器的值到TIMx_CCR1寄存器中:
选择有效输入端:TIMx_CCR1必须连接到TI1输入,所以写入TIMx_CCR1寄存器中的CC1S=01,一旦CC1S不为00时,通道被配置为输入,并且TIMx_CCR1寄存器变为只读。
根据输入信号的特点,配置输入滤波器为所需的带宽(即输入为TIx时,输入滤波器控制位是 TIMx_CCMRx寄存器中的ICxF位)。假设输入信号在最多5个时钟周期的时间内抖动,我们须配置滤波器的带宽长于5个时钟周期;因此我们可以(以fDTS频率)连续采样8次,以确认在TI1上一次真实的边沿变换,即在TIMx_CCMR1寄存器中写入IC1F=0011。
选择TI1通道的有效转换边沿,在TIMx_CCER寄存器中写入CC1P=0(上升沿)。
配置输入预分频器。在本例中,我们希望捕获发生在每一个有效的电平转换时刻,因此预分频器被禁止(写TIMx_CCMR1寄存器的IC1PS=00)。
设置TIMx_CCER寄存器的CC1E=1,允许捕获计数器的值到捕获寄存器中。
如果需要,通过设置TIMx_DIER寄存器中的CC1IE位允许相关中断请求,通过设置TIMx_DIER寄存器中的CC1DE位允许DMA请求。
4.3 输出比较通道

  q' K* T- p% C0 E2 e
847278-20160930210733203-1730593224.png

# f3 n' B0 h2 {+ z8 g; V
847278-20160930210734125-2036198122.jpg

: p, y% S8 p1 V0 _; b0 K  F
4.4 刹车通道

8 N/ C7 o( D, |( ^: h0 b3 i7 @

) q3 u+ P1 ^& l 847278-20160930210735047-1363951260.png % H% D; x  C4 ~! R% ]6 v/ j$ M

. |+ O1 r, x! o5 e形而上者谓之道 形而下者谓之器。" f7 k+ C% j- s' e% F) R& q

7 ^7 d/ ?, G2 I) x
, V" y' ]4 _' n. [9 W) h
收藏 评论0 发布时间:2022-1-18 21:44

举报

0个回答
关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新和工艺
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版