AVR定时器的用法要点介绍

发布者:声慢慢最新更新时间:2012-08-11 来源: 21ic 关键字:AVR  定时器  工作模式 手机看文章 扫描二维码
随时随地手机看文章

M16的T1 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)

快速参考见 Table 47. 波形产生模式的位描述

 

 

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 的输入捕捉单元可用来捕获外部事件,并为其赋予时间标记以说明此时间的发生时刻。[page]

外部事件发生的触发信号由引脚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分钟

关键字:AVR  定时器  工作模式 引用地址:AVR定时器的用法要点介绍

上一篇:基于AVR单片机的语音识别系统设计
下一篇:基于AVR的新型防汽车追尾安全装置设计

推荐阅读最新更新时间:2024-03-16 13:05

mini2440硬件篇之PWM定时器
1. 硬件原理 2440有5个16位定时器,其中0、1、2、3有PWM功能,有一根输出引脚,可以产生周期性高低电平变化。定时器4没有输出引脚。 2. 芯片手册 3. mini2440电路图 4. S3C2440寄存器 定时器时钟源是PCLK,先通过2个预分频器TCFG0 TCFG1降低频率,降频后就确定了定时器工作频率。初始设定值TCMPBn(用于比较反转输出电平)、TCNTBn。TCON控制定时器启动。TCMPBn的值装入TCMPn,TCNTBn的值装入TCNTn,每个定时器周期,TCNTn减1,可以通过TCNTOn读取计数值。当和TCMPn相等时,反转电平输出。减到0时,再次反转,如果TCON设置自动加载,则重复如上步骤。
[单片机]
mini2440硬件篇之PWM<font color='red'>定时器</font>
基于STM32定时器的PWM音乐播放功能的实现
基于32位的STM32F103,利用 PWM 产生的音频信号驱动蜂鸣器演奏乐曲,实现了音乐播放器的应用设计。该播放器能实现从低音到高音的21个音阶,并能根据乐谱演奏完整的曲目。测试结果表明,PWM的输出信号与各音阶对应的声音频率基本一致,方案切实可行。这一方法也可用于电机控制、电子琴设计等方面,具有较好的实用性。 在科研项目开发中,有时会遇到需要播放电话铃声、音乐等情况。简单的做法是购买专用音乐芯片,但该方法的缺点是播放的内容不可变,不能很好地满足项目需求。一般地,可采用89C51等单片机实现音乐播放,其播放内容及歌曲数量都可以随时修改,使用上相对方便。随着STM32系列微处理器的出现,其基于ARM Cortex—M内核的
[单片机]
基于STM32<font color='red'>定时器</font>的PWM音乐播放功能的实现
为什么选择AVR单片机
为什么选用AVR单片机? (1) 为什么选用AVR单片机? Flash程序存储器可擦写1000次以上,不再有报废品产生。PIC 有的是OTP,只能烧录一次。AVR程序存储器数据为16位组织,也可按8位理解。PIC是12/14位程序 存储器,作寄存器转移和算术、逻辑运算带来不便。 (2) 为什么选用AVR单片机? 高速度(50ns)、低功耗!硬件应用Harward结构,具有预取指令功能, 使得指令可以在一个时钟周期内执行。PIC要4个时钟周期执行一条指令。MSC-51要12个时钟周期 执行一条指令。 (3) 为什么选用AVR单片机? 超功能精简指令!具有32个通用工作寄存器(相当于8051中的32个累 加器,克服了单一累加
[单片机]
STM32定时器介绍
STM32定时器介绍 本文将介绍STM32定时器的一些基本概念性的东西,方便后面内容的理解学习。 接下来将从以下几个方面介绍:STM32定时器介绍 ①STM32定时器介绍 STM32F4共有14个定时器,按照定时器所具备的功能多少可分为3类:基本定时器、通用定时器、高级定时器; 高级定时器具有通用、基本定时器的所有功能; 从图中可以看出: 定时器的计数最大值为2^16-1; 计数类型有:向上计数模式、向下计数模式、中央对齐模式; 定时器的最大分频系数可以达到65536; DMA请求生成、捕获/比较通道、最大接口时钟视具体定时器; 下面就定时器的计数类型进行具体的介绍: “向上计数模式”:计数器从0计数到自动加载值、然后产生
[单片机]
STM32<font color='red'>定时器</font>介绍
一起学mini2440裸机开发(五)--定时器0的基础实验
实验前的准备 既然是关于定时器的实验,肯定要用到系统时钟,所以一定要保证系统时钟设置好,在这里需要的PCLK为50MHz。第二节分析MDK自带的S3C2440.c可以知道,默认的是不初始化系统时钟(是否选择初始化可以通过修改S3C2440.s中的CLOCK_SETUP来选择)。那么在这里首先修改一下S3C2440.s,对时钟进行初始化。 在这里只需要设置一处即可将 CLOCK_SETUP EQU 0修改为CLOCK_SETUP EQU 1,这样系统在启动时就会对咱们的芯片进行初始化,初始化之后的系统时钟值为:FCLK=300MHz,HCLK=100MHz,PCLK=50MHz。 实验1 实验实现的功
[单片机]
一起学mini2440裸机开发(五)--<font color='red'>定时器</font>0的基础实验
基于AVR和TMS320VC5402的HPI接口通信设计
1.前 言 TMS320VC5402(简称VC5402)是TI公司的DSP处理器,具有高级的数据处理结构和丰富的片内资源。但是VC5402 DSP内部不具有可编程的非易失片内存储器,所以为了保存程序代码和参数表,一般情况下要外扩一片存储器。VC5402可用的通用输入输出口(I/O port)少,软件上对I/O口的控制不灵活,没有对I/O口按位控制的指令,且具有流水线延迟。多不具有通用的通信接口如UART接口,CAN总线接口等,对控制的支持功能较少。AVR(Advanced RISC Architecture)单片机是ATMEL公司的flash型单片机,广泛应用于数据处理和控制领域,具有丰富的片内资源和灵活的接口形式。片内往
[单片机]
基于<font color='red'>AVR</font>和TMS320VC5402的HPI接口通信设计
AVR模数转换程序
1. 开发语言 本范例使用 WinAVR/GCC 20050214 版本开发 2. 范例描述 本程序简单的示范了如何使用ATmega16的ADC模数转换器 普通的单端输入 差分输入及校准基准电压的校准 查询方式 中断方式 数据格式的变换 出于简化程序考虑,各种数据没有对外输出,学习时建议使用JTAG ICE硬件仿真器 3. 电路图设计 : 为简化线路设计,使用了本网站的ATmega16功能小板。 在范例中 选用内部2.56V电压基准作Vref ,差分通道 10倍放大 则 单端电压测量范围 02.56V, 分辨率2.5mV 差分电压测量范围 +/- 256mV 分辨率0.5mV 电流分辨率
[单片机]
<font color='red'>AVR</font>模数转换程序
AVR单片机TWI总线的原理及应用
摘要 在简要对比TWI总线与I2C总线的基础上,详细介绍TWI总线的内部模块、工作时序和工作模式,并给出一个编程实例加以说明.对TWI总线和传统的I2C总线的正确区分及使用具有现实的指导意义。 关键词 两线串行总线TWI I2C AVR系列的单片机内部集成了TWI(Two-wire SerialInterface)总线。该总线具有I2C总线的特点,即接线简单,外部硬件只需两个上拉电阻,使用时钟线SCL和数据线SDA就可以将128个不同的设备互连到一起;而且支持主机和从机操作,器件可以工作于发送器模式或接收器模式,数据传输率高达400 kHz。正因为TWI总线具有这么多的优点,因此受到了使用者的青睐。 由于该总线
[单片机]
<font color='red'>AVR</font>单片机TWI总线的原理及应用
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
  • 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余年来致力于单片机与嵌入式系统推广工作。

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