STM32 定时器的使用

1.TIM定时器的时间计算
以stm32f4为例,APB2时钟最高84M,APB1时钟最高42M
TIM使用APB2时钟,具体可查询时钟树(以不分频时钟84M做计算)
时钟/psc(分频系数/84-1)*ARR(重装载值/500-1)=每次产生中断时间
TIM1_Init(500-1,84-1);
每次中断时间=84M/84 *500=500 ms
注:PSC和ARR都是从0开始的,所以要减1。ARR存在于CNT寄存器中,而CNT为16位,所以ARR不要超过16位二进数。
2.使用定时器进行定时
(1)除了对定时器进行初始化之外,还需在stm32f4xx_it.c (要根据使用的芯片而定)中增加定时器中断函数,在函数中一定清除中断标志位。

//定时器1中断服务函数
void TIM1_IRQHandler(void)
{
	if(TIM_GetITStatus(TIM1,TIM_IT_Update)==SET) //溢出中断
	{
		TIME++;
	}
	TIM_ClearITPendingBit(TIM1,TIM_IT_Update);  //清除中断标志位
}

(2)中断计数,判断条件要放在while最外层。

if(time >= 500)//这里选>=是避免由于受其他中断或者优先级更高的事件,从而错过
{
    time = 0;
    LED = ~LED;
}

3.使用定时器输出pwm波
(1)初始化代码

/TIM1 PWM部分初始化 
//PWM输出初始化
//arr:自动重装值
//psc:时钟预分频数
void TIM14_PWM_Init(u32 arr,u32 psc)
{		 					 
	GPIO_InitTypeDef GPIO_InitStructure;
	TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
	TIM_OCInitTypeDef  TIM_OCInitStructure;
	
	RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM14,ENABLE);  	//TIM14时钟使能    
	RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOF, ENABLE); 	//使能PORTF时钟	
	
	GPIO_PinAFConfig(GPIOF,GPIO_PinSource9,GPIO_AF_TIM14); //GPIOF9复用为定时器14
	
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;           //GPIOF9
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;        //复用功能
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;	//速度100MHz
	GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;      //推挽复用输出
	GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;        //上拉
	GPIO_Init(GPIOF,&GPIO_InitStructure);              //初始化PF9
	  
	TIM_TimeBaseStructure.TIM_Prescaler=psc;  //定时器分频
	TIM_TimeBaseStructure.TIM_CounterMode=TIM_CounterMode_Up; //向上计数模式
	TIM_TimeBaseStructure.TIM_Period=arr;   //自动重装载值
	TIM_TimeBaseStructure.TIM_ClockDivision=TIM_CKD_DIV1; 
	
	TIM_TimeBaseInit(TIM14,&TIM_TimeBaseStructure);//初始化定时器14
	
	//初始化TIM14 Channel1 PWM模式	 
	TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; //选择定时器模式:TIM脉冲宽度调制模式2
 	TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; //比较输出使能
	TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_Low; //输出极性:TIM输出比较极性低
	TIM_OC1Init(TIM14, &TIM_OCInitStructure);  //根据T指定的参数初始化外设TIM1 4OC1

	TIM_OC1PreloadConfig(TIM14, TIM_OCPreload_Enable);  //使能TIM14在CCR1上的预装载寄存器
 
  TIM_ARRPreloadConfig(TIM14,ENABLE);//ARPE使能 
	
	TIM_Cmd(TIM14, ENABLE);  //使能TIM14									  
}  

(2)调用代码

  TIM14_PWM_Init(1250-1,84-1);   //定时器时钟为84M,分频系数为84,所以计数频率为84M/84=1Mhz,重装载值1250,所以PWM频率为 1M/1250=800hz. 
    TIM_SetCompare1(TIM14,625); //占空比50%.   PWM每一个周期为1s/800hz=1.25ms=1250us.设置低电平时间为625us.
STM32定时器是该系列微控制器中的重要组成部分,它通常用于计时、计数、PWM信号生成、输入捕获等功能。STM32定时器有基本定时器、通用定时器和高级控制定时器等类型,不同的定时器功能有所不同。 使用STM32定时器的基本步骤如下: 1. 配置时钟源:首先需要配置定时器的时钟源,确保定时器可以正常工作。通常这涉及到启动定时器的时钟(APBx上的定时器时钟使能)。 2. 定时器初始化:通过定时器的控制寄存器来配置定时器的工作模式、预分频值、自动重载值等参数。预分频值决定了定时器计数的频率,而自动重载值则决定计数的范围。 3. 中断或事件配置(可选):如果需要定时器产生中断或用于事件触发,还需要配置相应的中断使能,并且在中断服务程序中处理定时器溢出等事件。 4. 启动定时器:最后,使能定时器计数。如果之前配置了中断,当定时器达到设定条件时(比如溢出或匹配到预设值),会触发中断。 下面是一个简化的代码示例,展示如何在STM32中配置和启动一个基本的定时器: ```c // 假设使用的是STM32的HAL库 #include "stm32f1xx_hal.h" // 定时器初始化函数 void TIM3_Init(void) { // 使能TIM3时钟 __HAL_RCC_TIM3_CLK_ENABLE(); // 定时器句柄声明 TIM_HandleTypeDef htim3; // 定时器基本配置 htim3.Instance = TIM3; htim3.Init.Prescaler = 0xFFFF; // 设置预分频值 htim3.Init.CounterMode = TIM_COUNTERMODE_UP; // 向上计数模式 htim3.Init.Period = 0xFFFF; // 设置自动重载值 htim3.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1; // 设置时钟分频因子 HAL_TIM_Base_Init(&htim3); // 启动定时器 HAL_TIM_Base_Start(&htim3); } // 主函数中调用初始化函数 int main(void) { // HAL库初始化 HAL_Init(); // 配置系统时钟 SystemClock_Config(); // 初始化定时器 TIM3_Init(); // 主循环 while (1) { // 其他任务... } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值