ATmega16定时器/计数器1的要点介绍

发布者:zhaodawei617最新更新时间:2019-11-21 来源: 51hei关键字:ATmega16  定时器  计数器1 手机看文章 扫描二维码
随时随地手机看文章

ATmega16的T/C1为16位定时器一共有15种工作模式,其他2个8位定时器(T0/T2)相对简单,除了T2有异步工作模式用于RTC应用外(可以利用溢出中断和比较匹配中断作定时功能) 

符号定义: 

BOTTOM 计数器计到0x0000 时即达到BOTTOM 

MAX     计数器计到0xFFFF ( 十进制的65535) 时即达到MAX 

TOP     计数器计到计数序列的最大值时即达到TOP。 

        TOP 值可以为固定值0x00FF、0x01FF或 0x03FF,或是存储于寄存器 OCR1A或ICR1里的数值,具体有赖于工作模式 

------注意MAX和TOP是不同的,在表格[波形产生模式的位描述]可以看到它们的作用 


   分5种工作类型 

   1   普通模式 WGM1=0 

     跟51的普通模式差不多,有TOV1溢出中断标志,发生于MAX(0xFFFF)时 

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

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

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

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

      

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

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

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

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

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

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

            ------如果TOP=MAX,TOP时也会产生TOV1溢出中断标志 

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

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

                    变量N 代表预分频因子(1、8、64、256、1024),T2多了(32、128)两级。       

       

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

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

     都有TOV1溢出中断,发生于TOP时[不是MAX,跟普通模式,CTC模式不一样] 

     比较匹配后可以产生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; 

       TCNT1=k; 

       k=TCNT1; 



这里举例 如何用16位定时器T1实现高精度1秒连续定时,精准度跟所用晶振一样 

T1 CTC模式,8MHz外部晶振,定时1秒的话,选256分频,刚好整步距,非常准确TOP=1000000/(0.125*256)-1=31249=0x7A11。 


作连续定时,必用CTC/PWM模式作,没有累积误差,稳定度跟时钟是一样,手动重装受中断影响是很难达到的。 

不过定时步距和最长定时间取决于时钟,分频系数和模式。 

对于非整步距的定时时间要求,就会存在小于一个步距的偏差。 

例如 T1,CTC模式,8MHz 

fOCn=fclk_IO/(2*N*(1+TOP)) 

定时时间 T= 0.125uS*N*(1+TOP) 

分频系数      定时步距     最长定时时间 

    1(无分频)    0.125uS       8192us      8毫秒 

    8                1uS      65536us     65毫秒 

   64                8uS        524ms    0.5秒 

256               32uS       2097ms      3秒 

1024              128uS       8388ms    超8秒了 

定时1秒的话,选256分频,刚好整步距,非常准确,TOP=1000000/(0.125*256)-1=31249=0x7A11。 

-----------当然了,时钟必须是高精度的晶振之类,不要用内部RC振荡器来瞎搞。 


由于精度取决于晶振的精度,配合软件做RTC实时时钟是完全可行的。 

用+/-20PPM的晶振,跑一个月误差1分钟 [60*60*24*30=2592000秒*20ppm=52秒]。 


作RTC用专门为32.768KHz时钟优化的T2定时器更合适,这里只是举例T1的实现方法 

如果用+/-2.5PPM的DS32KHz(MAXIM的业界最准确的32.768KHz单片稳补时钟芯片TXCO)做时钟源,超准确 

指标: -40~+85度全温度范围,年误差<4分钟,0~40度温度范围内+/-1PPM,年误差<1分钟


关键字:ATmega16  定时器  计数器1 引用地址:ATmega16定时器/计数器1的要点介绍

上一篇:AVR单片机定时器、PWM、ICP范例
下一篇:M128 PWM程序

推荐阅读最新更新时间:2024-11-11 16:01

