2018-03-07 AVR timer的 内部结构

from

http://www.avrbeginners.net/architecture/timers/timers.html

https://arduino-info.wikispaces.com/Timers-Arduino 

http://web.engr.oregonstate.edu/~traylor/ece473/lectures/tcnt1-3.pdf


atmege328,是一个8位机,AVR( 1997年,由ATMEL公司挪威设计中心的A先生和V先生,利用ATMEL公司的 内置Flash 存储技术,共同研发出RISC高速 8位 单片机



定时器时钟

----可以等于系统时钟(从晶振或任何时钟选项使用),

----也可以先由预分频器减慢。当使用预分频器时,您可以获得更大的计时器值,预分频器可以设置为1,8,64,256或1024。

当使用16位(0xFFFF )定时器时,预分频器设置为1024,一个8 MHz的AVR为8.38秒,

直接使用系统时钟相当于分频器设置为1,预分频器也可以设置为8,64,256或1024。

如果直接使用系统时钟(8M时钟)最小的时间分辨率是0.125μs,16位定时器最多可以计时长度是0.008192秒。可以记忆为 --千分之8秒。

由于预分频器每1024个时钟周期递增一次定时器,分辨率也为1024个时钟周期:1024个时钟周期= 0.000128秒, 一个8 MHz的AVR的 16位定时器 加上1024 预分频器  ,可以计数(0xFFFF + 1)* 1024个时钟周期= 67108864个时钟周期,即8.388608秒。可以记忆为-- 8秒。

也可以使用外部引脚作为定时器时钟或通过预分频器停止定时器。



当使用16位(0xFFFF )定时器时

8位定时器的计时器硬件图:  

1、定时器时钟(来自系统时钟,预分频系统时钟或外部引脚T0)对T / C寄存器(TCNT0)进行递增计数。

2、当它翻转(0xFF - > 0x00)时,定时器/计数器1 溢出中断标志置位。

如果TIMSK(定时器中断屏蔽寄存器)中的相应位置位(在这种情况下该位被命名为“TOIE0”)并且全局中断使能,则微指令将跳转到相应的中断向量(在2313中这是向量编号7 )。





定时器/计数器--寄存器概述

[ TCNT1 ]  计数寄存器。

[ TCCR1A / TCCR1B ] 。包括:

----定时器模式,是否以及如何将比较输出引脚连接到Timer1。

----PWM  分频,在寄存器的8位、9位到10位,

----输入噪声过滤器(用计数的方法),也是分频??

----输入捕捉边沿选择

----比较匹配时,是否要清零定时器/计数器1

----预分频器  


[ OCR1 ] output  compair register

----输出比较寄存器 用于在比较后生成中断。它与TCNT1比较,当两者匹配时,触发比较匹配中断。

 [ ICR1 ] input  compair register

----输入捕捉寄存器可用于捕捉外部 ICP引脚上 的脉冲边沿。An input capture register (ICRx) is available for capturing the counter value at the occurrence of external (edge) events such as an external pin change or comparator state change.

 [ TIMSK和TIFR ]

----定时器中断屏蔽寄存器(TIMSK)和定时器中断标志(TIFR)寄存器用于通过置位TIMSK中的位来控制哪些中断为“有效”,并确定哪些中断正在等待(TIFR)。全局中断使能。



重要注意事项:CPU仅有8位,所以16位寄存器一次只能访问8位(八个比特,一个字节),访问定时器寄存器时使用一个16位的临时寄存器。

16位  写:当写入高字节(TCNT1H和TCNT1A有啥关系??)时,数据被放置在TEMP寄存器中。当写入低字节时,数据一起传输到TCNT寄存器。必须首先写入高字节才能写入16位。

16位  读:读取低字节时,首先读取低字节以获得真正的16位读取。



定时器模式

[普通模式]     

在这种模式下,定时器数值一直增加。

它向上计数,从0xFFFF翻转到0x0000时,TCNT1向上计数并触发T / C1溢出中断。小心!定时器的16位计数器仅能 计数1-64K。

[ 输出比较模式 ]    

在这种模式下,定时器数值一直增加。

与OCR1A中的值进行比较。当这些值彼此相等时,输出比较中断标志(TIFR中的OCF)置1,可以调用ISR。

 [ 输入捕捉模式 ]    

在这种模式下,定时器数值一直增加。

可用于测量ICP引脚(Input Capture pin)的次数。一些外部电路产生可用于这种方式的脉冲。可以用它测量电机的转速。您可以将其设置为测量引脚上升沿或下降沿的次数。

 [ PWM模式 ]      

在这种模式下,定时器先++增加,到达顶峰时--减小

16位定时器的脉宽调制器(PWM)模式。PWM可设置为8,9或10位的分辨率。


某些外部硬件可能需要一个低电平有效的PWM信号,因此可以选择反相和不反相PWM。有硬件反转PWM信号的选项可节省代码空间和处理时间。


PWM在达到TOP值时,才自动写入OCR1的新值,因此防止产生非指定的脉冲宽度。 

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352

推荐阅读更多精彩内容