STM32G474之TIM1更新中断

STM32G474之TIM1能产生如下的中断:

1、捕获比较1个事件(Capture compare 1 event)

用来获取"捕获输入脉冲的时间",其次用来输出"比较输出波形";

2、捕获比较2个事件(Capture compare 2 event)

3、捕获比较3个事件(Capture compare 3 event)

4、捕获比较4个事件(Capture compare 4 event)

5、TIM更新事件(TIM Update event)

定时器计数器溢出,产生更新事件

6、TIM刹车输入事件(TIM Break input event)

当刹车信号到达时,则产生刹车输入事件

7、TIM刹车2输入事件TIM Break2 input event

8、TIM触发器检测事件(TIM Trigger detection event)

9、TIM换向事件(TIM commutation event)

10、TIM编码器索引事件(TIM Encoder index event)

11、TIM方向更改事件(TIM Direction change event)

12、TIM索引错误事件(TIM Index error event)

13、TIM转换错误事件(TIM Transition error event)

定时器的功能太多了,从简单入手,先学习定时器计数器溢出产生中断。这个功能是比较常用,所以先学习。

测试程序如下:

#include "Timer1.h"
#include "LED.h"
#include "stm32g4xx_hal.h"

void Timer1_Init(void);

void Timer1_Init(void)

{

TIM_HandleTypeDef htim1; //TIM1句柄

RCC_ClkInitTypeDef clkconfig;

uint32_t uwTimclock = 0;

uint32_t pFLatency;

uint32_t uwPrescalerValue = 0;

__HAL_RCC_TIM1_CLK_ENABLE();//使能"定时器1"的时钟,Enable TIM1 clock

HAL_RCC_GetClockConfig(&clkconfig, &pFLatency);//Get clock configuration

uwTimclock = HAL_RCC_GetPCLK2Freq();
//读取PCLK2的时钟频率,Return the PCLK2 frequency
//若PCLK2的分频器值为1,则和SystemCoreClock的值相等
//uwTimclock=170000000Hz

uwPrescalerValue = (uint32_t) ((uwTimclock / 10000U) - 1U);

//uwPrescalerValue=17000

htim1.Instance = TIM1;

htim1.Init.Period = (1000000U / 1000U) - 1U;

//定时器周期999

htim1.Init.Prescaler = uwPrescalerValue;

//设置TIM1预分频器为uwPrescalerValue

htim1.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
//设置时钟分频系数,TIM1_CR1中的CKD9:8=00b,tDTS=ttim_ker_ck;
//溢出时间为(990+1)*1*17000/170000000/1=0.1秒

htim1.Init.CounterMode = TIM_COUNTERMODE_UP;

htim1.Init.RepetitionCounter = 0;//重复计数(1-0)次,产生1次中断,比较重要

htim1.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_ENABLE;

//使能"自动重装载"

HAL_TIM_Base_Init(&htim1);

HAL_TIM_Base_Start_IT(&htim1);

HAL_NVIC_EnableIRQ(TIM1_UP_TIM16_IRQn);//使能TIM1产生中断

HAL_NVIC_SetPriority(TIM1_UP_TIM16_IRQn, 5, 0U);
//设置NVIC中断分组4:4位抢占优先级,0位响应优先级
//选择中断优先级组4,即抢占优先级为4位,取值为0~15,响应优先级组为0位,取值为0
//这里设置TIM1中断优先级为5

}

//TIM1"更新中断"和TIM16中断,共用一个中断源,TIM1每0.1秒中断一次
void TIM1_UP_TIM16_IRQHandler(void)

{

if( (TIM1->SR & TIM_FLAG_UPDATE) == TIM_FLAG_UPDATE)

{//读取TIM1状态寄存器TIMx_SR的bit0(UIF),UIF=1表示产生了"TIM1更新事件"

if( (TIM1->DIER & TIM_IT_UPDATE) == TIM_IT_UPDATE )

{//读取TIM1中断使能寄存器TIMx_DIER的bot0(UIE),查看UIE=1?

TIM1->SR = ~(TIM_IT_UPDATE);

LED1_Toggle(); //LED1引脚输出电平翻转

}

}

}

测试结果:

相关推荐
zlinear数据采集卡11 小时前
定时器电路深度解析:从经典555到STM32定时器,从ZLinear采集卡的工程化设计实战
stm32·单片机·嵌入式硬件·fpga开发·自动化
y.Ghost11 小时前
FreeRTOS-基础知识
嵌入式硬件
m0_3771081411 小时前
stm32-USART
stm32·单片机·嵌入式硬件
szxinmai主板定制专家12 小时前
基于 ARM+FPGA精密多轴实时运动控制卡设计方案,适用于半导体设备等高精度领域(一)
arm开发·人工智能·嵌入式硬件·fpga开发·架构·语音识别
叶沧ii大数据全栈呀12 小时前
Build-Your-Own-X 实战指南:从复刻经典到掌握核心原理
经验分享·开源
casual~12 小时前
十六届蓝桥杯国赛个人题解
经验分享·学习·算法·蓝桥杯
不做无法实现的梦~14 小时前
常见工程分析软件
stm32·嵌入式硬件·算法
国产电子元器件15 小时前
电流检测信号漂移问题分析
单片机·嵌入式硬件
YangWeiminPHD15 小时前
单片机AI边缘计算发展之路:从M0的开局到三足鼎立的智能革命
人工智能·单片机·边缘计算
梁朝辉15 小时前
筛选运算放大器时对于开环增益这一项参数怎么看?
嵌入式硬件·硬件工程