历史上的今天

今天是:2024年11月16日(星期六)

2019年11月16日 | M16的T1 16位定时器一共有15种工作模式,其他2个8位定时器

发布者:Huayu8888 来源: 51hei关键字:M16  16位定时器  工作模式 手机看文章 扫描二维码
随时随地手机看文章

分5种工作类型 

   1   普通模式 WGM1=0 

     跟51的普通模式差不多,有TOV1溢出中断,发生于TOP时 

     1 采用内部计数时钟      用于 ICP捕捉输入场合---测量脉宽/红外解码 

         (捕捉输入功能可以工作在多种模式下,而不单单只是普通模式) 

     2 采用外部计数脉冲输入   用于 计数,测频 

     其他的应用,采用其他模式更为方便,不需要像51般费神 

     

   2 CTC模式 [比较匹配时清零定时器模式] WGM1=4,12 

      跟51的自动重载模式差不多 

      1 用于输出50%占空比的方波信号 

      2 用于产生准确的连续定时信号 

      WGM1=4时, 最大值由OCR1A设定,TOP时产生OCF1A比较匹配中断 

      WGM1=12时,最大值由ICF1设定, TOP时产生ICF1输入捕捉中断 

      注:WGM=15时,也能实现从OC1A输出方波,而且具备双缓冲功能 

      计算公式: fOCn=fclk_IO/(2*N*(1+TOP)) 

                    变量N 代表预分频因子(1、8、32,64、256,1024)。      

      

   3 快速PWM模式 WGM1=5,6,7,14,15  

     单斜波计数,用于输出高频率的PWM信号(比双斜波的高一倍频率) 

     都有TOV1溢出中断,发生于TOP时 

     比较匹配后可以产生OCF1x比较匹配中断. 

       WGM1=5时, 最大值为0x00FF, 8位分辨率 

       WGM1=6时, 最大值为0x01FF, 9位分辨率 

       WGM1=7时, 最大值为0x03FF,10位分辨率  

      WGM1=14时,最大值由ICF1设定, TOP时产生ICF1输入捕捉中断 (单缓冲) 

      WGM1=15时,最大值由OCR1A设定,TOP时产生OCF1A比较匹配中断(双缓冲,但OC1A将没有PWM能力,最多只能输出方波) 

      改变TOP值时必须保证新的TOP值不小于所有比较寄存器的数值 

     注意,即使OCR1A/B设为0x0000,也会输出一个定时器时钟周期的窄脉冲,而不是一直为低电平 

     计算公式:fPWM=fclk_IO/(N*(1+TOP))

   4 相位修正PWM模式 WGM1=1,2,3,10,11  

     双斜波计数,用于输出高精度的,相位准确的,对称的PWM信号 

     都有TOV1溢出中断,但发生在BOOTOM时 

     比较匹配后可以产生OCF1x比较匹配中断. 

       WGM1=1时, 最大值为0x00FF, 8位分辨率 

       WGM1=2时, 最大值为0x01FF, 9位分辨率 

       WGM1=3时, 最大值为0x03FF,10位分辨率  

      WGM1=10时,最大值由ICF1设定, TOP时产生ICF1输入捕捉中断 (单缓冲) 

      WGM1=11时,最大值由OCR1A设定,TOP时产生OCF1A比较匹配中断(双缓冲,但OC1A将没有PWM能力,最多只能输出方波) 

     改变TOP值时必须保证新的TOP值不小于所有比较寄存器的数值 

     可以输出0%~100%占空比的PWM信号 

     若要在T/C 运行时改变TOP 值,最好用相位与频率修正模式代替相位修正模式。若TOP保持不变,那么这两种工作模式实际没有区别 

     计算公式:fPWM=fclk_IO/(2*N*TOP)

   5 相位与频率修正PWM模式 WGM1=8,9  

     双斜波计数,用于输出高精度的、相位与频率都准确的PWM波形 

     都有TOV1溢出中断,但发生在BOOTOM时 

     比较匹配后可以产生OCF1x比较匹配中断. 

      WGM1=8时,最大值由ICF1设定, TOP时产生ICF1输入捕捉中断 (单缓冲) 

      WGM1=9时,最大值由OCR1A设定,TOP时产生OCF1A比较匹配中断(双缓冲,但OC1A将没有PWM能力,最多只能输出方波) 

     相频修正修正PWM 模式与相位修正PWM 模式的主要区别在于OCR1x 寄存器的更新时间 

     改变TOP值时必须保证新的TOP值不小于所有比较寄存器的数值 

     可以输出0%~100%占空比的PWM信号 

     使用固定TOP 值时最好使用ICR1 寄存器定义TOP。这样OCR1A 就可以用于在OC1A输出PWM 波。 

     但是,如果PWM 基频不断变化(通过改变TOP值), OCR1A的双缓冲特性使其更适合于这个应用。 

     计算公式:fPWM=fclk_IO/(2*N*TOP)

