



全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
.AVRGCC 延时库函数的理解WinAVR20081205 延时函数 :void _delay_loop_1(uint8_t _count) _asm_ volatile ( 1: dec %0 nt brne 1b : =r (_count) : 0 (_count) ); 准确延时是 3*_count 个时钟周期 (0_count256) void _delay_loop_2(uint16_t _count) _asm_ volatile ( 1: sbiw %0,1 nt brne 1b : =w (_count) : 0 (_count) ); 准确延时是 4*_count+1 个时钟周期 (0_count256*256-1) _delay_loop_1() 最小延时是 3 个时钟周期,最大延时是 256*3 个时钟周期 _delay_loop_2() 最小延时是 4+1 个时钟周期,最大延时是 256*256*4+1 个时钟周期 void _delay_us(double _us) uint8_t _ticks; .double _tmp = (F_CPU) / 3e6) * _us; if (_tmp 1.0) _ticks = 1; else if (_tmp 255) _delay_ms(_us / 1000.0); return; else _ticks = (uint8_t)_tmp; _delay_loop_1(_ticks); void _delay_ms(double _ms) uint16_t _ticks; double _tmp = (F_CPU) / 4e3) * _ms; if (_tmp 1.0) _ticks = 1; else if (_tmp 65535) / _ticks = requested delay in 1/10 ms _ticks = (uint16_t) (_ms * 10.0); while(_ticks) / wait 1/10 ms _delay_loop_2(F_CPU) / 4e3) / 10); _ticks -; return; else _ticks = (uint16_t)_tmp; _delay_loop_2(_ticks); _dealy_us()最小延时 与 _delay_loop_1()相同,是 3 个时钟周期, _delay_us(0)就是最小延时,相当于_delay_loop_1(1), 在 8M 时钟下, _delay_us(0.375)也是最小延时(0.375us 是 3 个时钟周期) _delay_us(0.7499999)仍然是最小延时,相当于_delay_loop_1(1), 而_delay_us(0.74999999)则相当于_delay_loop_1(2)了。 ._dealy_ms() 最小延时与 _delay_loop_2()相同,是 4+1 个时钟周期。 _delay_ms(0)就是最小延时,相当于_delay_loop_2(1), 在 8M 时钟下, _delay_ms(0.0005)也是最小延时(0.0005ms 相当于是 4 个时钟周期) _delay_ms(0.0009999999)仍然是最小延时,相当于_delay_loop_2(1), 而_delay_ms(0.00099999999)则相当于_delay_loop_2(2) 了。 _dealy_us(_us)延时精度范围: (0 , 3 个时钟周期),误差(0,3)个时钟周期 (3 个时钟周期 , 768us/(F_CPU/1000000),误差(-2,0)个时钟周期 (768us/(F_CPU/1000000) , 262.14ms/(F_CPU/1000000),误差(-2,+1)个时钟周期, (262.14ms/(F_CPU/1000000) , 6553.5ms),误差 8M 时钟下(约+0.18ms ,约+57ms) _dealy_ms(_ms)延时精度范围: (0 , 4 个时钟周期),误差(1,5)个时钟周期 (4 个时钟周期 , 262.14ms/(F_CPU/1000000),误差(-2,+1)个时钟周期, (262.14ms/(F_CPU/1000000) , 6553.5ms),误差 8M 时钟下(约+0.18ms ,约+57ms) _dealy_us(_us)最大延时 6553.5ms,即_delay_us(6553500); _delay_ms(_ms)最大延时 6553.5ms,即_delay_ms(6553.5); 本人水平有限,如果错漏之处,多谢指正。 补充:1.WinAVR 延时库函数看起来,又是 double,又是 if、else,难道不耗时间? 不耗时间。WinAVR 延时库函数,double 都可以优化成常量,而整型常量,浮点常量运算,结果仍然仍然是常量。 编译器只要开优化,不会编译出额外的代码出来。if,else 也一样。if 判断条件是一个常量,也就是说某个分支一定为真, 另外的分支一定为假,编译器优化时,不会编译出额外代码。需要注意,如果要调用 WinAVR 延时库函数,则必须要开优化。 2.怎么没有计算函数调用,返回时间? WinAVR 延时库函数全部都是内联函数,没有函数调用和返回开销。当然,这也.有一个副作用,每处延时函数都会编译出一段代码, 占据更多的代码空间。 3.旧版 WinAVR _delay_us()最大延时 768us/(F_CPU/1000000),delay_ms()最大延时是 262.14ms/(F_CPU/1000000)。新版 WinAVR_delay_us()和_delay_ms() 最大延时都是 6553.5ms,不过误差也相对较大,每 0.1ms 多 7 个时钟周期,8M 时钟下,误差约为+0.88%。-附 IARAVR 延时函数: #ifndef _IAR_DELAY_H_ #define _IAR_DELAY_H_ #include intrinsics.h #include hal_type.h #define _delay_loop_1(A) _delay_cycles(3*(A) #define _delay_loop_2(A) _delay_cycles(4*(A)+1) #define _delay_us(A) _delay_cycles( (uint32) ( (double)(F_CPU) *(A)/1000000.0) + 0.5) #define _delay_ms(A)
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 航天科技行业科研成果统计表
- 2025-2030中医药保健食品行业发展动态与政策导向及商业机会分析报告
- 行业报告快速编写与报告生成模板
- 2025年福建省福州市辅警考试题库(附答案)
- 2025年防雷电安全试题及答案
- 2025年法务考试笔试题目及答案
- 2025年学历类自考学前儿童科学教育-学前特殊儿童教育参考题库含答案解析(5套试卷)
- 2025年学历类自考学前儿童科学教育-外国文学史参考题库含答案解析(5套试卷)
- 2025年中国传统体外人工受精行业市场全景分析及前景机遇研判报告 - 网
- 2025年学历类自考学前儿童发展-网络经济与企业管理参考题库含答案解析(5套试卷)
- 铁路团体车票协议书
- 大众内部购车协议书
- 2025新人教版英语八上单词默写单(先鸟版)
- 语言分析面试题及答案
- 养老护理移乘技能课件
- 授权委托押车协议书
- 物业服务接待课件
- 2025年度专业技术人员继续教育公需科目考试题(附答案)
- 广东2025年03月珠海市市直机关事业单位公开招考合同制职员笔试历年参考题库考点剖析附解题思路及答案详解
- 供应商有效管理方案
- 铝合金门窗安装与质量控制
评论
0/150
提交评论