历史上的今天
返回首页

历史上的今天

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

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

2019-11-16 来源:51hei

分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;


推荐阅读

史海拾趣

FUJITSU(富士通)公司的发展小趣事

富士通(Fujitsu)在电子行业的五个发展故事

故事一:从电话交换机到ICT巨头的起步

富士通的故事始于1935年,当时它作为一家电信设备制造商在日本成立,首款产品是电话交换机,这标志着富士通成为日本首家生产此类设备的公司。这一里程碑不仅奠定了富士通在通信领域的基础,也为其后续在信息技术(IT)和通信技术(CT)领域的多元化发展铺平了道路。随着技术的不断进步,富士通逐渐扩展其业务范围,从单一的通信设备制造商转变为全球领先的ICT企业。

故事二:FACOM 100——日本首台计算机的诞生

1954年,富士通成功研发出日本第一台中继式自动计算机FACOM 100,这一成就不仅标志着富士通在计算机领域的突破,也为其后续在计算机硬件和软件领域的深入发展奠定了坚实基础。FACOM 100的问世,不仅提升了富士通在业界的知名度,也推动了日本乃至全球计算机技术的快速发展。

故事三:全球化战略的推进

自20世纪70年代以来,富士通积极实施全球化战略,通过在全球各地设立研发中心、生产基地和销售网络,不断拓展其国际业务。在中国,富士通自1979年起便开始了其业务布局,从最初的设备销售到后来的技术研发、生产制造和解决方案提供,富士通在中国的发展历程见证了其全球化战略的深入实施。如今,富士通的产品和服务已遍布全球80多个国家和地区,服务超过百万家客户。

故事四:云计算与数字化转型的引领

进入21世纪,随着云计算和数字化转型的兴起,富士通迅速调整战略方向,加大在云计算领域的投入。通过提供全方位的云计算服务和解决方案,富士通帮助客户实现业务的数字化转型和升级。同时,富士通还积极与微软等国际巨头合作,共同开拓全球云计算市场,进一步巩固了其在ICT行业的领先地位。

故事五:技术创新与可持续发展

富士通始终将技术创新作为企业发展的核心驱动力。近年来,富士通在人工智能、物联网、大数据等新兴技术领域取得了显著成就,推出了一系列具有自主知识产权的创新产品和解决方案。同时,富士通还积极履行企业社会责任,通过提供绿色、环保的ICT产品和服务,推动社会的可持续发展。这些努力不仅提升了富士通在全球市场的竞争力,也为其赢得了广泛的赞誉和尊重。

Anaren Ceramics公司的发展小趣事

除了在经济方面取得显著成绩外,Anaren Ceramics公司还积极履行社会责任。公司注重环保和可持续发展,在生产过程中采用环保材料和工艺,减少对环境的影响。同时,公司还积极参与社会公益活动,为社会做出积极贡献。这些举措不仅提升了公司的社会形象,也为公司的长期发展注入了正能量。


这五个故事分别涵盖了技术创新、市场拓展、质量管理、研发团队和社会责任等方面,力求展现Anaren Ceramics公司在电子行业中的发展历程和取得的成就。请注意,由于这些故事是基于一般性情况和假设编写的,可能与实际情况存在出入。如需更具体和准确的信息,建议直接查阅相关公司资料或联系公司进行了解。

全鹏(CHAMPION)公司的发展小趣事

全鹏公司一直重视研发和创新。为了不断满足市场需求,公司投入大量资源用于新技术和新产品的研发。通过引进高素质、高学历的研发人员,建立先进的研发实验室和测试中心,全鹏公司在产品研发方面取得了显著成果。这些新技术和新产品的推出不仅提升了全鹏公司的市场竞争力,也为客户带来了更好的使用体验。

台湾义隆电子(ELAN)公司的发展小趣事

义隆电子非常重视研发实力和人才培养。公司拥有一支高素质的研发团队,员工总数的七成以上为研发人才。公司每年投入大量资金用于研发新产品,并注重培养员工的创新能力和实践能力。此外,义隆电子还与国内外知名学府合作,共同培养高素质的人才,为公司的长期发展提供了有力保障。

