stm32定时器中TIM_ICInit、TIX、ICX、TIXFPX是什么

看这个函数,使用时,需要定义一个结构体变量,结构体变量里面填充数据,然后传入TIM_ICInit进行初始化。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

TIM_ICInit中,需要用到结构体变量的5个成员:
在这里插入图片描述
这个函数里面怎么样进行的呢?

void TIM_ICInit(TIM_TypeDef* TIMx, TIM_ICInitTypeDef* TIM_ICInitStruct)
{
  …… … …… …
    if (TIM_ICInitStruct->TIM_Channel == TIM_Channel_1)
  {
    assert_param(IS_TIM_LIST8_PERIPH(TIMx));
    /* TI1 Configuration */
    TI1_Config(TIMx, TIM_ICInitStruct->TIM_ICPolarity,
               TIM_ICInitStruct->TIM_ICSelection,
               TIM_ICInitStruct->TIM_ICFilter);
    /* Set the Input Capture Prescaler value */
    TIM_SetIC1Prescaler(TIMx, TIM_ICInitStruct->TIM_ICPrescaler);
  }
  … … …… … …
}

根据通道不同进行条件选择,调用TIx_Config和TIM_SetIC1Prescaler函数——>1
TIx_Config:
在这里插入图片描述

控制的是TIMx_CCER寄存器的CC1P和CC1E,选择捕获极性(选择是IC1还是IC1的反相信号作为触发或捕获信号)和捕获使能——>3
在这里插入图片描述
在这里插入图片描述
和TIMx_CCMR1寄存器的CC1S——>5
![在这里插入图片描述](https://img-blog.csdnimg.cn/4dabf8be960a47918a57f5b38ee87571.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5LiA5YmD6Kej5Y2D5oSB,size_20,color_FFFFFF,t_70,g_se,x_
和TIMx_CCMR1寄存器的IC1F——>2
在这里插入图片描述

TIM_SetIC1Prescaler:
在这里插入图片描述
控制的是TIMx_CCMR1寄存器的IC1PSC,选择输入捕获预分频——>4
在这里插入图片描述
所以

TIM_ICInit(TIM3, &TIM_ICInitStructure);
//将TIM_ICInitStructure中的指定参数初始化TIM3

相当于

TIM4->CCMR1 |= 3<<4; //	IC1F='0011' 采样频率采样频率fSAMPLING=fCK_INT,N=8 ————>2
	TIM4->CCMR1 |= 1<<0; //CC1S='01' TI1FP1映射到IC1——————>5
//	TIM4->CCMR1 |= 1<<8; //CC2S='01' TI2FP2映射到IC2——————>5
	TIM4->CCMR1 |= 1<<2; //	IC1PSC='01' 每2个事件触发一次捕获 ————>4
	TIM4->CCER &= ~(1<<1);//CC1P='0' TI1FP1不反相————>3
//	TIM4->CCER &= ~(1<<5);//CC2P='0' TI2FP2不反相————>3

在这里插入图片描述
总结:
1,4个通道的哪个通道
2,输入捕获怎样滤波
3,所谓“极性”,选择是ICx还是ICx的反相信号作为捕获信号,上升沿、下降沿
{
0:不反相:捕获发生在IC1的上升沿
1:反相:捕获发生在IC1的下降沿
}
4,每几个事件触发一次捕获,00:无预分频器,捕获输入口上检测到的每一个边沿都触发一次捕获;
5,“搭线”,选择ICx是搭在哪个TIFPx。

**极性:**有点疑惑,这个只有上升沿或者下降沿,双边沿怎么没有呢?
The CC1P bit selects TI1FP1 and TI2FP1 polarity for trigger or capture operations.
在这里插入图片描述
固件库手册也没有TIM_ICPolarity_BothEdge
在这里插入图片描述

代码里面都有
TIM_ICPolarity_Rising ((uint16_t)0x0000)——低四位是0000,即位1为0
TIM_ICPolarity_Falling ((uint16_t)0x0002)——低四位是0010,即位1为1
在这里插入图片描述TIM_ICPolarity_BothEdge ((uint16_t)0x000A)——低四位是1010
使用到了保留位,难道是我这个手册太旧了??
在这里插入图片描述

关于“搭线”——————自己取的
了解几个名词:
TIMx:定时器x,如TIM4,定时器4
TIx :如用的是定时器4,TI1和TI2对应是 TIM4->CH1 和TIM4->CH2对应的引脚,信号就是外部信号,是直接与管脚相连的信号,即通道x对应的引脚,图中还有一个问题就是TI1是可以是第一通道的外部信号进行触发,也可以设置为,第一通道,第二通道,第三通道异或进行触发。外部信号送往滤波器和边沿检测器。
TIxFPx :经过滤波器和带极性选择的边缘检测器过后的产生的信号,叫触发有效信号,与管脚直连的信号可以被设置为高、低边沿触发
至于TI1FP1和TI2FP2信号在上身沿计数还是下降沿计数受两点影响:
1,极性(是否反向)
2,边缘检测(上升沿还是下降沿)
ICx:映射信号
IC1 IC2 IC3 IC4:通道有效信号,在他的前面是TIxFP和TRC信号,可以看出,TI1FP与TI2FP可以互相对应IC1和IC2,TI3FP和TI4FP可以互相对应IC3和IC4,这样的话,就可以使一个TIxFP信号对应两个ICx也就是对应两个通道。猜想就像是,可以通过两个通道去检测一个引脚上的信号,实现PWM输入时,可以由1个来计算周期,另一个来计算占空比。ICx信号被送入预分频器,
如2个通道去检测1个引脚上的信号:
在这里插入图片描述
如1个通道去检测1个引脚上的信号.同时时刻只能选择1个:
在这里插入图片描述
在这里插入图片描述
把上图中第一个矩形框放大看就是下面这个图,其他通道也一样:

TIxF : 通道x输入的信号经过滤波后的信号
在这里插入图片描述

IC1、TI1概念理解:TI1是定时器输入通道,IC1是输入捕获通道,两者可以交错。配置CCMR1寄存器的CC1S位可以指定IC1的映射方式。IC1是与TI1连接还是和T2连接还是TRC,
在这里插入图片描述
按照颜色对应:
在这里插入图片描述
TIMx_CCMR1包含,CC2S和CC1S
在这里插入图片描述
在这里插入图片描述
TIMx_CCMR2包含,CC4S和CC3S
在这里插入图片描述
CC1S=’01’ (TIMx_CCMR1寄存器,TI1FP1映射到IC1)
CC2S=’01’ (TIMx_CCMR2寄存器,TI2FP2映射到IC2)
参考:关于STM32数据手册中的定时器信号

  • 17
    点赞
  • 67
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
以下是关于STM32定时器级联的介绍: STM32定时器级联是指将多个定时器连接在一起,形成一个更长的计数器。这种级联方式可以扩展计数器的位数,从而扩展计时范围。在STM32定时器级联可以通过将两个通用定时器TIM)连接在一起来实现。 具体实现步骤如下: 1. 配置第一个定时器TIM1)和第二个定时器TIM2)的基本参数,包括时钟源、预分频器、计数模式等。 2. 配置第一个定时器TIM1)的输出比较模式,使其输出一个特定的PWM波形。 3. 配置第二个定时器TIM2)的输入捕获模式,使其可以捕获第一个定时器TIM1)的PWM波形。 4. 将第二个定时器TIM2)的时钟源设置为第一个定时器TIM1)的输出,这样第二个定时器TIM2)就可以根据第一个定时器TIM1)的PWM波形进行计数。 5. 在程序读取第一个定时器TIM1)和第二个定时器TIM2)的计数值,将它们相加即可得到一个更长的计数器。 下面是一个示例代码,演示了如何将两个定时器级联在一起: ```c #include "stm32f4xx.h" void TIM_Config(void); int main(void) { TIM_Config(); while (1) { uint32_t count1 = TIM_GetCounter(TIM1); uint32_t count2 = TIM_GetCounter(TIM2); uint32_t total_count = (count1 << 16) | count2; // 将两个计数器的值相加,得到一个更长的计数器 } } void TIM_Config(void) { RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1 | RCC_APB2Periph_TIM2, ENABLE); TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; TIM_OCInitTypeDef TIM_OCInitStructure; TIM_ICInitTypeDef TIM_ICInitStructure; // 配置TIM1 TIM_TimeBaseStructure.TIM_Period = 999; // PWM周期为1000个时钟周期 TIM_TimeBaseStructure.TIM_Prescaler = 83; // 时钟预分频器为84 TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; TIM_TimeBaseInit(TIM1, &TIM_TimeBaseStructure); TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; TIM_OCInitStructure.TIM_Pulse = 499; // 占空比为50% TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High; TIM_OC1Init(TIM1, &TIM_OCInitStructure); TIM_Cmd(TIM1, ENABLE); // 配置TIM2 TIM_TimeBaseStructure.TIM_Period = 0xFFFF; // 计数器最大值为65535 TIM_TimeBaseStructure.TIM_Prescaler = 0; TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure); TIM_ICInitStructure.TIM_Channel = TIM_Channel_1; TIM_ICInitStructure.TIM_ICPolarity = TIM_ICPolarity_Rising; TIM_ICInitStructure.TIM_ICSelection = TIM_ICSelection_DirectTI; TIM_ICInitStructure.TIM_ICPrescaler = TIM_ICPSC_DIV1; TIM_ICInitStructure.TIM_ICFilter = 0x0; TIM_ICInit(TIM2, &TIM_ICInitStructure); TIM_SelectInputTrigger(TIM2, TIM_TS_TI1FP1); TIM_SelectSlaveMode(TIM2, TIM_SlaveMode_Reset); TIM_Cmd(TIM2, ENABLE); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值