STM32学习笔记07—基础定时器实验 0 E: T* R7 x+ [4 O9 F5 _7 b r' y8 q& c6 [9 z, h3 P! ^0 D3 ?( w 7.1 STM32定时器概述% [& _- V: X/ l& X) r STM32内部共有8个定时器,其中Timer1和Timer8属于高级定时器,Timer2~Timer5属于通用定时器,8个定时器的资源独立,互不影响。 STM32的通用定时器是一个通过可编程预分频器(PSC)驱动的16位自动装载计数器(CNT)构成。STM32的通用定时器可以被用于:测量输入信号的脉冲长度(输入捕获)或者产生输出波形(输出比较和PWM)等。使用定时器预分频器和RCC时钟控制器预分频器,脉冲长度和波形周期可以在几个微秒到几个毫秒间调整。STM32的每个通用定时器都是完全独立的,没有互相共享的任何资源。 通用定时器的内部结构如下图所示。 要使用通用定时器的基本功能,一共需要配置4个寄存器,剩余的寄存器都是在输入捕获和输出比较中使用到的。# t W2 p! Q" p6 M6 E 7.2.1 控制寄存器1:TIMx_CR1 L! Q, e! }, L4 I4 V 00:采样频率与定时器输入频率相等( g1 c$ G0 P" `& F 01:采样频率是定时器输入频率的2倍 10:采样频率是定时器输入频率的4倍; k7 p* B, Y9 H. D- z! [8 t/ |) \ 11:保留0 S+ p" E0 F5 \ M. R: x Bit 7:自动重装载使能" _7 z5 u- }6 n4 V6 t 0:TIMx_ARR寄存器中没有缓冲* H5 i8 [/ x" F 1:TIMx_ARR寄存器的数据装入缓存器' x r' a( F* B& P% ]4 a! K4 G Bit 6~Bit 5:选择中央对齐模式 00:边沿对齐模式,计数器根据方向位DIR计数 01:中央对齐模式1,计数器交替向上向下计数,当TIMx_CCMRx中的CCxS=00时,计数器向下计数时被设置( q& v8 A8 }' M4 H 10:中央对齐模式2,计数器交替向上向下计数,当TIMx_CCMRx中的CCxS=00时,计数器向上计数时被设置4 [ T ^* z O) U, |- R 11:中央对齐模式3,计数器交替向上向下计数,当TIMx_CCMRx中的CCxS=00时,计数器向下和向上计数时 被均设置% m9 I0 l; B% j2 p- t( o Bit 4:计数方向 0:向上计数,计数器从0计数到TIMx_ARR寄存器的数据时重新从0开始并产生一个计数器溢出事件% `3 r3 C, q* U' r 1:向下计数,计数器从TIMx_ARR寄存器的数据计数到0时重新从TIMx_ARR寄存器的数据开始并产生一个计数器溢出事件8 a! U6 d5 Q! o8 e h Bit 3:单脉冲模式( {' f: P. A8 w" A, a2 z 0:发生更新事件时计数器不停止, D; h( t7 H6 {# l0 [ 1:在发生下一次更新事件时,计数器停止- h+ Y6 T4 y$ V0 b. T7 x Bit 2:更新请求源 0:如果使能了更新中断或DMA请求,计数器溢出/设置UG位/从模式控制器产生更新都产生更新中断或DMA请求1 Y& H" Q8 u% V, g" x 1:如果使能了更新中断或DMA请求,只有计数器溢出才产生更新中断或DMA请求1 ]$ K6 t/ H3 v/ d3 I6 Y: h& g Bit 1:禁止更新, K; H0 ~0 q( g+ ]6 ?5 N" B 0:允许UEV。更新事件由计数器溢出/设置UG位/从模式控制器产生更新事件产生 1:不产生更新事件: @1 {/ C1 O P" K Bit 0:使能计数器 0:禁止计数器 1:使能计数器 7.2.2 DMA/中断使能寄存器:TIMx_DIER 0:禁止触发DMA请求 1:允许触发DMA请求 Bit 12:允许捕获/比较4的DMA请求 0:禁止捕获/比较4的DMA请求 1:允许捕获/比较4的DMA请求 Bit 11:允许捕获/比较3的DMA请求 0:禁止捕获/比较3的DMA请求 1:允许捕获/比较3的DMA请求 Bit 10:允许捕获/比较2的DMA请求7 T3 V0 r) t" F 0:禁止捕获/比较2的DMA请求 1:允许捕获/比较2的DMA请求1 b5 } d6 k* M Bit 9:允许捕获/比较1的DMA请求 0:禁止捕获/比较1的DMA请求" H9 O; r5 @' q) Q- C2 m 1:允许捕获/比较1的DMA请求 Bit 8:允许更新的DMA请求+ b3 w9 U; ^6 Q- A8 ^6 v4 i0 m 0:禁止更新的DMA请求3 F8 L' k/ R# ]; } 1:允许更新的DMA请求 Bit 6:触发中断使能. L3 A# j$ o V$ Z7 W! }$ M4 e 0:禁止触发中断3 Q! E$ N( G$ K7 O# y 1:允许触发中断 Bit 4:允许捕获/比较4的中断1 F( @ y( [2 ^; n% s, c& \ ] 0:禁止捕获/比较4的中断4 I( ?2 {; {; J 1:允许捕获/比较4的中断 Bit 3:允许捕获/比较3的中断 0:禁止捕获/比较3的中断- H6 L$ ~) b# M% Q* H 1:允许捕获/比较3的中断+ m, g D4 f; i* K: E. |1 z& [6 X Bit 2:允许捕获/比较2的中断 0:禁止捕获/比较2的中断 1:允许捕获/比较2的中断9 u% J' N/ a2 f1 U; ~ Bit 1:允许捕获/比较1的中断% V6 J. l3 b; u8 X2 s 0:禁止捕获/比较1的中断0 g+ r* B6 e6 [' }1 g% S+ l 1:允许捕获/比较1的中断 Bit 0:允许更新中断 0:禁止更新中断0 c+ A* f9 |% D; p& l# } 1:允许更新中断! a/ J; Q7 k' a) @ 7.2.3 预分频寄存器:TIMx_PSC- g* I9 ^. L5 c; m: Y8 X . ^ H5 {' S9 I0 g7 Y A! f' K7 i( ?( o2 P3 J 7.2.4 自动重装载寄存器:TIMx_ARR 7.2.5 状态寄存器:TIMx_SR 0:无重复捕获产生* f8 E+ T/ Z: ~0 Z. @& c$ A 1:当计数器的值捕获到TIMx_CCR4寄存器时,CC4IF的状态已经为1 Bit 11:捕获/比较3重复捕获标记 0:无重复捕获产生 1:当计数器的值捕获到TIMx_CCR3寄存器时,CC3IF的状态已经为18 v$ Y- A3 M: C4 h8 y+ Y Bit 10:捕获/比较2重复捕获标记3 c6 w* D( j# E/ j: U 0:无重复捕获产生6 Z; j, o( W) D' X& [- d0 y 1:当计数器的值捕获到TIMx_CCR2寄存器时,CC2IF的状态已经为1& A$ o4 U: U, m Bit 9:捕获/比较1重复捕获标记 0:无重复捕获产生 X+ I* O# h- U1 L$ g- u 1:当计数器的值捕获到TIMx_CCR1寄存器时,CC1IF的状态已经为1. E1 ~ q. g1 L Bit 6:触发器中断标记 0:无触发事件产生4 d0 y1 x9 M) \4 @ 1:触发器中断等待响应. j9 K1 k& C1 [# Y* I! \ Bit 4:捕获/比较4中断标记 V1 {' ]' @& f& c9 R" S 通道CC4配置为输出模式:( |7 Z6 E1 i/ ~! r 0:无匹配发生0 G, M, M2 T2 U% @5 Y: D 1:TIMx_CNT的值与TIMx_CCR4的值匹配 通道CC4配置为输入模式:1 y; i7 p) V+ v1 ? 0:没有输入捕获产生 1:计数器值已经被捕获到TIMx_CCR4中(在IC4上检测到与所选极性相同的边沿) Bit 3:捕获/比较3中断标记 通道CC3配置为输出模式:/ r8 z0 e3 g. X% [/ g 0:无匹配发生 1:TIMx_CNT的值与TIMx_CCR3的值匹配 通道CC3配置为输入模式:4 f c! p6 S, o 0:没有输入捕获产生6 W0 F1 @: F$ _ K X, u 1:计数器值已经被捕获到TIMx_CCR3中(在IC3上检测到与所选极性相同的边沿); w; h2 D! k" x# ]4 k8 u2 i N& C0 G Bit 2:捕获/比较2中断标记; E6 D( W/ q& z$ g; ^4 D& s1 _. T 通道CC2配置为输出模式:( K8 d- D2 A& Z( k7 i# _) g 0:无匹配发生 1:TIMx_CNT的值与TIMx_CCR2的值匹配 通道CC2配置为输入模式: 0:没有输入捕获产生 1:计数器值已经被捕获到TIMx_CCR2中(在IC2上检测到与所选极性相同的边沿) Bit 1:捕获/比较1中断标记+ ]( ]/ d2 y$ D3 t( z. [+ W( v: _ 通道CC1配置为输出模式: 0:无匹配发生( ?' j$ l4 _, K4 \2 V 1:TIMx_CNT的值与TIMx_CCR1的值匹配" `7 |1 L6 b6 I6 l' H3 l, ] 通道CC1配置为输入模式:$ ], B0 p. Z& s. S7 p! M1 I 0:没有输入捕获产生 1:计数器值已经被捕获到TIMx_CCR1中(在IC1上检测到与所选极性相同的边沿) Bit 0:更新中断标记 0:无更新事件产生 1:更新中断等待响应,当产生更新事件时该位由硬件置1,由软件清0 7.2.6 计数器:TIMx_CNT 7.3 定时器例程 利用定时器1实现LED以1Hz闪烁,LED接在PA1上。 (1)创建TIM1驱动文件,tim.c和tim.h,并将文件添加进工程。4 R+ a, e4 y; W: | 添加定时器地址 (4)tim.c写入如下所示代码
) k4 W! o; \" I4 |0 l: X (5)主函数编写如下所示代码4 z6 V0 C4 g2 e% ]" C% n T! _ 7.4 软件仿真截图 0 K: W0 S/ H( s8 u' v0 R |