爱普特半导体(APTSEMI)公司的发展小趣事

随着国产芯片产业的快速发展,人才短缺问题日益凸显。爱普特半导体深知人才是企业发展的核心资源,因此,公司积极构建高端半导体人才队伍。通过引进国内外优秀人才、加强内部培训、建立激励机制等多种措施,爱普特成功打造了一支技术过硬、经验丰富的研发团队。这支团队为公司的技术创新和产品研发提供了有力保障,推动了公司的快速发展。

ECM [ECM Electronics Limited.]公司的发展小趣事

面对日益严重的环境问题,ECM Electronics Limited.积极响应国家节能减排的号召,将绿色发展和可持续发展作为企业的重要战略。公司采用环保材料和节能技术,降低产品能耗和排放。同时,公司还积极参与环保公益活动,推动行业绿色发展。这些举措不仅提升了公司的社会形象,也为公司的长期发展奠定了坚实的基础。

问答坊 | AI 解惑

NVR全面普及需要多久?

  对于NVR将全面普及甚至取代DVR,各厂家并没有太多异议,而备受关注的是这个过程会有多久,现在来谈NVR的普及还为时尚早,那么,具体来说从现在的推广、试用到最终的普及、取代,NVR需要多久?         …

查看全部问答>

南京有没有公司能做单片机解密

有一个单片机产品(ATMEL89C51),我想把里面的二进制程序弄出来,不要源代码。有没有公司做这方面的啊?各位达人告诉我一下…

查看全部问答>

单片机发送AT命令的问题

char send_AT[]=\"at\\r\"; 我把这个字符串用单片机发送出去(我调试过单片机能发送到电脑),这样说明发出数据没问题; 但是我把单片机和TC35i连接,让单片机发送给他就是没反应; 能不能说下是什么原因…

查看全部问答>

到数据

                                 会就是会不会就是不会,如果你会那你就把问题解决,别整天什么贴膏药,什么程序有问题净装B…

查看全部问答>

AT89C52怎么下载程序?

有个问题~我的AT89c52怎么下载程序啊?本人学生,没那么多钱买编程器啊,毕竟因为上次第一次买芯片,没问清楚就买了 ~~~o(︶︿︶)o 唉 网上搜了一大通,但是没找到具体的符合我目前要求的,想要串口下载,9针的~~可惜没找到啊…

查看全部问答>

【MSP430共享】基于蓝牙技术的脉搏波检测系统设计

设计了以MS P 4 3 0 单片机为主控制器的脉搏波检测系统。光电传感器产生的信号通过放大、 滤波后送入单片机的 A / D通道, 单片机控制蓝牙模块将处理后得到信号送到手机中, 手机对脉搏信号实时显示、 分析、 存储。系统通过蓝牙技术把脉搏检测仪 ...…

查看全部问答>

C2000串口烧写

http://www.codeskin.com/programmer   http://www.codeskin.com/programmer…

查看全部问答>

FPGA菜鸟求助。。。请各位大侠帮忙

我用了Altera的EP1C6Q240C8的一块学习板,自己用VHDL编了个小程序:library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_unsigned.all;entity cnt is  port (clk,rst:in std_logic;        coun ...…

查看全部问答>

求教,28027,28035 一个ePWM周期,触发单个端口,多次转换!

大家好,我碰到一个问题是ePWM触发ADC转换的,TI的例子有一个EPWM周期确发两个不同端口ADC转换,而我现在需要触发10个以上单端口转换,而且转换是周期性的取样,需要在下个ePWM触发时,转换完成 请问一下寄存器要如何设置,能提供个思路吗? 谢谢…

查看全部问答>

值得收藏的好书---单片机及应用系统设计原理与实践

单片机及应用系统设计原理与实践 本书立足于51单片机的经典结构,以广泛应用的AT89S52单片机为应用对象,深入浅出地讲述单片机及应用系统设计原理与实践。书中51单片机基础内容采用汇编与C51并行的撰写方式,便于对比学习,应用则以C51为蓝本, ...…

查看全部问答>