STM32F407 HAL库 定时器

STM32定时器基础:频率单位、预分频与GPIO中断应用
本文介绍了STM32中兆赫兹频率单位、预分频技术、定时器分类及其在GPIO中断和PWM控制中的应用,包括高级定时器如TIM1和TIM8,以及基本定时器TIM6和TIM7的配置和使用示例,还展示了串口通信的集成测试。
基本概念
兆赫兹

1MHZ(兆赫兹)是频率的单位,表示每秒周期性震动1,000,000次。

预分频器

不分频

在这里插入图片描述

2分频,两个脉冲输出一次

在这里插入图片描述

三分频

在这里插入图片描述

自动重装载寄存器

当计时器里的计数器=自动重装载寄存器值,计数器清零

定时器分类
种类位数计数器模式产生DMA请求捕获/比较通道互补输出特殊应用场景
高级定时器(TIM1,TIM8)16向上,向下,向上/向下可以4带死区控制盒紧急刹车,可应用于PWM电机控制
通用定时器(TIM2~TIM5)16向上,向下,向上/向下可以4通用。定时计数,PWM输出,输入捕获,输出比较
基本定时器(TIM6,TIM7)16向上,向下,向上/向下可以0主要应用于驱动DAC

通用和基本时钟源:APB1

高级定时器时钟源:APB2

在这里插入图片描述

定时器配置

时钟源:内部时钟

在这里插入图片描述

假如记录1秒

1秒=自动重装载寄存器 / 输入HZ

1秒=自动重装载寄存器 / (时钟源 / 预分频器)

1秒 = 10000 / (72000000 / 7200)

1秒 = 10000 / (84000000 / 8400)

配置

Prescaler (PSC - 16 bits value) 预分频器

Counter Period 自动重装载寄存器

auto-reload preload 自动重新加载预加载

在这里插入图片描述

开启中断

在这里插入图片描述

LED测试代码

开启GPIO测试灯

在这里插入图片描述

测试中断

int index = 0;

void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{
	if(htim == &htim2)
	{
		if(index == 1)
		{
			index = 0;
			HAL_GPIO_WritePin(GPIOF, GPIO_PIN_6|GPIO_PIN_7|GPIO_PIN_8, GPIO_PIN_SET);
		}else{
			index = 1;
			HAL_GPIO_WritePin(GPIOF, GPIO_PIN_6|GPIO_PIN_7|GPIO_PIN_8, GPIO_PIN_RESET);
		}
	}
}

启动定时器

HAL_TIM_Base_Start_IT(&htim2);
串口测试代码

开启串口

在这里插入图片描述

串口打印

void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{
	if(htim == &htim2)
	{
		printf("Hello word STM32 \r\n");
	}
}

结果

在这里插入图片描述

测试案例
https://download.youkuaiyun.com/download/hmxm6/89005379

### STM32F407 HAL 定时器计时示例 对于STM32F407,利用HAL实现定时器计时功能主要通过初始化定时器、设置回调函数以及处理中断来完成。下面提供一段基于TIM2的定时器计时实例代码。 #### 初始化定时器 在`main.c`文件中的`MX_TIM2_Init()`函数用于配置定时器参数并启动它。此过程会自动调用`HAL_TIM_Base_MspInit()`来进行MSP初始化操作,包括NVIC、CLOCK等必要设置[^2]。 ```c static void MX_TIM2_Init(void) { TIM_ClockConfigTypeDef sClockSourceConfig = {0}; TIM_MasterConfigTypeDef sMasterConfig = {0}; htim2.Instance = TIM2; htim2.Init.Prescaler = 8399; // 预分频值取决于系统频率, 这里假设SYSCLK=84MHz htim2.Init.CounterMode = TIM_COUNTERMODE_UP; htim2.Init.Period = 999; // 自动重装载值决定溢出周期 htim2.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1; htim2.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE; if (HAL_TIM_Base_Init(&htim2) != HAL_OK) { Error_Handler(); } sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL; if (HAL_TIM_ConfigClockSource(&htim2, &sClockSourceConfig) != HAL_OK) { Error_Handler(); } sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET; sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE; if (HAL_TIMEx_MasterConfigSynchronization(&htim2, &sMasterConfig) != HAL_OK) { Error_Handler(); } } ``` #### 设置回调函数 当定义好定时器之后,在每次发生更新事件(即定时时间到达)时都会触发相应的中断服务程序(ISR),而ISR内部则会执行预设好的回调函数。这里展示了一个简单的串口打印例子: ```c void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim) { if (htim->Instance == TIM2) { printf("Hello world from STM32!\r\n"); } } ``` 这段代码会在每秒钟输出一次字符串到调试端口上[^3]。 #### 启动定时器 最后一步是在主循环或者适当位置调用如下API开启定时器: ```c if(HAL_TIM_Base_Start_IT(&htim2)!= HAL_OK){ /* Starting Error */ Error_Handler(); } ``` 上述代码片段展示了如何使用HALSTM32F407配置和运行一个基本的定时器应用案例。需要注意的是实际项目开发过程中还需要考虑更多细节比如错误处理机制等等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值