STM32CubeMX定时器中断

本文介绍如何使用CubeMx配置STM32定时器,并通过代码实现每秒中断一次的功能。此外,还详细展示了如何控制LED灯的状态变化,包括配置步骤、关键代码片段及其实现原理。

一、使用CubeMx配置文件

1、创建文件,如图所示
在这里插入图片描述
在这里插入图片描述

2、配置LED灯,将引脚设为输出模式,如图所示
在这里插入图片描述

3、配置时钟
有关定时器的内容可以查看中文手册
定时器有一个时钟频率计算用于计数时间,假如时钟频率为8M,不进行分频处理,那么
定时器计数一次需要时间是1/8M s约等于0.1微秒。
定时器产生中断的时间T=计数周期数/(时钟频率/分频数)
例如:时钟频率是15M,实现每一秒产生一次定时器中断
分频数和计数周期可以自己设定(范围在65535~1)
15/15000*1000 :计数1000次就是一秒,一秒产生一次中断。
分频数:15000-1 计数周期:1000-1
-1:分频数和计数周期都是从0开始,硬件给我们自动加1
配置如图所示
在这里插入图片描述
从图上可以看出没有采用分频默认为16MHZ,这里将它2分频,如图所示
在这里插入图片描述
配置参数
请添加图片描述

在这里插入图片描述

4、配置文件
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5、生成文件
在这里插入图片描述

二、修改代码

1、添加启动文件
在这里插入图片描述
2,看一下定时器的初始化,是否和配置的一样
在这里插入图片描述
3、主函数修改(添加开启中断函数)
在这里插入图片描述

延时函数要在.h文件中进行声明,
在HAL库文件中可以查看中断开启函数
在这里插入图片描述

在这里插入图片描述
4、time.c函数的修改
添加了一个LED灯的控制函数和一个重载回调函数

#include "tim.h"
#include "gpio.h"

TIM_HandleTypeDef htim1;
int k = 0x1;
void MX_TIM1_Init(void)
{
  TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  TIM_MasterConfigTypeDef sMasterConfig = {0};

  htim1.Instance = TIM1;
  htim1.Init.Prescaler = 8000-1;
  htim1.Init.CounterMode = TIM_COUNTERMODE_UP;
  htim1.Init.Period = 999;
  htim1.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  htim1.Init.RepetitionCounter = 0;
  htim1.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_ENABLE;
  if (HAL_TIM_Base_Init(&htim1) != HAL_OK)
  {
    Error_Handler();
  }
  sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  if (HAL_TIM_ConfigClockSource(&htim1, &sClockSourceConfig) != HAL_OK)
  {
    Error_Handler();
  }
  sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  if (HAL_TIMEx_MasterConfigSynchronization(&htim1, &sMasterConfig) != HAL_OK)
  {
    Error_Handler();
  }

}
//led处理函数,要在time.h中声明
void LED_Key(int x)
{
	if(x == 1)
	{
	   HAL_GPIO_WritePin(GPIOB, GPIO_PIN_0, GPIO_PIN_RESET);
		 HAL_GPIO_WritePin(GPIOB, GPIO_PIN_1, GPIO_PIN_SET);
	  
	}
	else 
	{
		 HAL_GPIO_WritePin(GPIOB, GPIO_PIN_1, GPIO_PIN_RESET);
		 HAL_GPIO_WritePin(GPIOB, GPIO_PIN_0, GPIO_PIN_SET);
	}
}

void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{
		//取反,来获取不同的LED状态
	  k = ~k;
	  LED_Key(k);
}
### 配置和使用 STM32 CubeMX 中的定时器中断 #### 使用 HAL 库初始化定时器并设置中断回调函数 为了在 STM32 设备上利用定时器中断,需先通过 STM32CubeMX 工具完成基本硬件配置。启动该软件后创建新项目,并选择目标微控制器型号。 对于具体定时器的选择,在外设配置界面找到 TIMx (其中 x 表示具体的定时器编号),点击进入其参数设定页面。这里可以指定计数模式、自动重装载值以及预分频系数等重要属性[^1]。 当完成了上述基础配置之后,还需要开启相应的时钟资源及使能全局中断选项。这一步骤同样是在图形化界面上操作完成,确保选择了“Enable”状态下的 NVIC 设置项对应所使用的定时器通道[^2]。 接着生成初始化代码框架,这部分工作由 STM32CubeMX 自动生成。打开工程文件夹内的 `main.c` 文件查看自动生成的部分源码片段: ```c /* USER CODE BEGIN PV */ uint8_t TimerFlag = 0; /* USER CODE END PV */ /* Private function prototypes -----------------*/ void SystemClock_Config(void); static void MX_GPIO_Init(void); static void MX_TIM2_Init(void); /* 这里假设选用的是TIM2定时器 */ ``` 注意到有一个名为 `MX_TIM2_Init()` 的函数声明被包含进来,这就是用来执行实际硬件寄存器写入动作的地方。而用户可以在自己的应用程序逻辑部分定义变量来跟踪时间事件的发生情况,比如上面例子中的 `TimerFlag` 变量用于标志一次完整的周期结束。 最后也是最关键的一环就是编写处理程序响应机制即所谓的 ISR(Interrupt Service Routine)。根据 HAL 库的规定,应该覆盖默认版本的 `HAL_TIM_PeriodElapsedCallback()` 函数以便于实现特定业务需求的功能扩展[^3]: ```c // 定义定时器溢出回调函数 void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim){ if(htim->Instance==TIM2){ // 判断是否为 TIM2 中断触发 TimerFlag = !TimerFlag; // 翻转标志位 GPIO_TogglePin(GPIOA,GPIO_PIN_5); // 假定 PA5 是 LED 输出端口,则此句会使得LED闪烁 } } ``` 以上就是在 STM32 CubeMX 中配置和使用定时器中断的方法概述。
评论 6
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Liu Zz

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值