- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
STM32高级定时器使用方法及注意事项
By 深圳市威睿晶科 Felix
主要特性:
高级定时器与通用定时器的主要差别如下红色区域
● 16位向上、向下、向上/下自动装载计数器
● 16位可编程(可以实时修改)预分频器,计数器时钟频率的分频系数为1~65535之间的任意数值
● 多达4个独立通道:
─ 输入捕获
─ 输出比较
─ PWM生成(边缘或中间对齐模式)
─ 单脉冲模式输出
● 死区时间可编程的互补输出
● 使用外部信号控制定时器和定时器互联的同步电路
● 允许在指定数目的计数器周期之后更新定时器寄存器的重复计数器
● 刹车输入信号可以将定时器输出信号置于复位状态或者一个已知状态
● 如下事件发生时产生中断/DMA: ─ 更新:计数器向上溢出/向下溢出,计数器初始化(通过软件或者内部/外部触发) ─ 触发事件(计数器启动、停止、初始化或者由内部/外部触发计数) ─ 输入捕获 ─ 输出比较 ─ 刹车信号输入
● 支持针对定位的增量(正交)编码器和霍尔传感器电路
● 触发输入作为外部时钟或者按周期的电流管理
如上所示,对于一般地应用是体现不出来它高端的地方了。
使用心得:
由于V3.5库函数将定时器资源全部融合在一块了,所以显得stm32f10x_tim.c库特别庞大,找功能函数很是麻烦,还容易搞混乱。面对这种情况寄存器操作就显得很方便了,所以以下程序我是直接参考寄存器说明来逐步配置的,阅读起来不太方便,但写起来方便,而且不会重复混乱,更容易理解到定时器的工作过程。
1 首先是作为定时器的通用功能:定时
定时功能的实现,是通过设置定时时钟为内部时钟源来实现,如手册上介绍:
“如果禁止了从模式控制器(SMS=000),则CEN、DIR(TIMx_CR1寄存器)和UG位(TIMx_EGR寄存器)是事实上的控制位,并且只能被软件修改(UG位仍被自动清除)。只要CEN位被写成’1’,预分频器的时钟就由内部时钟CK_INT提供。”
配置步骤如下:
void TIM1Timing(void){
RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1|RCC_APB2Periph_GPIOA,ENABLE);
//打开TIM1时钟
TIM1-CR1 =0x380 ;//456bit=0,向上计数
TIM1-SMCR=0xfff8;//sms=000,禁止从模式控制器
TIM1-PSC=7199;//设置预分频,公式fCK_PSC/( PSC[15:0]+1)= 0.1Mhz,100us/+1
TIM1-ARR=10000;//设置自动重装载值为 10000,即溢出一次时间为1S
TIM1-RCR=0;//重复计数寄存器为0,这个是设置事件(中断)频率的,为0即溢出1次中断标志置位
TIM1-EGR|=1;重新初始化计数器,即清空计数器(要是向上计数则清0,要是向下计数则填装自动装载值)
TIM1-SR=0x0000;//清中断标志
TIM1-DIER|=1;//开启更新中断,即出现一次溢出事件中断一次
TIM1-CR1|=0X001;//打开定时器1}
这样就实现了最基本的定时功能,可以在中断函数里实现1S的定时处理
2,输入捕获功能:InputCapture
这个功能可以很方便的计算出输入信号的频率,兼具外部计数以及内部定时的功能
手册上的实现步骤:是以配置TIM1的通道1-TI1为例的
● 选择有效输入端:TIMx_CCR1必须连接到TI1输入,所以写入TIMx_CCR1寄存器中的CC1S=01,只要CC1S不为’00’,通道被配置为输入,并且TIMx_CCR1寄存器变为只读。
● 根据输入信号的特点,配置输入滤波器为所需的带宽(即输入为TIx时,输入滤波器控制位是TIMx_CCMRx寄存器中的ICxF位)。假设输入信号在最多5个内部时钟周期的时间内抖动,我们须配置滤波器的带宽长于5个时钟周期;因此我们可以(以fDTS频率)连续采样8次,以确认在TI1上一次真实的边沿变换,即在TIMx_CCMR1寄存器中写入IC1F=0011。 无需滤波的话写入0即可
● 选择TI1通道的有效转换边沿,在TIMx_CCER寄存器中写入CC1P=0(上升沿)。
● 配置输入预分频器。在本例中,我们希望捕获发生在每一个有效的电平转换时刻,因此预分频器被禁止(写TIMx_CCMR1寄存器的IC1PS=00)。
● 设置TIMx_CCER寄存器的CC1E=1,允许捕获计数器的值到捕获寄存器中。
● 如果需要,通过设置TIMx_DIER寄存器中的CC1IE位允许相关中断请求,通过设置TIMx_DIER寄存器中的CC1DE位允许DMA请求。 当发生一个输入捕获时:
● 产生有效的电平转换时,计数器的
您可能关注的文档
最近下载
- 精品解析:北京市和平街第一中学2024-2025学年八年级上学期期中语文试题(原卷版).docx VIP
- 建筑垃圾处理及清运方案.docx VIP
- (2024)高中历史新课程标准考试模拟测试题及答案.pdf VIP
- 辽宁省名校联盟2025年高三1月份联合考试 语文试卷(含答案详解).pdf
- 矿山安全生产标准化讲义.ppt VIP
- 辽宁省名校联盟2025年高三3月份联合考试 语文试卷(含答案解析).docx
- 18如何帮助学生学会恰当的消费.docx VIP
- 个人生涯发展报告.ppt VIP
- 2024-2025学年高一上学期期中考试动员主题班会(共24张ppt).pptx
- 2025年中国邮政集团工作人员招聘考试笔试试题(含答案).docx VIP
原创力文档


文档评论(0)