单片机编写延时函数的简单方法

单片机编写延时函数的简单方法

ID:5916154

大小:133.00 KB

页数:4页

时间:2017-12-28

单片机编写延时函数的简单方法_第1页
单片机编写延时函数的简单方法_第2页
单片机编写延时函数的简单方法_第3页
单片机编写延时函数的简单方法_第4页
资源描述:

《单片机编写延时函数的简单方法》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、编写延时函数的简单方法  PostBy:2010-6-210:26:01  在本站51hei-5板子上做315兆无线解码和红外解码试验的时候,延时函数的精度很重要,要做到相当精确才可以成功,所以大家一定要掌握.  这也是大家最常在QQ里问我的一个问题,如果从keil里看了c语言的反汇编代码然后根据晶振和指令计算延时的时间这样虽然非常的准确但是相当的麻烦而且容易搞错,我这里介绍一个最简单的方法.可以验证你的延时函数    这里用一个例程详细介绍一下。   过程参考如下:   在编译器下建立一个新项目,也可以利用

2、已有项目。此过程中需要注意,单片机晶振的选择,因为for循环里指令的执行时间和晶振有直接关系,本例中晶振使用11.0592M。此主题相关图片如下:20090oc1.jpg    编写一段关于延时的函数,主要利用for循环,代码如下:voiddelay_ms(unsignedintms){unsignedinti;unsignedcharj;   for(i=0;i

3、输入参数,如果输入1,就是要求程序延时1ms。j变量是调整程序运行的时间参数。调整j的数值,使1次循环的时间在1ms。   将此程序编译通过,然后利用软件仿真,调整时间。 此主题相关图片如下:20090oc2.jpg下面这个sec就是程序运行到现在的这一行所用的时间。此主题相关图片如下:20090oc3.jpg  两次时间差就是延时函数使用的时间,如果与1ms相差比较多,用户可以调整j参数的值,使延时时间尽量接近1ms。如增大j的值for(j=0;j<105;j++);   此方法得出延时函数,在晶振不同的情

4、况下,延时时间会不准。软件调试结果,这个程序的延时时间为:1.01779ms,一般的单片机系统中都可以应用。 下面来说说汇编的传统计算方法: 指令周期、机器周期与时钟周期      指令周期:CPU执行一条指令所需要的时间称为指令周期,它是以机器周期为单位的,指令不同,所需的机器周期也不同。      时钟周期:也称为振荡周期,一个时钟周期=晶振的倒数。      MCS-51单片机的一个机器周期=6个状态周期=12个时钟周期。      MCS-单片机的指令有单字节、双字节和三字节的,它们的指令周期不尽相同

5、,一个单周期指令包含一个机器周期,即12个时钟周期,所以一条单周期指令被执行所占时间为12*(1/12000000)=1us。了解了上面这些我们来看一个例子;============延时1秒子程序========================DELAY_1S:      MOVR4,#10;延时子程序,12M晶振延时1.002035秒L3:MOVR2,#200 ;1指令周期L1:MOVR3,#249 ;1指令周期L2:DJNZR3,L2    ;2指令周期DJNZR2,L1         ;2指令周期DJ

6、NZR4,L3         ;2指令周期RET                     ;2指令周期;循环体延时时间:[(249*2+1+2)*200+1+2]*10*12/12000000=1.002030s;加上ACALL指令和第一条mov指令以及最后一条RET指令算出来整个函数的时间为1.002035s;===================================================通常选用的是11.0592MHZ的晶振:[(249*2+1+2)*200+1+2]*10*12/

7、11059200=1.08727213541666666...S汇编延时子程序的延时计算问题对于程序DELAY: MOVR0,#00HDELAY1:MOVR1,#0B3HDJNZR1,$DJNZR0,DELAY1 查指令表可知MOV一个机器周期,DJNZ指令需用两个机器周期,而一个机器周期时间长度为12/11.0592MHz,所以该段程序执行时间为:((0B3×2+1+2)×256+1)×12÷11059200=100.2789mS 第一层:DJNZR1,$:执行了B3H次,一次两个周期,所以为0B3×2; 

8、第二层:MOVR1,#0B3H为一个周期,DJNZR0,DELAY1为两个周期,这样循环一次就是0B3×2+1+2个周期;第二层的执行次数本来是255次,但因为赋首值为0,而DJNZ是先减1,再比较的,所以就应该是256次。 这样的话,整个循环执行完应该是(0B3×2+1+2)×256+1次。再加上开始赋值这一句,就是((0B3×2+1+2)×256+1)了  还说明一下:nop指令或者_nop_(

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。