05_STM32F4通用定时器详细讲解
05_STM32F4通用定时器详细讲解精编版
RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3,ENABLE); ///使能TIM3时钟
2时钟Timer3的配置。
TIM_TimeBaseInitStructure.TIM_Period = arr;//自动重装载值
Timer3是一个16位的定时器,有四个独立通道,分别对应着PA6 PA7 PB0 PB1
主要功能是:1输入捕获——测量脉冲长度。
2输出波形——PWM输出和单脉冲输出。
Timer3有4个时钟源:
1:内部时钟(CK_INT),来自RCC的TIMxCLK
2:外部时钟模式1:外部输入TI1FP1与TI2FP2
TIM_TimeBaseInit(TIM3,&TIM_TimeBaseInitStructure);//初始化TIM3
3使能中断
TIM_ITConfig(TIM3,TIM_IT_Update,ENABLE); //允许定时器3更新中断。
4打开Timer3。
TIM_Cmd(TIM3,ENABLE); //使能定时器3
3:捕获/比较选择
8TIM3捕获/比较模式寄存器2 (TIM3_CCMR2)
9TIM3捕获/比较使能寄存器(TIM3_CCER)
1:上升沿触发or下降沿触发
2:捕获/比较输出使能
10 TIM3计数器(TIM3_CNT)
11 TIM3预分频器(TIM3_PSC)
计数器时钟频率CK_CNT等于fCK_PSC/ (PSC[15:0] + 1)。
1TIM3控制寄存器1 (TIM3_CR1)
作用:1使能自动重载TIM3_ARR
(待分)05STM32F4通用定时器详细讲解
系列共有个定时器,功能很强大。
个定时器分别为:个高级定时器:和个通用定时器:和个基本定时器:和本篇欲以通用定时器为例,详细介绍定时器的各个方面,并对其功能做彻底的探讨。
是一个位的定时器,有四个独立通道,分别对应着主要功能是:输入捕获——测量脉冲长度。
输出波形——输出和单脉冲输出。
有个时钟源::内部时钟(),来自的:外部时钟模式:外部输入与:外部时钟模式:外部触发输入,仅适用于、、,,对应着引脚:内部触发输入:一个定时器触发另一个定时器。
时钟源可以通过相关位进行设置。
这里我们使用内部时钟。
(最高)定时器挂在高速外设时钟或低速外设时钟上,时钟不超过内部高速时钟,故当不为时,定时器时钟为其倍,当为时,为了不超过,定时器时钟等于。
例如:我们一般配置系统时钟为,内部高速时钟,欲分频为,(因为最高时钟为),那么挂在总线上的时钟为。
《中文参考手册》的页列出与通用定时器相关的寄存器一共个,以下列出与相关的寄存器及重要寄存器的简单介绍。
控制寄存器()作用:使能自动重载定时器的计数器递增或递减计数。
事件更新。
计数器使能控制寄存器()从模式控制寄存器()中断使能寄存器()作用::使能事件更新中断:使能捕获比较中断状态寄存器():事件更新中断标志:捕获比较中断标志事件生成寄存器()捕获比较模式寄存器():输出比较模式:输出比较预装载使能,即使能后可以随时改变捕获比较寄存器()的值:捕获比较选择捕获比较模式寄存器()捕获比较使能寄存器():上升沿触发下降沿触发:捕获比较输出使能计数器()预分频器()计数器时钟频率等于([] )。
自动重载寄存器()当自动重载值为空时,计数器不工作难道说每次事件都必须装载重载值?捕获比较寄存器()输出时:是捕获比较寄存器的预装载值,由的位使能。
输入时:为上一个输入捕获事件()发生时的计数器值。
捕获比较寄存器()捕获比较寄存器()捕获比较寄存器()用来做定时中断与之相关的时基单元寄存器有计数器()预分频器()自动重载寄存器()原理:这里以向上计数为例,即计数器向上计数,当达到所设定的值时,归零重新计数,若使能了更新中断,则在归零时,进入中断。
STM32学习笔记4通用定时器基本定时功能
STM32学习笔记(4):通用定时器基本定时功能1.STM32的Timer简介STM32中一共有11个定时器,其中2个高级控制定时器,4个普通定时器和2个基本定时器,以及2个看门狗定时器和1个系统嘀嗒定时器。
其中系统嘀嗒定时器是前文中所描述的SysTick,看门狗定时器以后再详细研究。
今天主要是研究剩下的8个定时器。
其中TIM1和TIM8是能够产生3对PWM互补输出的高级定时器,常用于三相电机的驱动,时钟由APB2的输出产生。
TIM2-TIM5是普通定时器,TIM6和TIM7是基本定时器,其时钟由APB1输出产生。
由于STM32的TIMER功能太复杂了,所以只能一点一点的学习。
因此今天就从最简单的开始学习起,也就是TIM2-TIM5普通定时器的定时功能。
2.普通定时器TIM2-TIM52.1时钟来源计数器时钟可以由下列时钟源提供:·内部时钟(CK_INT)(TIx):外部输入脚1外部时钟模式·.·外部时钟模式2:外部触发输入(ETR)·内部触发输入(ITRx):使用一个定时器作为另一个定时器的预分频器,如可以配置一个定时器Timer1而作为另一个定时器Timer2的预分频器。
由于今天的学习是最基本的定时功能,所以采用内部时钟。
TIM2-TIM5的时钟不是直接来自于APB1,而是来自于输入为APB1的一个倍频器。
这个倍频器的作用是:当APB1的预分频系数为1时,这个倍频器不起作用,定时器的时钟频率等于APB1的频率;当APB1的预分频系数为其他数值时(即预分频系数为2、4、8或16),这个倍频器起作用,定时器的时钟频率等于APB1的频率的2倍。
APB1的分频在STM32_SYSTICK的学习笔记中有详细描述。
通过倍频器给定时器时钟的好处是:APB1不但要给TIM2-TIM5提供时钟,还要为其他的外设提供时钟;设置这个倍频器可以保证在其他外设使用较低时钟频率时,TIM2-TIM5仍然可以得到较高的时钟频率。
STM32通用定时器库函数设置心得——新手必看
STM32通用定时器库函数设置心得——新手必看STM32通用定时器是STM32微控制器系列中很重要的一个组件,它具有多种功能,包括定时器、PWM生成器、输入捕获和输出比较等。
在STM32中,定时器的使用非常广泛,常用于各种定时操作、计数操作和脉冲宽度调制等应用。
本文将对STM32通用定时器的库函数进行介绍,帮助新手快速掌握并应用。
首先,在使用STM32通用定时器之前,需要了解一些基本概念。
STM32通用定时器包括TIM2、TIM3、TIM4和TIM5等,它们具有相似的特性和功能,可以根据实际需求选择使用。
在使用定时器之前,需要开启其时钟,并进行相应的初始化设置。
1.定时器时钟的开启和初始化开启定时器的时钟,需要在RCC时钟控制寄存器中设置相应的位。
具体来说,需要设置APB1或APB2总线上的定时器时钟使能位,开启相应定时器的时钟。
初始化定时器,需要对定时器的模式、预分频值、计数模式、自动重装载寄存器和定时器中断进行设置。
其中,预分频值决定了定时器的时钟频率,计数模式决定了定时器的工作方式,自动重装载寄存器决定了定时器的溢出时间。
2.定时器中断的设置定时器中断用于定时触发一些操作,可以是定时执行一些函数、改变一些变量或者触发其中一种事件。
定时器的中断分为溢出中断和比较中断两种,可以根据实际需求选择使用。
在使用定时器中断之前,需要设置定时器的中断使能位,并在中断处理函数中编写相应的中断处理代码。
在中断处理函数中,可以根据具体需求进行相应的操作,比如改变一些标志位、执行一些函数或者发送一些数据。
3.定时器的计数和计时定时器的计数和计时是定时器的核心功能,它决定了定时器的工作方式和定时器值的变化规律。
定时器的计数可以根据实际需要进行设置,可以是向上计数、向下计数或者上下计数。
定时器的计时功能需要根据预分频值和自动重装载寄存器进行计算,以确定定时器的溢出时间和定时时间。
通过改变预分频值和自动重装载寄存器,可以实现不同的定时功能。
STMF通用定时器详细讲解
S T M F通用定时器详细讲解Standardization of sany group #QS8QHH-HHGX8Q8-GNHHJ8-HHMHGN#STM32F4系列共有14个定时器,功能很强大。
14个定时器分别为:2个高级定时器:Timer1和Timer810个通用定时器:Timer2~timer5 和 timer9~timer142个基本定时器: timer6和timer7本篇欲以通用定时器timer3为例,详细介绍定时器的各个方面,并对其PWM功能做彻底的探讨。
Timer3是一个16位的定时器,有四个独立通道,分别对应着PA6 PA7 PB0 PB1主要功能是:1输入捕获——测量脉冲长度。
2 输出波形——PWM输出和单脉冲输出。
Timer3有4个时钟源:1:内部时钟(CK_INT),来自RCC的TIMxCLK2:外部时钟模式1:外部输入TI1FP1与TI2FP23:外部时钟模式2:外部触发输入TIMx_ETR,仅适用于TIM2、TIM3、TIM4,TIM3,对应着PD2引脚4:内部触发输入:一个定时器触发另一个定时器。
时钟源可以通过TIMx_SMCR相关位进行设置。
这里我们使用内部时钟。
定时器挂在高速外设时钟APB1或低速外设时钟APB2上,时钟不超过内部高速时钟HCLK ,故当APBx_Prescaler 不为1时,定时器时钟为其2倍,当为1时,为了不超过HCLK ,定时器时钟等于HCLK 。
例如:我们一般配置系统时钟SYSCLK 为168MHz ,内部高速时钟 AHB=168Mhz ,APB1欲分频为4,(因为APB1最高时钟为42Mhz ),那么挂在APB1总线上的timer3时钟为84Mhz 。
《STM32F4xx 中文参考手册》的424~443页列出与通用定时器相关的寄存器一共20个,以下列出与Timer3相关的寄存器及重要寄存器的简单介绍。
1 TIM3 控制寄存器 1 (TIM3_CR1)作用:1使能自动重载TIM3_ARR2定时器的计数器递增或递减计数。
STM32通用定时器的基本特性、操作模式及相关应用介绍
STM32 通用定时器的基本特性、操作模式及相关应
用介绍
众所周知,STM32 的定时器功能非常庞大复杂,应用也非常普遍。
目前STM32 家族已有10 条产品线,其中都内置多个定时器外设。
尽管STM32 各系列的定时器无论从数目上还是特性上可能略有差异,但它们整体上还是具有一些公共特性与相同的操作模式。
ST 官方有一篇针对STM32 通用定时器的应用笔记,编号为AN4776,内容较为详尽丰富。
该笔记主要对STM32 通用定时器的基本特性、操作模式及相关应用做了细致清晰的描述。
既有对基本概念的详细讲解,又有相关实际应用的原理介绍,同时还配有相关应用的参考工程代码。
该笔记值得一读。
这里简单介绍下AN4776 应用笔记的基本内容框架。
该笔记主要分两部分。
第一部分主要是对STM32 定时器的基本组成及特性的描述和讲解。
第二部分对STM32 定时器的一些特定应用做了专门描述,包括基本工作原理和相关应用代码的介绍。
STM32通用定时器库函数设置心得——新手必看
通用定时器STM32的通用定时器为:TIM2、TIM3、TIM4和TIM5在使用通用定时器时利用库函数直接设置定时器如下:1.使能定时器TIM_X的时钟:(X=2、3、4、5)RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIMX,ENABLE);2.计算要定时的时间,根据定时时间来设定分频数和最大计数值(以向上计数为例子),其中计算关系如下:系统时钟(一般为72MHZ) = 定时器分频数 * 计数值假如分频数为7200,则定时器时钟为:72MHZ/7200=10KHZ,定时器每次计数时间间隔为1/10000秒,假如定时1秒,则要计数10000次,因此计数器的最大计数值为9999,因为计数器从零开始计数。
3.将计算好的分频数和计数值分别赋值以上面定时为例,如下:/自动重装的计数值TIM_TimeBaseStructure.TIM_Period = (10000 - 1);// 这个就是预分频系数TIM_TimeBaseStructure.TIM_Prescaler =7200 ;//数字滤波器,定时的时候不涉及此功能,为零即TIM_TimeBaseStructure.TIM_ClockDivision = 0;//计数模式选择,此处设置为向上模式TIM_TimeBaseStructure.TIM_CounterMode=TIM_CounteMode_Up;//定时基本设置((X=2、3、4、5))TIM_TimeBaseInit(TIMX, &TIM_TimeBaseStructure);//清除定时器X的中断溢出标识TIM_ClearITPendingBit(TIMX, TIM_IT_Update);//开定时器X溢出中断TIM_ITConfig(TIM5, TIM_IT_Update, ENABLE);//计数器使能,开始工作TIM_Cmd(TIM5, ENABLE);到此通用定时器的定时功能配置完成,以上配置代码可写入void TIMX_Init(void)函数中,函数名自己可变。
05_STM32F4通用定时器详细讲解
STM32F4系列共有14个定时器,功能很强大。
14个定时器分别为:2个高级定时器:Timer1和Timer810个通用定时器:Timer2~timer5 和 timer9~timer142个基本定时器: timer6和timer7本篇欲以通用定时器timer3为例,详细介绍定时器的各个方面,并对其PWM 功能做彻底的探讨。
Timer3是一个16位的定时器,有四个独立通道,分别对应着PA6 PA7 PB0 PB1 主要功能是:1输入捕获——测量脉冲长度。
2 输出波形——PWM 输出和单脉冲输出。
Timer3有4个时钟源:1:内部时钟(CK_INT ),来自RCC 的TIMxCLK2:外部时钟模式1:外部输入TI1FP1与TI2FP23:外部时钟模式2:外部触发输入TIMx_ETR ,仅适用于TIM2、TIM3、TIM4,TIM3,对应着PD2引脚4:内部触发输入:一个定时器触发另一个定时器。
时钟源可以通过TIMx_SMCR 相关位进行设置。
这里我们使用内部时钟。
定时器挂在高速外设时钟APB1或低速外设时钟APB2上,时钟不超过内部高速时钟HCLK ,故当APBx_Prescaler 不为1时,定时器时钟为其2倍,当为1时,为了不超过HCLK ,定时器时钟等于HCLK 。
例如:我们一般配置系统时钟SYSCLK 为168MHz ,内部高速时钟 AHB=168Mhz ,APB1欲分频为4,(因为APB1最高时钟为42Mhz ),那么挂在APB1总线上的timer3时钟为84Mhz 。
《STM32F4xx 中文参考手册》的424~443页列出与通用定时器相关的寄存器一共20个, 以下列出与Timer3相关的寄存器及重要寄存器的简单介绍。
1 TIM3 控制寄存器 1 (TIM3_CR1)SYSCLK(最高AHB_Prescaler APBx_Prescaler作用:1使能自动重载TIM3_ARR2定时器的计数器递增或递减计数。
STM32的定时器定时时间计算(计数时间和中断定时时间)
STM32的定时器定时时间计算(计数时间和中断定时时间)时基单元可编程⾼级控制定时器的主要部分是⼀个16位计数器和与其相关的⾃动装载寄存器。
这个计数器可以向上计数、向下计数或者向上向下双向计数。
此计数器时钟由预分频器分频得到。
计数器、⾃动装载寄存器和预分频器寄存器可以由软件读写,即使计数器还在运⾏读写仍然有效。
时基单元包含:●计数器寄存器(TIMx_CNT)●预分频器寄存器 (TIMx_PSC)●⾃动装载寄存器 (TIMx_ARR)●重复次数寄存器 (TIMx_RCR)⾃动装载寄存器是预先装载的,写或读⾃动重装载寄存器将访问预装载寄存器。
根据在TIMx_CR1寄存器中的⾃动装载预装载使能位(ARPE)的设置,预装载寄存器的内容被⽴即或在每次的更新事件UEV时传送到影⼦寄存器。
当计数器达到溢出条件(向下计数时的下溢条件)并当TIMx_CR1寄存器中的UDIS位等于0时,产⽣更新事件。
更新事件也可以由软件产⽣。
随后会详细描述每⼀种配置下更新事件的产⽣。
计数器由预分频器的时钟输出CK_CNT驱动,仅当设置了计数器TIMx_CR1寄存器中的计数器使能位(CEN)时,CK_CNT才有效。
(更多有关使能计数器的细节,请参见控制器的从模式描述)。
注意,在设置了TIMx_CR寄存器的CEN位的⼀个时钟周期后,计数器开始计数。
预分频器描述预分频器可以将计数器的时钟频率按1到65536之间的任意值分频。
它是基于⼀个(在TIMx_PSC寄存器中的)16位寄存器控制的16位计数器。
因为这个控制寄存器带有缓冲器,它能够在运⾏时被改变。
新的预分频器的参数在下⼀次更新事件到来时被采⽤。
尤其注意的是当发⽣⼀个更新事件时,所有的寄存器都被更新,硬件同时(依据URS位)设置更新标志位(TIMx_SR寄存器中的UIF位)。
●重复计数器被重新加载为TIMx_RCR寄存器的内容。
●⾃动装载影⼦寄存器被重新置⼊预装载寄存器的值(TIMx_ARR)。
STM32定时器详细讲解及应用
TIM3->DIER|=1<<0; //允许更新中断 TIM3->DIER|=1<<6; //允许触发中断 TIM3->CR1|=0X01; //使能定时器 3(这里面包括计数方向为向上计数) } #if 0 void TIM4_Configuration(void) {
TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; TIM_OCInitTypeDef TIM_OCInitStructure; /* TIM4 clock enable */
/*使能预装载*/ TIM_ARRPreloadConfig(TIM4, ENABLE); /*预先清除所有中断位*/ TIM_ClearITPendingBit(TIM4, TIM_IT_Update);
TIM_ITConfig(TIM4, TIM_IT_Update, ENABLE);
/* 允许 TIM2 开始计数 */ TIM_Cmd(TIM4, ENABLE); } #else void TIM_Configuration(u16 p,u16 psc) { RCC->APB1ENR|=1<<2;//TIM4 时钟使能 //自动装载寄存器 TIM4->ARR=p; //设定定时器自动重装值 //PSC 预分频寄存器 TIM4->PSC=psc; //设定定时器的分频系数 TIM4->DIER|=1<<0; //允许更新中断 TIM4->DIER|=1<<6; //允许触发中断 TIM4->CR1|=0X01; //使能定时器 3(这里面包括计数方向为向上计数)
***********
* Function Name : TIM2_IRQHandler TIM2 中断
stm32通用定时器详解
stm32通用定时器STM32的定时器是个强大的模块,定时器使用的频率也是很高的,定时器可以做一些基本的定时,还可以做PWM输出或者输入捕获功能。
时钟源问题:名为TIMx的有八个,其中TIM1和TIM8挂在APB2总线上,而TIM2-TIM7则挂在APB1总线上。
其中TIM1&TIM8称为高级控制定时器(advanced control timer).他们所在的APB2总线也比APB1总线要好。
APB2可以工作在72MHz下,而APB1最大是36MHz。
定时器的时钟不是直接来自APB1或APB2,而是来自于输入为APB1或APB2的一个倍频器。
下面以定时器2~7的时钟说明这个倍频器的作用:当APB1的预分频系数为1时,这个倍频器不起作用,定时器的时钟频率等于APB1的频率;当APB1的预分频系数为其它数值(即预分频系数为2、4、8或16)时,这个倍频器起作用,定时器的时钟频率等于APB1的频率两倍。
假定AHB=36MHz,因为APB1允许的最大频率为36MHz,所以APB1的预分频系数可以取任意数值;当预分频系数=1时,APB1=36MHz,TIM2~7的时钟频率=36MHz(倍频器不起作用);当预分频系数=2时,APB1=18MHz,在倍频器的作用下,TIM2~7的时钟频率=36MHz。
有人会问,既然需要TIM2~7的时钟频率=36MHz,为什么不直接取APB1的预分频系数=1?答案是:APB1不但要为TIM2~7提供时钟,而且还要为其它外设提供时钟;设置这个倍频器可以在保证其它外设使用较低时钟频率时,TIM2~7仍能得到较高的时钟频率。
再举个例子:当AHB=72MHz时,APB1的预分频系数必须大于2,因为APB1的最大频率只能为36MHz。
如果APB1的预分频系数=2,则因为这个倍频器,TIM2~7仍然能够得到72MHz的时钟频率。
能够使用更高的时钟频率,无疑提高了定时器的分辨率,这也正是设计这个倍频器的初衷。
STM32之通用定时器
STM32 之通用定时器
STM32 中的定时器有多种,按功能分成2 个高级控制器定时器,4 个普通定时器,2 个基本定时器,2 个看门狗定时器,1 个系统滴答定时器SysTick。
定时器的关键是定时时间的计算。
比如用定时器控制继电器的开关的时候,需要延时一段时间才关闭或者开启,这时候离不开定时器定时。
通用定时器定时时间计算。
1 秒中断的基本实现:
通用定时器模块的入口时钟经过分频得到计数器的时钟,用CK_CNT 表示,预分频器的系数为:TIMx_PSC,当TIMx_PSC=0 时,表示不分频,=1 时,2 分频。
以此类推。
公式为:CK_CNT=fclk_PSC/(PSC[15:0]+1),其中PSC 最大为65535.
其次是TIM5 计数器的计数值的设置,TIM5 计数器以CK_CNT 为时钟来计数。
计数到设定值产生中断。
(1/分频后计数时钟)*计数值=设定时间。
以1 秒为例
(1/(72MHz/7200))*10000=1s。
强大的STM32F4的定时器设定方法-附源码
STM32定时器比较多,使用起来也比较混乱。
windows下做过编程的人一定对SetTimer有印象,不过该定时器也不那么好用,因为id要自己维护,并且保证不跟程序中的其他id冲突。
手头上的项目要用到定时器,又不想每次都跑到寄存器里详细设定参数,所以就写了个类似SetTimer的定时器。
注:请在STM32F407上使用该定时器,其他内核需要修改,如M3内核是没有32位定时器的使用方法:u8 SetTimer(u32 unTime, u32 unCount, TIMERFUN pHandler,u32 ucPara)使用SetTimer去向系统申请一个定时器,如果成功,返回定时器ID,失败返回0.为了使定时器ID更有意义,这里设定返回值为定时器编号这里根据计时时间自动分配定时器。
比如你需要一个比较长时间的定时,那么SetTimer会给你分配一个32位定时器(M4内核)参数:unTime:计时时间(ms,如需ns请自行修改或者使用delay)unCount :计时器运行次数,0为无限运行,非零的话,运行unCount次后,该定时器关闭。
pHandler:定时器定时后执行的函数,该处如果不需要执行,可填0(什么都不需要做,干嘛要开启定时器?),当然这里可以自己定义函数指针类型(比如传2个参数或者变参:呃,变参太变态)ucPara:函数参数/*关闭定时器tmrId:定时器ID*/void KillTimer(TIMER tmrId);例如:view sourceprint?1 //每隔0.5s 反转4bit 灯2 tmrIrb = SetTimer(500, 0, IndRvsBit, 4);3 printf("IndRvsBit Timer Id: %d\r\n",tmrIrb);45 if(0 != tmrIrb)6 {7 ucCnt = SetTimer(10 * 1000, 1, KillBlink, tmrIrb); //10s 后关闭位4反转8 printf("KillBlink Timer Id: %d\r\n",ucCnt);9 }view sourceprint?1view sourceprint?1view sourceprint?1view sourceprint?1view sourceprint?1view sourceprint?1这里要提前定义好参数里的函数指针view sourceprint?01 void KillBlink(u8 ucOpt)02 {03 // RTC_ShutWakeUp();04 KillTimer(ucOpt);05 printf("KillBlink(%d)\r\n", ucOpt);06 }0708 void AdPickTime(u8 ucOpt)09 {10 PushCmd(0xF2,0);11 }1213 void IndRvsBit(u8 ucOpt)14 {15 SubBoardIndSingle(4, acCurInd[4] ^ (1 << ucOpt));16 }header:view sourceprint?01 #ifndef __TIMER_H02 #define __TIMER_H03 #include "board.h"04 #include "zkekglobe.h"0 5 /////////////////////////////////////////////////////////////////// ///////////////60//All rights reserved708 //////////////////////////////////////////////////////////////////////////////////09101112 /*使能基本计时器13 ucTimerIdx:计时器编号 范围:2~5 9~1414 unCount 自动重装值。
STM32定时器-职业教育-
1
IRS UDIS
0 CEN
位 15:10 保留,始终读为0,
rw rw rw rw rw rw rw rw rw rw
位9:3
CKD[1:O]利钟分频闪子(Clock division) 定义在定时器时钟(CKJNT)赖率与數宁滤波器(ETR. T1x>使用的采样频率之间的分频比佛^
00: tDTS - tcKJWT
F5 』
z
5 入餌数伎〒 TlMx_ARR 寄存F狀5 /
36 K 36
控制寄存器 TIMx CR1
14.4.1 控制寄存器 1 (TIMx_CR1)
偏移地址:0x00 复位位:0x0000
15 14 13 12 11 10 9 8
保留
CKD[1:O]
1
ARPE
65 C_:0]
4
3
DIR 0PM
2
-中央对齐模式(向上/向下计数):计数器从 0开始计数到设定的数值-1,产生一个计数 器 溢出事件,然后向下计数到1并且产生一 个计数器下溢事件;再从0开始重新计数。
CK_INT
_______________________________
______
CNT_EN
____ _nLrurLrLRmLrLRTLrLrLrm
CK_PSC
CNT_EN ____ 定口寸狀时钟-CK CNT 汁数杈奇//然
汁数器洫出 史新率件(UEV)
山新屮断标志(UIF)
n r n ..n .n .n .n n n .n n nnnn厂 厂
ruumjuvuirLiuuLrui
____._______________
TL
n
IM动加级影了寄77器
05_STM32F4通用定时器详细讲解教学提纲
TIM_TimeBaseInitStructure.TIM_CounterMode=TIM_CounterMode_Up; //向上计数模式
TIM_TimeBaseInitStructure.TIM_ClockDivision=TIM_CKD_DIV1;
定时器时钟上文已经讲了,由于Timer3挂在APB1总线上
故Timer3进入中断的周期为(CK_PSC+1)*(TIM3_ARR+1)/84000000秒
频率为84000000/[(CK_PSC+1)*(TIM3_ARR+1)] Hz
利用官方库函数实现每500ms进入中断,改变LED灯的电平,程序如下
14 TIM3捕获/比较寄存器2 (TIM3_CCR2)
15 TIM3捕获/比较寄存器3 (TIM3_CCR3)
16 TIM3捕获/比较寄存器4 (TIM3_CCR4)
1 Timer3用来做定时中断
与之相关的时基单元寄存器有
10 TIM3计数器(TIM3_CNT)
11 TIM3预分频器(TIM3_PSC)
12 TIM3自动重载寄存器(TIM3_ARR)
原理:
这里以向上计数为例,即计数器TIM3_CNT向上计数,当达到TIM3_ARR所设定的值时,归零重新计数,若使能了更新中断,则在TIM3_CNT归零时,进入中断。
进入中断的时间为(TIM3_ARR+1)个计时器周期
而计时器单元时钟是由定时器时钟分频得到,每(CK_PSC+1)个定时器周期计数一次。
1TIM3控制寄存器1 (TIM3_CR1)
STM32通用定时器使用详解
STM32通用定时器使用详解1.通用定时器基本介绍•通用定时器包括TIM2、TIM3、TIM4和TIM5•STM32通用定时器是一个通过可编程预分频器驱动的16位自动装载计数器构成。
•每个定时器都是完全独立的,没有互相共享任何资源。
它们可以一起同步操作。
•定时器可以进行定时器基本定时,输出4路PWM,输入捕获o本文详细介绍这三个功能并且利用定时器3并且示例代码使用2.开发环境开发平台:keil5单片机:STM32F103ZET63.基本定时功能3.1定时器时钟来源分析STM32部分时钟树:3.1.1 首先我们我们的系统时钟(SYSCLK 72MHz)经过AHB分频器给APB1外设,但是APB1外设最大的只能到36Mhz,所以必须要系统时钟的二分频。
下面又规定了如果APB1预分频系数为1则频率不变,否则频率X2至定时器2~7,所以定时器2~7的时钟频率为还是72MHz3.1.2 分配给我们定时器的时钟是72MHz,我们可以根据自己的需求再设置定时器的分频,设置它的定时值/** 初始化定时器的时候指定我们分频系数psc,这里是将我们的系统时钟(72MHz)进行分频* 然后指定重装载值arr,这个重装载值的意思就是当我们的定时器的计数值达到这个arr时,定时器就会重新装载其他值.例如当我们设置定时器为向上计数时,定时器计数的值等于arr之后就会被清0重新计数* 定时器计数的值被重装载一次被就是一个更新(Update)* 计算Update时间公式Tout = ((arr+1)*(psc+1))/T clk公式推导详解:Tclk是定时器时钟源,在这里就是72Mhz我们将分配的时钟进行分频,指定分频值为psc,就将我们的T clk分了psc+1,我们定时器的最终频率就是T clk/(psc+1) MHz 这里的频率的意思就是1s中记T clk/(psc+1)M个数(1M=10的6次方) ,每记一个数的时间为(psc+1)/Tclk ,很好理解频率的倒数是周期,这里每一个数的周期就是(psc+1)/T clk 秒然后我们从0记到arr 就是 (arr+1)*(psc+1)/T clk举例:比如我们设置arr=7199,psc=9999我们将72MHz (1M等于10的6次方) 分成了(9999+1)等于7200Hz就是一秒钟记录9000数,每记录一个数就是1/7200秒我们这里记录9000个数进入定时器更新(7199+1)*(1/7200)=1s,也就是1s进入一次更新Update*///简单进行定时器初始化,设置预装载值和分频系数void MY_TIM3_Init(u16 arr,u16 psc){//初始化结构体TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;//1.分配时钟RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3,ENABLE);//2.初始化定时器相关配置TIM_TimeBaseStructure.TIM_Period = arr;TIM_TimeBaseStructure.TIM_Prescaler = psc;/*在这里说一下这个TIM_ClockDivision 是设置与进行输入捕获相关的分频设置的这个值不会影响定时器的时钟频率,我们一般设置为TIM_CKD_DIV1,也就是不分频*/TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; //向上计数TIM_TimeBaseInit(TIM3,&TIM_TimeBaseStructure);//3.打开定时器TIM_Cmd(TIM3,ENABLE);}/****************** 主函数 ********************///在主函数中我们可以调用初始化int main(){//定时器初始化MY_TIM3_Init(7199,9999);while(1){//检测更新标志位if(TIM_GetFlagStatus(TIM3,TIM_IT_Update)){//清除标志位TIM_ClearFlag(TIM3,TIM_IT_Update);//....(每隔一秒执行任务)}}}4.定时器输出PWM4.1基本介绍4.1.1 PWM是脉冲宽度调制,我们是通过改变脉冲的宽度来达到改变输出电压的效果,本质上就是调节占空比实现的,STM32除了基本定时器(TIM6,TIM7)不能输出PWM以外,其它的定时器都具有输出PWM,其中高级定时器(TIM1和TIM8)还能输出7路PWM,基本定时器(TIM2,TIM3,TIM4,TIM5)也可以输出4路PWM输出PWM是很有用的,比如我们可以通过控制电机来玩小车,或者通过输出PWM改变LED的亮度,制造呼吸灯等等4.1.2 我们通用定时器能输出PWM的IO口是固定的,虽然我们可以通过重映射可以改变引脚,具体是哪一些IO口我们要通过查阅STM32的参考手册这里涉及到一个重映射的概念,重映射就是管脚的外设功能映射到另一个管脚,但是不是可以随便映射的,具体对应关系参考手册上的管脚说明。
STM32F4 第15讲 定时器中断实验-TIMER -M4
typedef struct {
uint16_t TIM_Prescaler; uint16_t TIM_CounterMode; uint16_t TIM_Period; uint16_t TIM_ClockDivision; uint8_t TIM_RepetitionCounter; } TIM_TimeBaseInitTypeDef;
✓ 通用定时器常用寄存器和库函数
定时器使能函数:
void TIM_Cmd(TIM_TypeDef* TIMx, FunctionalState NewState)
定时器中断使能函数:
void TIM_ITConfig(TIM_TypeDef* TIMx, uint16_t TIM_IT, FunctionalState NewState);
✓ 定时器中断实验
定时器中断实验相关寄存器
✓ 通用定时器常用寄存器和库函数 计数器当前值寄存器CNT
✓ 通用定时器常用寄存器和库函数 预分频寄存器TIMx_PSC
✓ 通用定时器常用寄存器和库函数 自动重装载寄存器(TIMx_ARR)
✓ 通用定时器常用寄存器和库函数 控制寄存器1(TIMx_CR1)
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
TIM_TimeBaseInitStructure.TIM_Period = arr;//自动装载值
TIM_TimeBaseInitStructure.TIM_ClockDivision=TIM_CKD_DIV1;
12 TIM3自动重载寄存器(TIM3_ARR)
当自动重载值为空时,计数器不工作
难道说每次事件都必须装载重载值?
13 TIM3捕获/比较寄存器1 (TIM3_CCR1)
输出时:CCR1是捕获/比较寄存器的预装载值,由TIM3_CCMR的OC1PE位使能。
输入时:CCR1为上一个输入捕获事件(IC1)发生时的计数器值。
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=0x01; //抢占优先级1
NVIC_InitStructure.NVIC_IRQChannelSubPriority=0x03; //子优先级3
NVIC_InitStructure.NVIC_IRQChannelCmd=ENABLE;
Timer3是一个16位的定时器,有四个独立通道,分别对应着PA6 PA7 PB0 PB1
主要功能是:1输入捕获——测量脉冲长度。
2输出波形——PWM输出和单脉冲输出。
Timer3有4个时钟源:
1:内部时钟(CK_INT),来自RCC的TIMxCLK
2:外部时钟模式1:外部输入TI1FP1与TI2FP2
1TIM3控制寄存器1 (TIM3_CR1)
作用:1使能自动重载TIM3_ARR
2定时器的计数器递增或递减计数。
3事件更新。
4计数器使能
2TIM3控制寄存器2 (TIM3_CR2)
3TIM3从模式控制寄存器(TIM3_SMCR)
4TIM3DMA/中断使能寄存器(TIM3_DIER)
作用:1:使能事件更新中断
1打开时钟,Timer3挂在APB1上,所以命令开启时钟。
RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3,ENABLE); ///使能TIM3时钟
2时钟Timer3的配置。
TIM_TimeBaseInitStructure.TIM_Period = arr;//自动重装载值
3:捕获/比较选择
8TIM3捕获/比较模式寄存器2 (TIM3_CCMR2)
9TIM3捕获/比较使能寄存器(TIM3_CCER)
1:上升沿触发or下降沿触发
2:捕获/比较输出使能
10 TIM3计数器(TIM3_CNT)
11 TIM3预分频器(TIM3_PSC)
计数器时钟频率CK_CNT等于fCK_PSC/ (PSC[15:0] + 1)。
TIM_TimeBaseInitStructure.TIM_Prescaler=psc; //定时器分频
TIM_TimeBaseInitStructure.TIM_CounterMode=TIM_CounterMode_Up; //向上计数模式
TIM_TimeBaseInitStructure.TIM_ClockDivision=TIM_CKD_DIV1;
3:外部时钟模式2:外部触发输入TIMx_ETR,仅适用于TIM2、TIM3、TIM4,TIM3,对应着PD2引脚
4:内部触发输入:一个定时器触发另一个定时器。
时钟源可以通过TIMx_SMCR相关位进行设置。这里我们使用内部时钟。
定时器挂在高速外设时钟APB1或低速外设时钟APB2上,时钟不超过内部高速时钟HCLK,故当APBx_Prescaler不为1时,定时器时钟为其2倍,当为1时,为了不超过HCLK,定时器时钟等于HCLK。
STM32F4系列共有14个定时器,功能很强大。14个定时器分别为:
2个高级定时器:Timer1和Timer8
10个通用定时器:Timer2~timer5和timer9~timer14
2个基本定时器:timer6和timer7
本篇欲以通用定时器timer3为例,详细介绍定时器的各个方面,并对其PWM功能做彻底的探讨。
2:使能捕获/比较中断
5TIM3状态寄存器(TIM3_SR)
1:事件更新中断标志
2:捕获/比较中断标志
6TIM3事件生成寄存器(TIM3_EGR)
7TIM3捕获/比较模式寄存器1 (TIM3_CCMR1)
1:输出比较模式
2:输出比较预装载使能,即使能后可以随时改变TIM3捕获/比较寄存器1(TIM3_CCR1)的值
TIM_TimeBaseInit(TIM3,&TIM_TimeBaseInitStructure);//初始化TIM3
TIM_ITConfig(TIM3,TIM_IT_Update,ENABLE); //允许定时器3更新中断
TIM_Cmd(TIM3,ENABLE); //使能定时器
NVIC_InitStructure.NVIC_IRQChannel=TIM3_IRQn; //定时器中断
14 TIM3捕获/比较寄存器2 (TIM3_CCR2)
15 TIM3捕获/比较寄存器3 (TIM3_CCR3)
16 TIM3捕获/比较寄存器4 (TIM3_CCR4)
1 Timer3用来做定时中断
与之相关的时基单元寄存器有
10 TIM3计数器(TIM3_CNT)
11 TIM3预分频器(TIM3_PSC)
TIM_TimeBaseInit(TIM3,&TIM_TimeBaseInitStructure);//初始化TIM3
3使能中断
TIM_ITConfig(TIM3,TIM_IT_Update,ENABLE); //允许定时器3更新中断。
4打开Timer3。
TIM_Cmd(TIM3,ENABLE); //使能定时器3
12 TIM3自动重载寄存器(TIM3_ARR)
原理:
这里以向上计数为例,即计数器TIM3_CNT向上计数,当达到TIM3_ARR所设定的值时,归零重新计数,若使能了更新中断,则在TIM3_CNT归零时,进入中断。
进入中断的时间为(TIM3_ARR+1)个计时器周期
而计时器单元时钟是由定时器时钟分频得到,每(CK_PSC+1)个定时器周期计数一次。
5配置中断。
6中断服务函数编写。
故可见STM32的初始化函数都离不开以下几步
1打开设备时钟。
2配置参数。
3打开设备。
设备需配置后再打开。如果需要配置中断,那么则需要编写中断服务函数。
完整程序如下
void TIM3_Int_Init(u16 arr,u16 psc)
{
TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStructure;
NVIC_Init(&NVIC_InitStructure);
}
/Timer3中断服务函数
void TIM3_IRQHandler(vus(TIM3,TIM_IT_Update)==SET)//溢出中断
{
GPIO_ToggleBits(GPIO_LED ,DS1_PIN);//LED灯电平翻转
例如:我们一般配置系统时钟SYSCLK为168MHz,内部高速时钟AHB=168Mhz,APB1欲分频为4,(因为APB1最高时钟为42Mhz),那么挂在APB1总线上的timer3时钟为84Mhz。
《STM32F4xx中文参考手册》的424~443页列出与通用定时器相关的寄存器一共20个,
以下列出与Timer3相关的寄存器及重要寄存器的简单介绍。
定时器时钟上文已经讲了,由于Timer3挂在APB1总线上
故Timer3进入中断的周期为(CK_PSC+1)*(TIM3_ARR+1)/84000000秒
频率为84000000/[(CK_PSC+1)*(TIM3_ARR+1)] Hz
利用官方库函数实现每500ms进入中断,改变LED灯的电平,程序如下
}
TIM_ClearITPendingBit(TIM3,TIM_IT_Update); //清除中断标志位
}
然后main()函数中TIM3_Int_Init(5000-1,8400-1);即可
可以计算进入中断的频率为2Hz即LED灯每500ms亮一次,LED周期为1Hz。
NVIC_InitTypeDef NVIC_InitStructure;
RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3,ENABLE); //使能TIM3时钟
TIM_TimeBaseInitStructure.TIM_Prescaler=psc; //定时器分频