
前言' s# Y. O! p( g 本文档:+ Y2 L# V; c; I ● 概述了 STM32F1xx、STM32F2xx、STM32F4xx、STM32L1xx 和 STM32F30/31/37/38x微控制器系列的定时器外设;# e% h; n9 D$ X; X K7 ?5 I1 l ● 介绍了定时器的多种模式和特殊功能,如时钟源; ● 介绍了如何使用各种可用模式与功能;2 E, A/ h& N, X1 t! t @( E' P ● 介绍了如何计算各种配置下的时基; ● 除基本定时器模式外,还介绍了定时器同步序列以及用于电机控制应用的高级功能。( c) }, e; S+ ` 本文档针对各模式提供了典型配置以及使用方法的示例。 除非另外说明,本文档余下部分中的术语 STM32xx 均用于指代 STM32F1xx、STM32F2xx、 STM32F4xx、 STM32L1xx 和 STM32F30/31/37/38x 微控制器系列。 ![]() : L: p: P! ?6 _+ D% C 1概述 STM 32 器件使用多种类型的定时器,各种定时器特点如下: ●通用定时器:可用于输出比较(时序和延迟生成)、单脉冲模式、输入捕捉(用于测量外部信号频率)、传感器接口(编码器和霍尔传感器)等各种场合。 ●高级定时器:此类定时器的功能最多。除通用功能外,它们还包含一些与电机控制和数字能量转换应用相关的功能:三个带死区控制的互补信号以及紧急关断输入。 ●单通道或双通道定时器:用作通用定时器,通道数有限。 ●带互补输出的单通道或双通道定时器:与上一类型相同,只是其中一个通道上具有死区发生器。这样可得到时基与高级定时器无关的互补信号。. `( X6 W9 G$ J1 f# y ●基本定时器:没有任何输入/输出,既可用作时基定时器,也可用于触发 DAC 外设。 表 2 汇总了 STM32 系列定时器。 表 3 给出了定时器特性的总览。文档 ID 022500 第 2 版 + [' R/ o# g5 y- L/ y6 @/ s9 G - P+ z$ M! t7 \+ y$ D, p" ^4 B. B ![]() , q0 Y& k8 u! `, R9 V ![]() 2基本定时器模式 基本定时器经过编程可在以下其中一种配置下工作。( a4 H1 v3 U" F( q 2.1时钟输入源/ V, [- L/ J3 i$ I" ?/ s. g' u' N 定时器可同时与多个时钟同步: ●内部时钟- U, s8 s) s. {5 l3 G ●外部时钟 —外部时钟模式 1(TI1 或 TI2 引脚) —外部时钟模式 2(ETR 引脚)5 W" ~" [4 {- C4 { —内部触发时钟 (ITRx) 1 J' b5 x6 a/ R3 U& p' N 2.1.1内部时钟# j- B, u4 q8 w7 U$ @ 默认情况下,定时器由 RCC 提供的内部时钟驱动。要选择该时钟源,应该将 SMCR_SMS(如果存在)位复位。" ]0 r3 c. v6 `8 j5 {! \ 5 d6 W# b7 X' p% T 2.1.2外部时钟 外部时钟定时器分为两类: ●连接到 TI1 或 TI2 引脚的外部时钟 ●连接到 ETR 引脚的外部时钟* i W0 ~- X4 h8 d% C3 L' X) f 在上述情况下,通过与 TIx 引脚或 ETR 引脚连接的外部信号提供时钟。并且应该验证最大外部时钟频率。 注: 0 t* [0 r( V) X# _1 t4 Q 1除以上所有时钟源外,定时器还应该通过 APBx 时钟驱动。/ ^* W& ]3 C1 K1 G% X 2外部时钟并非直接馈送预分频器,而是首先通过专用逻辑块与 APBx 时钟同步。 外部时钟模式 1(TI1 或 TI2 引脚) 在此模式下,外部时钟将施加到定时器的输入引脚 TI1 或 TI2 上。为此:2 [# v* A: X; U6 f- d0 O 1.配置定时器将 TIx 引脚用作输入:& P& |% E8 ~. ] a) 通过对 TIMx_CCMR1 寄存器中的 CCxS 位执行写操作,选择要使用的引脚。( f: x4 N5 \5 [/ X b) 选择输入的极性:- ^$ Q: w$ }- f$ _2 u 对于 STM32F10x 系列:通过对 TIMx_CCER 寄存器中的 CCxP 位执行写操作,选择上升沿触发或下降沿触发; 对于其它系列:通过对 TIMx_CCER 寄存器中的 CCxP 和 CCxNP 位执行写操作,选择上升/下降沿触发,或者边沿触发(a)。. w$ z) d% s w$ r: l6 ] c)根据需要,通过对 TIMx_CCMR1 寄存器中的 ICxF[3:0] 位执行写操作配置滤波器和预分频器: 通过对 TIMx_SMCR 寄存器的 TS 位执行写操作,将定时器 TIx 选为触发输入源。) l! D1 S- b U- J 通过对 TIMx_SMCR 寄存器写入 SMS=111 选择外部时钟模式 1。通过将% U! P3 y( F( A0 t$ S& G" e# G5 G# J" y5 U TIMx_CCER 寄存器中的 CCEx 位置 1 使能相应的通道。: S' W+ Y0 u3 o0 [, J8 ] 2.通过对 TIMx_SMCR 寄存器中的 TS 位执行写操作,将定时器 TIx 选为触发输入源。8 B: B5 S" t6 c% F5 a 3.通过对 TIMx_SMCR 寄存器写入 SMS=111 选择外部时钟模式 1。$ q0 |% Q! b1 ^* A. Q4 I ! t" q) l" ?. J+ Q5 a 外部时钟模式 2(ETR 引脚)2 s \: I5 Z1 t/ a) V' n! Z3 A 外部时钟模式 2 将 ETR 引脚用作定时器输入时钟。要使用该功能: 1.通过对 TIMx_SMCR 寄存器写入 ECE = 1 选择外部时钟模式 2。 2.根据需要,通过对 TIMx_SMCR 寄存器中的 ETPS [1:0]、ETF [3:0] 和 ETP 位执行写操作配置预分频器、滤波器和极性。 " G# D9 h: y- B. k2 D0 j: { 1 B2 l d- L3 Q' v; F 内部触发时钟 (ITRx). u2 k) ~( y j* k& t% M 这是一个特殊的定时器同步模式。当将一个定时器用作另一个定时器的预分频器时,第一个定时器的更新事件或输出比较信号将用作第二个定时器的时钟。 ) `5 l+ i& Y# D. `; c / X6 g+ @8 {# ^- P 2.2时基发生器5 z! `$ g/ e+ t5 ?) l% j 定时器可用作时基发生器。根据时钟、预分频器和自动重载、以及重复计数器(如果存在)的参数,16 位定时器可生成 1 纳秒到数分钟的更新事件。对于 32 位定时器,时间范围更大。 ! d1 L0 N% L+ Y; K6 L 更新事件周期示例& [( x7 c0 s% q/ F; ^ 更新事件周期按如下公式计算: Update_event = TIM_CLK/((PSC + 1)*(ARR + 1)*(RCR + 1)) ' Q$ N7 M y2 W+ q) f* m . t- e! r4 u' o8 T$ [! z3 E: ] 其中: TIM_CLK = 定时器时钟输入$ X, X6 V% D* {- H PSC = 16 位预分频器寄存器0 h$ u. T2 z* f ARR = 16/32 位自动重载寄存器- V9 _0 J% `! S. y1 s" p- S RCR = 16 位重复计数器2 ^" X) w( b9 j; x1 ^( B3 X/ L. z , F" w7 N r+ C( Y: E # Y* U/ Z& X0 m! m* _ 2 @! L* M9 B/ k# F' [ % E& F6 I. p: i$ H. z i' v p TIM_CLK = 72 MHz) u! q) H, I7 d2 n/ ?. v& l 预分频比 = 1& n, _8 b7 s+ B" C. W s. t 自动重载值 = 65535 无重复计数器 RCR = 0 Update_event = 72*106/((1 + 1)*(65535 + 1)*(1)) Update_event = 549.3 Hz c2 j% {6 f( ]& ^" D ; P0 g" }' y2 m5 J. _2 K" \ 外部时钟模式 2 示例2 G0 @5 N. v5 m) u 在此模式下,更新事件周期按如下公式计算:2 G& u U1 Y9 t/ n; Y1 B$ D1 ` Update_event = ETR_CLK/((ETR_PSC)*(PSC + 1)*(ARR + 1)*(RCR + 1))0 l* G e! h6 c$ Z: j 其中:ETR_CLK = 连接到 ETR 引脚的外部时钟频率。 ETR_CLK = 100 kHz 预分频比 = 15 F# [8 ?( D6 p1 ] ETR_PSC = 2 自动重载值 = 255 重复计数器 = 2. t1 M: B) X/ p7 P/ C Update_event= 100*103/((2 + 1)* (1+ 1)*((255 + 1)*(2 + 1)) Update_event = 21.7 Hz 外部时钟模式 1 示例 在此模式下,更新事件周期按如下公式计算: Update_event = TIx_CLK/((PSC + 1)*(ARR + 1)*(RCR +1))$ l# `# V1 F6 } 其中:TIx_CLK = 连接到 TI1 引脚或 TI2 引脚的外部时钟频率。/ E! R6 ?6 A( G5 i, ] TIx_CLK = 50 kHz 预分频比 = 1- r& y; B5 n L9 j* O8 ? _& n+ h/ c 自动重载值 = 2551 u# o0 }' E$ u) n: U 重复计数器 = 2 Update_event = 50 000/((1+ 1)*((255 + 1)*(2 + 1)) Update_event = 32.55 Hz ( ?6 V/ I& ]; \8 U 内部触发时钟 (ITRx) 模式 1 示例 在此模式下,更新事件周期按如下公式计算:( l1 n5 k6 c- B* o Update_event = ITRx_CLK/((PSC + 1)*(ARR + 1)*(RCR + 1))# j+ y2 T Q$ U4 ]. p6 D 其中 ITRx_CLK = 映射到定时器触发输入 (TRGI) 的内部触发频率7 g M5 ]% `0 ?0 K6 Z& H ITRx_CLK = 8 kHz! s# [' p7 b, R5 a 预分频比 = 1 自动重载值 = 255" g! y) h' }+ V3 A9 q 重复计数器 = 1: W* p# Y2 r C0 v- @* Y Update_event = 8000/((1+ 1)*((255 + 1)*(1 + 1)) Update_event = 7.8 Hz! ], q3 @" k% m; U# w 根据计数器模式的不同,更新事件通常在以下情况产生: ●每次上溢(如果使用递增计数模式):TIMx_CR1 寄存器中的 DIR 位复位 ●每次下溢(如果使用递减计数模式):TIMx_CR1 寄存器中的 DIR 位置 1 ●每次上溢和下溢(如果使用中心对齐模式):CMS 位不为零。# s6 ]$ S+ E$ I* f) r4 P& Q2 h 还可以通过以下方式生成更新事件: ●通过软件生成更新事件(如果 TIM_EGR 寄存器中的 UG(更新生成)位置 1)。3 @; ]: z% K2 f- A& C ●通过从模式控制器生成更新事件: F; e- {7 D+ L3 q0 Q! p 因为缓冲的寄存器(ARR、PSC 和 CCRx)需要一个装载预装载值的更新事件,因此将URS(更新请求源)置 1 可避免每次装载这些值时触发更新标志位。这样,只有当计数器发生上溢/下溢时才会生成更新事件。; b5 M2 g3 V; A1 M% h6 G 此外,可以通过将 CR1 寄存器中的 UDIS(更新禁止)位置 1 以禁止更新事件。这样,便不会生成更新事件,而各影子寄存器(ARR、PSC 和 CCRx)的值会保持不变。但如果将 UG位置 1,或者从从模式控制器接收到硬件复位,则会重新初始化计数器和预分频器。 当 DIER 寄存器中的 UIE 位或/和 UDE 位置 1 时,会产生中断或/和 DMA 请求。" h, ^9 D' q0 E 有关在此模式下使用定时器的详细信息,请参见 /Project/STM32xx_StdPeriph_Examples/TIM/TimeBase 文件夹中 STM32xx 标准外设库提供的示例。" S* \$ z. _: {9 _8 J7 m u1 K/ _" \: l/ b1 @# E 完整版请查看:附件8 q, d6 k' z) Y+ U. P% \ |
DM00042534_ZHV2.pdf
下载815.27 KB, 下载次数: 7