STM32F103_LL库+寄存器学习笔记22 - 基础定时器TIM实现1ms周期回调

导言


如上所示,STM32F103有两个基本定时器TIM6与TIM7,所谓「基本定时器」,即功能最简单的定时器。

项目地址:

github:

gitee(国内):

一、LL库


1.1、CubeMX

如上所示,STM32F103 的定时器时钟频率均为 72 MHz。


1.2、tim.c

CubeMX 根据上述配置,自动生成了相应初始化代码。

1.3、main.c

1.4、stm32f1xx_it.c

1.5、编译、调试


如上所示,串口疯狂打印"Hello,World\n"。

二、寄存器方式


2.1、myTIM6Drive.c


如上所示,基于寄存器的实现代码简洁明了。

2.2、编译、调试


由此可见,两种实现方式在功能和效果上完全一致。

三、梳理寄存器


3.1、RCC_APB1ENR时钟使能寄存器

c 复制代码
RCC->APB1ENR |= RCC_APB1ENR_TIM6EN; // 使能 TIM6 时钟

3.2、TIMx_PSC预分配寄存器

c 复制代码
TIM6->PSC = 71;      /* PSC 寄存器:计数时钟 = PCLK1/(PSC+1) */

3.3、TIMx_ARR自动重载寄存器

c 复制代码
TIM6->ARR = 999;     /* ARR 寄存器:计数到 ARR 后产生更新事件 */

3.4、TIMx_CR1控制寄存器1

c 复制代码
TIM6->CR1 |= TIM_CR1_ARPE; /* 3. 使能 ARR 预装载 */

TIM6->CR1 |= TIM_CR1_CEN;  /* 4. 启动定时器 */

3.5、TIMx_SR状态寄存器

c 复制代码
TIM6->SR &= ~TIM_SR_UIF; /* 1. 清除更新中断标志 */

在中断回调函数中,遇到 UIF 更新中断时,需要及时将其标志位清零。
TIM_SR_UIF 定义为 0x0001(即 bit-0)。所以,~TIM_SR_UIF 等于 0xFFFE。把 UIF 位对应的位置为 0,其它位为 1。最终,SR &= 0xFFFE 就是"给 UIF 写 0,给其它位写 1"------符合"写 0 清"语义。

3.6、TIMx_DIER中断使能寄存器

如上所示,将 DIER 寄存器的 UIE 位置 1,可使能 TIMx 的更新中断(计数溢出)。

c 复制代码
TIM6->DIER |= TIM_DIER_UIE; // 使能更新中断
相关推荐
好好研究22 分钟前
学习栈和队列的插入和删除操作
数据结构·学习
新中地GIS开发老师1 小时前
新发布:26考研院校和专业大纲
学习·考研·arcgis·大学生·遥感·gis开发·地理信息科学
猫猫的小茶馆2 小时前
【STM32】通用定时器基本原理
c语言·stm32·单片机·嵌入式硬件·mcu·51单片机
SH11HF2 小时前
小菜狗的云计算之旅,学习了解rsync+sersync实现数据实时同步(详细操作步骤)
学习·云计算
Frank学习路上2 小时前
【IOS】XCode创建firstapp并运行(成为IOS开发者)
开发语言·学习·ios·cocoa·xcode
jingshaoqi_ccc2 小时前
stm32的USART使用DMA配置成循环模式时发送和接收有着本质区别
stm32·单片机·嵌入式硬件
Chef_Chen4 小时前
从0开始学习计算机视觉--Day07--神经网络
神经网络·学习·计算机视觉
X_StarX5 小时前
【Unity笔记02】订阅事件-自动开门
笔记·学习·unity·游戏引擎·游戏开发·大学生
MingYue_SSS5 小时前
开关电源抄板学习
经验分享·笔记·嵌入式硬件·学习
巴伦是只猫6 小时前
【机器学习笔记 Ⅱ】1 神经网络
笔记·神经网络·机器学习