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; // 使能更新中断
相关推荐
lizhihai_994 小时前
股市学习心得-AI算力20大硬件四金刚
学习
卖芒果的潇洒农民4 小时前
【0417】学习路线
学习
xzal125 小时前
python中,turtle基础知识笔记1
笔记·python·turtle
han_hanker5 小时前
RequestAttributes , ServletRequestAttributes学习
学习
weixin_513449966 小时前
PCA、SVD 、 ICP 、kd-tree算法的简单整理总结
c++·人工智能·学习·算法·机器人
鱼鳞_6 小时前
Java学习笔记_Day29(异常)
java·笔记·学习
嵌入式小企鹅7 小时前
DeepSeek-V4昇腾首发、国芯抗量子MCU突破、AI编程Agent抢班夺权
人工智能·学习·ai·程序员·算力·risc-v
Amazing_Cacao7 小时前
CFCA精品可可产区认证课程风土解析(亚洲):撕开标签伪装,将微气候差异转化为可用变量
学习
我的xiaodoujiao7 小时前
API 接口自动化测试详细图文教程学习系列11--Requests模块3--测试练习
开发语言·python·学习·测试工具·pytest
九成宫8 小时前
IT项目管理期末复习——Chapter 8 项目质量管理
笔记·项目管理·软件工程