正点原子--STM32通用定时器学习笔记(2)

1. 通用定时器输入捕获部分框图介绍

捕获/比较通道的输入部分(通道1)

输入通道映射CC1S1:0→采样频率CKD1:0→滤波方式IC1F3:0→边沿检测方式CC1P→捕获分频ICPS1:0→使能捕获CC1E

输入部分对相应的TIx输入信号采样,并产生一个滤波后的信号TIxF。之后带极性选择的边缘检测器产生一个信号(TIxFPx),它可以作为从模式控制器的输入触发或者作为捕获控制。该信号通过预分频进入捕获寄存器(ICxPS)。

按照上述配置流程,依次配置对应的寄存器。

首先配置输入通道映射CC1S1:0,配置为01从TI1FP1线路输入,配置为10从TI2FP1线路输入,配置为11从TRC线路输入,如下图所示。

接下来设置采样频率:控制寄存器 1(TIMx_CR1)的CKD1:0 ⬇⬇⬇设置滤波方式选择: 捕获/ 比较模式寄存器 1(TIMx_CCMR1)的输入捕获部分⬇⬇​​​​​​​⬇​​​​​​​选择边沿检测方式: 捕获/ 比较使能寄存器(TIMx_CCER)⬇​​​​​​​⬇​​​​​​​⬇​​​​​​​

设置输入通道映射: 捕获/ 比较模式寄存器 1(TIMx_CCMR1)⬇​​​​​​​⬇​​​​​​​⬇​​​​​​​

使能捕获: 捕获/ 比较使能寄存器(TIMx_CCER)

以上配置好后所产生的IC1PS来到捕获/比较通道1的主电路部分,也就到了下一部分的学习。

捕获/比较通道1的主电路---输入部分

上图深灰色部分为输出部分,我们不看它。

①配置CC1S为输入,经过或门1输出信号1;

②配置捕获使能→1,以及捕获分频后的信号→1,两者都为1,经过与门1后输出为1(这里的"捕获到信号"和"捕获使能"是通过硬件产生,也可通过软件产生捕获事件,两者二选一)

或门1 输出信号1,与门1 输出信号1 经过 或门2 输出信号也为1,两者都为1,那么与门2 输出为1,会触发捕获事件,此时会把计数器的值转移到捕获/比较影子寄存器 ,由于捕获/比较影子寄存器 不可直接访问,便会再次把数值转移到捕获/比较预装载寄存器(CCRx1~4)让用户读取,什么时候转移呢?当CCR1读操作完成时产生信号1,经过与门3输出1,这时就会把影子寄存器的值转移到预装载寄存器中,程序员直接读取CCR1寄存器的值就相当于直接获取了计数器的值。

举个栗子,假设通道1配置为上升沿触发,当捕获到上升沿信号产生捕获事件,计数器里的数值会转移到捕获/比较影子寄存器,再转移到捕获/比较预装载寄存器,这时读取CCR1的值记为CNT1,当捕获到上升沿时通过硬件立刻配置为下降沿触发,当捕获到下降沿后获取对应的计数值为CNT2,CNT2-CNT1的值就是一个高电平的计数个数,通过计数个数以及定时器计数频率就可以算出高电平持续的时间。

2. 通用定时器输入捕获脉宽测量原理


相关推荐
国科安芯4 小时前
基于AS32S601ZIT2型抗辐照MCU的商业航天卫星姿态确定与控制系统研究
单片机·嵌入式硬件·安全·fpga开发·架构·risc-v
三品吉他手会点灯5 小时前
STM32F103 学习笔记-24-I2C-读写EEPROM(第2节)-I2C协议层介绍
笔记·stm32·学习
项目題供诗5 小时前
STM32-DMA数据转运+AD多通道(二十一)
stm32·单片机·嵌入式硬件
z200509305 小时前
【C++学习】C++ 类型转换深度解析:从 C 风格缺陷到 C++ 四种安全转换的思想内核
c语言·c++·学习
FPC_小西5 小时前
LDO 低压差线性稳压器 拆解电源稳压核心原理
人工智能·单片机·嵌入式硬件·集成学习·pcb工艺·hdi高密度互联
三品吉他手会点灯5 小时前
STM32F103 学习笔记-24-I2C-读写EEPROM(第3节)-STM32的I2C框图详解
笔记·stm32·学习
sheeta19985 小时前
LeetCode 每日一题笔记 日期:2026.06.14 题目:2130. 链表最大孪生和
笔记·leetcode·链表
踏着七彩祥云的小丑5 小时前
嵌入式测试学习第 36 天:串口日志分析、通过日志定位简单问题
单片机·嵌入式硬件·学习
Flittly5 小时前
【AgentScope Java新手村系列】(7)子Agent编排
java·spring boot·笔记·spring·ai
MartinYeung55 小时前
[论文学习]LLM 情境学习资料的快速精确遗忘技术:基于 In-Context Learning 与量化 K-Means 的 ERASE 方法
学习·算法·kmeans