7. STM32——定时器中断(1秒闪烁灯)

基本框架

1. 配置定时器时钟

在 stm32f10x_rcc.h 头文件中查找相关函数函数

RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);

2. 配置定时器结构体

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在 stm32f10x_tim.h 头文件中查找相关函数函数

TIM_TimeBaseInitTypeDef timInitStructure;

//2.配置定时器结构体
timInitStructure.TIM_ClockDivision	=	TIM_CKD_DIV1; //tDTS = Tck_tim
timInitStructure.TIM_CounterMode	=	TIM_CounterMode_Up; //向上计数模式
timInitStructure.TIM_Period			=	10000-1; //自动重装载寄存器周期的值。
timInitStructure.TIM_Prescaler		=	7200-1; //定时器预分频设置
//配置成1秒闪烁

3. 开启定时器中断

在 stm32f10x_tim.h 头文件中查找相关函数函数

TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE);
TIM_Cmd(TIM2, ENABLE);

4. 配置中断结构体

在 misc.h 头文件中查找相关函数函数

TIM2_IRQn 在 stm32f10x.h 头文件中可以查找到

NVIC_InitTypeDef nvicInitStructure;

//4.配置中断结构体
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
		
nvicInitStructure.NVIC_IRQChannel					= TIM2_IRQn;
nvicInitStructure.NVIC_IRQChannelPreemptionPriority	= 1;
nvicInitStructure.NVIC_IRQChannelSubPriority		= 1;
nvicInitStructure.NVIC_IRQChannelCmd				= ENABLE;
		
NVIC_Init(&nvicInitStructure);

5. 搭建定时器中断服务函数

//5.搭建定时器中断服务函数
void TIM2_IRQHandler(void)
{
		static uint16_t t = 0;
		
		if( TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET) //发生中断
		{
				if(t++ %2 == 1) //t 为奇数时,LED亮 为偶数时,LED灭
				{
						GPIO_ResetBits(GPIOC, GPIO_Pin_13);
				}
				else
				{
						GPIO_SetBits(GPIOC, GPIO_Pin_13);
				}
		}
		
		TIM_ClearITPendingBit(TIM2, TIM_IT_Update); //清除定时中断标志
		
}

闪烁灯代码整合

tim.c

#include "tim.h"
#include "stm32f10x.h"

void tim_Init(void)
{
		TIM_TimeBaseInitTypeDef timInitStructure;
		NVIC_InitTypeDef 				nvicInitStructure;
	
		//1.配置定时器时钟
		RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);
		
		//2.配置定时器结构体
		timInitStructure.TIM_ClockDivision	= TIM_CKD_DIV1;
		timInitStructure.TIM_CounterMode	= TIM_CounterMode_Up;
		timInitStructure.TIM_Period			= 10000-1;
		timInitStructure.TIM_Prescaler		= 7200-1;
		
		TIM_TimeBaseInit(TIM2, &timInitStructure);
		//3.开启定时器中断
		TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE);
		TIM_Cmd(TIM2, ENABLE);
		
		//4.配置中断结构体
		NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
		
		nvicInitStructure.NVIC_IRQChannel					= TIM2_IRQn;
		nvicInitStructure.NVIC_IRQChannelPreemptionPriority	= 1;
		nvicInitStructure.NVIC_IRQChannelSubPriority		= 1;
		nvicInitStructure.NVIC_IRQChannelCmd				= ENABLE;
		
		NVIC_Init(&nvicInitStructure);
		
		//5.搭建定时器中断服务函数
		
}

tim.h

#include "stm32f10x.h"

void tim_Init(void);

main.c

#include "stm32f10x.h"
#include "main.h"
#include "led.h"
#include "shake.h"
#include "relay.h"
#include "exti.h"
#include "usart.h"
#include "tim.h"

void delay(uint16_t time)
{
	uint16_t i=0;
	
	while(time--)
	{
		i=10000;
		while(i--);
	}
}

int  main()
{
		LED_Init();
		tim_Init();
		
		GPIO_SetBits(GPIOC, GPIO_Pin_13);
		
//		USARTSendByte(USART1, 'O');
//		USARTSendByte(USART1, 'K');
//		printf("Yinyuer is a pretty girl!");
		
		while(1)
		{
				
		}
}

//5.搭建定时器中断服务函数
void TIM2_IRQHandler(void)
{
		static uint16_t t = 0;
		
		if( TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET)
		{
				if(t++ %2 == 1)
				{
						GPIO_ResetBits(GPIOC, GPIO_Pin_13);
				}
				else
				{
						GPIO_SetBits(GPIOC, GPIO_Pin_13);
				}
		}
		
		TIM_ClearITPendingBit(TIM2, TIM_IT_Update);
		
}

1秒闪烁灯

在这里插入图片描述

  • 12
    点赞
  • 123
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
STM32是一款广泛应用于嵌入式系统的微控制器,通过定时器可以方便地实现LED闪烁功能。 首先,我们需要配置一个定时器来控制LED闪烁间隔。定时器可以选择使用内部的系统时钟作为时基,也可以通过外部时钟源提供时基。在本例中,我们选择使用内部时钟作为时基。 接下来,我们需要配置GPIO引脚来控制LEDSTM32有多个GPIO引脚可以用来控制LED的亮灭状态。我们将一个GPIO引脚配置为输出模式,并连接到LED。 然后,我们需要编写代码来配置定时器和GPIO引脚,并实现LED闪烁。 首先,我们使用CubeMX来配置STM32的时钟源和GPIO引脚。我们选择一个合适的时钟源作为定时器的时基,同时将一个GPIO引脚配置为输出模式,并连接到LED。 然后,我们打开Keil或其他编程软件,编写C语言代码来实现LED闪烁。在代码中,我们使用定时器的中断功能来控制LED的亮灭状态。 首先,我们初始化定时器并配置定时器的参数,如定时器的预分频值和计数器的重载值。然后,我们使能定时器的中断,并编写一个中断服务函数来处理定时器中断。 在中断服务函数中,我们使用一个计数变量来记录中断的次数。当计数变量达到我们需要的闪烁间隔时,我们改变LED的状态,即改变GPIO引脚的电平状态,使LED闪烁。 最后,我们在主函数中启动定时器,并进入一个无限循环来保持程序的运行。在无限循环中,我们不需要做任何操作,因为LED闪烁将由定时器中断实现。 通过上述步骤,我们成功实现STM32通过定时器来控制LED闪烁功能。这样,每当定时器中断触发时,LED的状态就会改变,从而实现了LED闪烁效果。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值