STM32定时器 输入捕获实现双边沿检测
STM32的定时器有输入捕获功能,在STM32F10x_tim.h中对于TIM_Input_Capture_Polarity有如下定义 #define TIM_ICPolarity_Rising ((uint16_t)0x0000) #define TIM_ICPolarity_Falling ((uint16_t)0x0002) #define TIM_ICPolarity_BothEdge ((uint16_t)0x000A) #define IS_TIM_IC_POLARITY(POLARITY) (((POLARITY) == TIM_ICPolarity_Rising) ||
[单片机]
第5章 定时器/计数器
定时/计数器的功能 MCS-51单片机内共有两个可编程的定时/计数器T0和T1。它们都是十六位加法计数器结构,分别由TH0、TL0和TH1、TL1四个8位计数器组成,每个定时/计数器都具有定时和计数两种功能。 计数功能 对外来脉冲进行计数。计数脉冲的输入端来自单片机的两个信号引脚T0(P3.4)和T1(P3.5)外部输入的脉冲在负跳变时有效,计数脉冲的频率最高为振荡频率的1/24。 定时功能 定时功能也是通过计数器的计数来实现的,不过这时的计数脉冲来自单片机的内部,即每个机器周期产生一个计数脉冲。因此,计数频率为振荡频率的1/12。这样,不但可以根据计数器的预置值计算出定时时间,也可以反过来按定时时间的要求,计算出计数器的
[单片机]
ATmega16 nokia7110 LCD 屏幕实验
屏幕控制器用得是SED1565系列 LCD pin pin1 Temp sensor 47k (at 25C) pin2 _CS pin3 Speaker_p pin4 D/_C pin5 SCLK (max. 3.2MHz at Vlogic=+2.8V) pin6 Speaker_n pin7 On/Off pin8 Led - pin9 Led + pin10 Gnd pin11 Gnd pin12 Vlogic (+ 2.8V) pin13 SDATA pin14 _RESET ################################## pin 2 : Chip Select (CS) pin 4 : Co
[单片机]
<font color='red'>ATmega16</font> nokia7110 LCD 屏幕实验
基于ATmega16单片机 程控滤波器程序源代码
#include avr/io.h #include avr/signal.h #include avr/interrupt.h #include util/delay.h #define uint unsigned int #define uchar unsigned char static uchar interrupt ,count; static uchar b; uint a; SIGNAL(SIG_OVERFLOW1)/*溢出中断*/ { TCNT1H=0X7F; TCNT1L=0XFC; interrupt++; if(interrupt==a) { interrupt=0;
[单片机]
ATMega16单片机外部中断程序分享
//Crystal:7.3728MHz,功能:学习外部中断0的程序 #include #include #defineLED_COMPORTA^=(1《voidport_init(void) { PORTA=0x40; DDRA=0x40; PORTB=0x00; DDRB=0x00; PORTC=0x00;//m103outputonly DDRC=0x00; PORTD=0x04; DDRD=0x00; } #pragmainterrupt_handlerint0_isr:2 voidint0_isr(void) { LED_COM; } //callthisroutinetoiniTIalizeallperiphera
[单片机]
<font color='red'>ATMega16</font>单片机外部中断程序分享
STM32速成笔记(6)—定时器
一、什么是定时器 关于什么是定时器,简单来讲,就是是用来定时的。STM32F103ZET6有两个基本定时器TIM6和TIM7,四个通用定时器TIM2~TIM5和两个高级定时器TIM1,TIM8。每一个定时器都是完全独立的,不共享任何资源。 根据中文参考手册介绍,基本定时器最为简单,类似于51单片机的定时器。通用定时器在基本定时器的基础上增加了输入捕获和输出比较功能。高级定时器相比通用定时器,又增加了可编程死区互补输出,重复计数器等功能。 STM32F103ZET6的通用定时器是一个通过可编程预分频器驱动的16位自动装载计数器构成。使用定时器预分频器和RCC时钟控制器预分频器,脉冲长度和波形周期可以在几个微秒到几个毫秒间调
[单片机]
STM32速成笔记(6)—<font color='red'>定时器</font>
Exynos4412裸机开发 —— 看门狗定时器
一、看门狗定时器概述 看门狗(WatchDog Timer) 定时器和PWM的定时功能目的不一样。它的特点是,需要不同的接收信号(一些外置看门狗芯片)或重新设置计数器,保持计数值不为0。一旦一些时间接收不到信号,或计数值为0,看门狗将发出复位信号复位系统或产生中断。 看门狗的作用是微处理器收到干扰进入错误状态后,使系统在一定时间间隔内复位。因此看门狗是保证系统长期、可靠和稳定运行的有效措施。目前大部分的嵌入式芯片内部都集成了看门狗定时器来提高系统运行的可靠性。 4412处理器的看门狗是当系统被故障干扰时,用于处理器的复位操作,也可以作为一个通用的16位定时器来请求中断操作。看门狗定时器产生128个PCLK周期的复位信号。主
[单片机]
Exynos4412裸机开发 —— 看门狗<font color='red'>定时器</font>
[单片机框架][APP_KEY] 利用软定时器实现按键扫描
使用例子: 任意地点初始化:app_key_init(); void demo(void) { bsp_led_toggle(LED0); } // 按键触发事件则会跳转到对应功能函数。 这里演示单击,执行demo函数。 button_fun_callback_t button_fun_callback = { {BUTTON0, BUTTIN_SINGLE_CLICK, demo} }; 文件代码如下 app_key.c /******************************************************************************** * @file app_
[单片机]
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

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

换一换 更多 相关热搜器件

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

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