当前位置:首页 > 单片机 > 单片机
[导读] 输入捕获模式可以用来测量脉冲宽度或者测量频率。STM32的定时器,除了TIM6和TIM7,其他定时器都有输入捕获功能。STM32的输入捕获,简单的说就是通过检测TIMx_CHx上的边沿信号,在边沿信号发生跳变(比如上升沿/下降

输入捕获模式可以用来测量脉冲宽度或者测量频率。STM32的定时器,除了TIM6和TIM7,其他定时器都有输入捕获功能。STM32的输入捕获,简单的说就是通过检测TIMx_CHx上的边沿信号,在边沿信号发生跳变(比如上升沿/下降沿)的时候,将当前定时器的值(TIMx_CNT)存放到对应的通道的捕获/比较寄存(TIMx_CCRx)里面,完成一次捕获。同时还可以配置捕获时是否触发中断/DMA 等.


例如:我们用到TIM5_CH1来捕获高电平脉宽,也就是要先设置输入捕获为上升沿检测,记录发生上升沿的时候TIM5_CNT的值。然后配置捕获信号为下降沿捕获,当下降沿到来时,发生捕获,并记录此时的TIM5_CNT值。这样,前后两次TIM5_CNT之差,就是高电平的脉宽,同时TIM5的计数频率我们是知道的,从而可以计算出高电平脉宽的准确时间。


首先TIMx_ARR和TIMx_PSC,这两个寄存器用来设自动重装载值和TIMx的时钟分频。


再来看看捕获/比较模式寄存器1:TIMx_CCMR1,这个寄存器在输入捕获的时候,非常有用;TIMx_CCMR1明显是针对2个通道的配置,低八位[7:0]用于捕获/比较通道1的控制,而高八位[15:8]则用于捕获/比较通道2的控制,因为TIMx还有CCMR2这个寄存器,所以可以知道CCMR2是用来控制通道3和通道4(详见《STM32参考手册》290页,14.4.8节)。


这里用到TIM5的捕获/比较通道1,我们重点介绍TIMx_CMMR1的[7:0]位(其实高8位配置类似)。


再来看看捕获/比较使能寄存器:TIMx_CCER;


接下来我们再看看DMA/中断使能寄存器:TIMx_DIER,我们需要用到中断来处理捕获数据,所以必须开启通道1的捕获比较中断,即CC1IE设置为1。


控制寄存器:TIMx_CR1,我们只用到了它的最低位,也就是用来使能定时器的;


最后再来看看捕获/比较寄存器1:TIMx_CCR1,该寄存器用来存储捕获发生时,TIMx_CNT的值,我们从TIMx_CCR1就可以读出通道1捕获发生时刻的TIMx_CNT值,通过两次捕获(一次上升沿捕获,一次下降沿捕获)的差值,就可以计算出高电平脉冲的宽度。


使能捕获和更新中断(设置TIM5的DIER寄存器)

因为我们要捕获的是高电平信号的脉宽,所以,第一次捕获是上升沿,第二次捕获时下降沿,必须在捕获上升沿之后,设置捕获边沿为下降沿,同时,如果脉宽比较长,那么定时器就会溢出,对溢出必须做处理,否则结果就不准了。这两件事,我们都在中断里面做,所以必须开启捕获中断和更新中断。


1 void init_tim2_cam(u16 psc, u16 arr, u8 way, u8 dir)

2 {

3 RCC->APB1ENR |= 1 << 0; //使能定时器2时钟

4 RCC->APB2ENR |= 1 << 2; //使能PortA

5

6 switch (way)

7 {

8 case 1:

9 GPIOA->CRL &= 0xfffffff0;

10 GPIOA->CRL |= 0x00000008;

11 break;

12 case 2:

13 GPIOA->CRL &= 0xffffff00;

14 GPIOA->CRL |= 0x00000088;

15 break;

16 case 3:

17 GPIOA->CRL &= 0xfffff000;

18 GPIOA->CRL |= 0x00000888;

19 break;

20 case 4:

21 GPIOA->CRL &= 0xffff0000;

22 GPIOA->CRL |= 0x00008888;

23 break;

24 }

25

26 TIMER->PSC = psc;

27 TIMER->ARR = arr;

28

29 switch (way)

30 {

31 case 4:

32 TIMER->CCMR2 |= 1 << 8;

33 if (dir == 0)

34 TIMER->CCER |= 1 << 13; //下降沿捕获

35 else

36 TIMER->CCER &= ~(1 << 13); //上升沿捕获

37 TIMER->CCER |= 1 << 12;

38 TIMER->DIER |= 1 << 4;

39 case 3: //CCR3 PA2

40 TIMER->CCMR2 |= 1 << 0;

41 if (dir == 0)

42 TIMER->CCER |= 1 << 9; //下降沿捕获

43 else

44 TIMER->CCER &= ~(1 << 9); //上升沿捕获

45 TIMER->CCER |= 1 << 8;

46 TIMER->DIER |= 1 << 3;

47 case 2: //CCR2 PA1

48 TIMER->CCMR1 |= 1 << 8; //CCR2配置通道方向:输入

49 if (dir == 0)

50 TIMER->CCER |= 1 << 5; //下降沿捕获

51 else

52 TIMER->CCER &= ~(1 << 5); //上升沿捕获

53 TIMER->CCER |= 1 << 4; //CCR2通道捕获使能

54 TIMER->DIER |= 1 << 2; //CCR2通道允许捕获中断

55 case 1: //>CCR1 PA0

56 TIMER->CCMR1 |= 1 << 0; //CCR1配置通道方向:输入

57 if (dir == 0)

58 TIMER->CCER |= 1 << 1; //下降沿捕获

59 else

60 TIMER->CCER &= ~(1 << 1); //上升沿捕获

61 TIMER->CCER |= 1 << 0; //CCR1捕获使能

62 TIMER->DIER |= 1 << 1; //CCR1通道允许捕获中断

63 break;

64 }

65 TIMER->DIER |= 1 << 0; //允许更新中断

66 MY_NVIC_Init(1, 2, TIM2_IRQChannel, 2); //中断

67 TIMER->CR1 = 0x01; //使能定时器

68 TIMER->SR &= ~(1 << 0);

69 }



本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