T/C 的时钟源 

    T/C 的时钟源可以有多种选择,由CS12:0控制,分别用于高速(低分频)/长时间(高分频)/外部计数场合 

    一个16位定时器,在8MHz系统时钟驱动下,可以实现uS级的高速定时和长达8秒的超长定时,这可是标准51的弱点

    CS12 CS11 CS10 说明 

        0     0     0   无时钟源      (T/C 停止) 

        0     0     1   clkIO/1     ( 无预分频)  

        0     1     0   clkIO/8     ( 来自预分频器

        0     1     1   clkIO/64    ( 来自预分频器) 

        1     0     0   clkIO/256   ( 来自预分频器)  

        1     0     1   clkIO/1024 ( 来自预分频器) 

        1     1     0   外部T1 引脚,下降沿驱动 

        1     1     1   外部T1 引脚,上升沿驱动 

   分频器复位 

         在高预分频应用时,通过复位预分频器来同步T/C 与程序运行,可以减少误差。 

    但是必须注意另一个T/C是否也在使用这一预分频器,因为预分频器复位将会影响所有与其连接的T/C。 

   

   外部时钟源 

    由于使用了引脚同步逻辑,建议外部时钟的最高频率不要大于fclk_IO/2.5。 

    外部时钟源不送入预分频器 

    选择使用外部时钟源后,即使T1引脚被定义为输出,其T1引脚上的逻辑信号电平变化仍然会驱动T/C1 计数,这个特性允许用户通过软件来控制计数。 

    

输入捕捉单元 

    T/C 的输入捕捉单元可用来捕获外部事件,并为其赋予时间标记以说明此时间的发生时刻。 

    外部事件发生的触发信号由引脚ICP1 输入,也可通过模拟比较器单元来实现。 

    时间标记可用来计算频率、占空比及信号的其它特征,以及为事件创建日志。 

    

    输入捕捉单元可以工作在多种工作模式下 

    (使用ICR1定义TOP的(WGM1=12,14,10,8)波形产生模式时,ICP1与输入捕捉功能脱开,从而输入捕捉功能被禁用。) 

    在任何输入捕捉工作模式下都不推荐在操作过程中改变TOP值 

    

    当引脚ICP1 上的逻辑电平( 事件) 发生了变化,或模拟比较器输出ACO 电平发生了变化,并且这个电平变化为边沿检测器所证实,输入捕捉即被激发: 

    16位的TCNT1 数据被拷贝到输入捕捉寄存器ICR1,同时输入捕捉标志位ICF1 置位。 

    如果此时ICIE1 = 1,输入捕捉标志将产生输入捕捉中断。 

    中断执行时ICF1 自动清零,或者也可通过软件在其对应的I/O 位置写入逻辑"1” 清零。 

    

    注意,改变触发源有可能造成一次输入捕捉。因此在改变触发源后必须对输入捕捉标志执行一次清零操作以避免出现错误的结果 

    

    除去使用ICR1定义TOP的波形产生模式外, T/C中的噪声抑制器与边沿检测器总是使能的。 

    (其实就是永远使能??) 

    使能噪声抑制器后,在边沿检测器前会加入额外的逻辑电路并引入4个系统时钟周期的延迟. 

    噪声抑制器使用的是系统时钟,因而不受预分频器的影响 

    

    使用输入捕捉中断时,中断程序应尽可能早的读取ICR1 寄存器 

    如果处理器在下一次事件出现之前没有读取ICR1 的数据, ICR1 就会被新值覆盖,从而无法得到正确的捕捉结果。 

    

    测量外部信号的占空比时要求每次捕捉后都要改变触发沿。 

    因此读取ICR1 后必须尽快改变敏感的信号边沿。改变边沿后,ICF1 必须由软件清零( 在对应的I/O 位置写"1”)。 

    若仅需测量频率,且使用了中断发生,则不需对ICF1 进行软件清零。 

    

输出比较单元 

    16位比较器持续比较TCNT1与OCR1x的内容,一旦发现它们相等,比较器立即产生一个匹配信号。 

    然后OCF1x 在下一个定时器时钟置位。 

    如果此时OCIE1x = 1, OCF1x 置位将引发输出比较中断。 

    (就是说输出比较可以工作在所有工作模式下,但PWM模式下更好用,功能更强) 

    

    输出比较单元A(OCR1A) 的一个特质是定义T/C 的TOP 值( 即计数器的分辨率)。 

    TOP 值还用来定义通过波形发生器产生的波形的周期。 

    

    由于在任意模式下写TCNT1 都将在下一个定时器时钟周期里阻止比较匹配,在使用输出比较时改变TCNT1就会有风险,不管T/C是否在运行 

    这个特性可以用来将OCR1x初始化为与TCNT1 相同的数值而不触发中断。

   强制输出比较(FOC) 

    工作于非PWM 模式时,可以通过对强制输出比较位FOC1x 写”1” 的方式来产生比较匹配。 

    强制比较匹配不会置位 OCF1x 标志,也不会重载/ 清零定时器, 

    但是OC1x 引脚将被更新,好象真的发生了比较匹配一样(COMx1:0 决定OC1x 是置位、清零,还是交替变化)。 

    

比较匹配输出单元 

    比较匹配模式控制位COM1x1:0 具有双重功能。 

    1 波形发生器利用COM1x1:0 来确定下一次比较匹配发生时的输出比较OC1x 状态; 

    2 COM1x1:0 还控制OC1x 引脚输出的来源。 

    只要COM1x1:0 不全为零,波形发生器的输出比较功能就会重载OC1x 的通用I/O 口功能。 

    但是OC1x 引脚的方向仍旧受控于数据方向寄存器 (DDR)。 

    从OC1x 引脚输出有效信号之前必须通过数据方向寄存器的DDR_OC1x 将此引脚设置为输出。 

    

    波形发生器利用COM1x1:0 的方法在普通模式、CTC 模式和PWM 模式下有所区别。 

    对于所有的模式,设置COM1x1:0=0 表明比较匹配发生时波形发生器不会操作OC1x寄存器

访问16位寄存器 

    写16 位寄存器时,应先写入该寄存器的高位字节. 

       usigned int k; 

       k=0x1234; 

       TCNT1H=(unsigned char)(k>>8); 

       TCNT1L=(unsigned char) k; 

    而读16 位寄存器时应先读取该寄存器的低位字节. 

       usigned int k; 

        k=TCNT1L; 

        k+=(unsigned int)(TCNT1H<<8); 

    使用“C” 语言时,编译器会自动处理16位操作. 

       usigned int k; 

       k=0x1234; 

       TCNT=k; 

       k=TCNT1;


关键字:M16  16位定时器  工作模式 引用地址:M16的T1 16位定时器一共有15种工作模式,其他2个8位定时器

上一篇:AVR单片机改造遥控车
下一篇:最后一页

推荐阅读

英国一家小型机器人开发了一系列用于农业的定制型灵活机器人,这种机器人能够替代现有的田间拖拉机。 农业往往被认为落后于高科技时代,对农民来说,他们的工作场所是创新技术的肥沃试验田。他们是最早使用商用的人员,也是最早使用技术的人员。配置自动驾驶系统的农业设备完全可以在农田这种封闭的区域有效且安全地进行工作。农业科技的发展是小型农业...
利用玩具遥控车的高频发射电路和高频接收电路,结合单片机进行数据传输,模拟两通道比例控制遥控器。发射端用ATTINY24从TX的8号脚控制玩具遥控器的高频发射部分接收端用ATTINY24从RX2的3号脚接收信号。然后PWM控制遥控车的两个电机,一个由电位器反馈。另一个由测速盘反馈。数据结构0 高电平100us,低电平300us1 高电平200us,低电平200us数据帧结构16位...
据台媒经济日报报道,供应链传出,苹果正紧锣密鼓开发折叠机,不仅持续累积专利,并要求台湾供应链送样测试,包括鸿海、新日兴等都是苹果首款折叠 iPhone 相当依赖的伙伴。  报道称,供应链透露,苹果为让首款折叠 iPhone 能尽快问世,目前已在测试折叠机的屏幕、轴承等关键零组件,而屏幕仍将由三星提供面板,轴承方面则有几家供应商,台厂则以新日...
  11月10日上午,国家能源集团宁夏电力灵武公司光火储耦合22兆瓦/4.5兆瓦时飞轮储能工程开工。作为国内第一个全容量飞轮储能-火电联合调频工程,也是全球单体储电量最大、单体功率最大的飞轮储能,突破了500千瓦级大功率飞轮单体的技术瓶颈,实现大功率飞轮单体工程应用。 图为项目开工现场   一直以来,该公司加快煤电机组节能升级和灵活性改造...

史海拾趣

问答坊 | AI 解惑

单片机的单CPU仿真器的设计

摘要:本文基于对8051单片机存储空间结构的深层次分析,提出了一种基于单片机的单CPU仿真器设计方案。该方案实用廉价,工程实践性强,可用于设计新的教学设备。 引言单片机以它的廉价、体积小、可塑性强、稳定性高的特性,有着广阔的市场前景。在用 ...…

查看全部问答∨

关于51单片机的I/O口及外部拉电阻

对于51单片机的I/O口及外部拉电阻,常见到一些模糊认识。稍微总结一下,或许有点用处。 ▲ P1, P2,P3口:对地有一个晶体管做的开关,对电源是内部有个集成电阻(大约几十K~200K前后),   输出时,是由内部晶体管拉到0,或由内部上拉电阻拉到 ...…

查看全部问答∨

LCD屏驱动电路

LCD屏驱动电路 附件中以第二个为准 [ 本帖最后由 呱呱 于 2008-6-30 13:17 编辑 ]…

查看全部问答∨

谁有游乐场小型红外线打靶游戏机?

本帖最后由 jameswangsynnex 于 2015-3-3 20:00 编辑 帮朋友询问:如题,新旧均可。 如有想法,请跟帖。 …

查看全部问答∨

广电总局手机电视标准CMMB标准

第一部分:广播信道帧结构,信道编码和调制…

查看全部问答∨

第四代光源—白色LED

人类历史上使用的照明光源,第一代是油灯(蜡烛),第二代是爱迪生发明的白炽灯,第三代是荧光灯,现在人们充满期待的是第四代光源—白色LED。这是利用化合物制作而成的世纪固体新光源。 自从1962年GE公司的Nick Holonyak Jr首先开发出第一个实用可 ...…

查看全部问答∨

关于ARM7 LPC2138芯片的IAP应用,碰到棘手难题,求助!

typedef struct {     uint32   Num;     uint32   Data; } DNum,*pIDNum; #define IAP_ENTER_ADR   0x7FFFFFF1  // IAP入口地址定义 #define FLASHLOCATION   0 ...…

查看全部问答∨

Wince 5.0 UDA1341音频驱动开发困惑

正在看mini2440 BSP上的基于I2S总线的单体音频驱动程序(UDA1341),看得一头雾水,各位帮帮忙,有什么好建议,能让我理一下头绪,比如大致的驱动流程啊,或者说说你们学习的经验。在此谢过啦。…

查看全部问答∨

这个WINCE的小程序可以帮我添加一个返回/退出 按钮吗?

链接http://bbs.100gps.com/attachment.php?aid=16314 可以下载看。 QQ 44901402 非常感谢…

查看全部问答∨
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
  • ARM裸机篇--按键中断
    先看看GPOI的输入实验:按键电路图:GPF1管教的功能:EINT1要使用GPF1作为EINT1的功能时,只要将GPFCON的3:2位配置成10就可以了!GPF1先配 ...
  • 网上下的--ARM入门笔记
    简单的介绍打今天起菜鸟的ARM笔记算是开张了,也算给我的这些笔记找个存的地方。为什么要发布出来?也许是大家感兴趣的,其实这些笔记之所 ...
  • 学习ARM开发(23)
    三个任务准备与运行结果下来看看创建任务和任运的栈空间怎么样的,以及运行输出。Made in china by UCSDN(caijunsheng)Lichee 1 0 0 ...
  • 学习ARM开发(22)
    关闭中断与打开中断中断是一种高效的对话机制,但有时并不想程序运行的过程中中断运行,比如正在打印东西,但程序突然中断了,又让另外一个 ...
  • 学习ARM开发(21)
    先要声明任务指针,因为后面需要使用。 任务指针 volatile TASK_TCB* volatile g_pCurrentTask = NULL;volatile TASK_TCB* vol ...
  • 学习ARM开发(20)
  • 学习ARM开发(19)
  • 学习ARM开发(14)
  • 学习ARM开发(15)
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

更多每日新闻
更多往期活动

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved