新闻中心

EEPW首页 > 嵌入式系统 > 设计应用 > 基于MCS-51单片机的测控系统的软时钟设计的优化

基于MCS-51单片机的测控系统的软时钟设计的优化

作者:时间:2013-02-17来源:网络收藏

  随着微电脑的广泛应用,以单片机为核心的微机已随处可见。为满足用户要求,这些系统通常都具有数码显示时钟的功能。由于内部包含2个定时计数器,将其中一个定时计数器用于设计的方法,可以大大节省硬件开销。本文提出了如何提高的定时精度,以及在存在的情况下,如何提高以单片机为核心的的设计质量的方法。

  一、 MCS-51单片机内部定时计数器的概述

  MCS-51单片机内部包含2个定时计数器T0和T1,它们都是16位的加法计数器,既可用于定时,也可用于计数,在用于定时的情况下,计数脉冲由内部提供,因此计数速率固定为CPU振荡频率的1/12;在用于计数的情况下,计数脉冲来自外部,外部计数脉冲通过MCS-51的引脚T0(第14脚)或T1(第15脚)输入,在发生从1到0的跳变时计数加1。每个定时计数器又有4种工作方式可供选择:方式O构成13位定时计数器,高3位未用;方式1构成16位定时计数器;方式2构成8位定时计数器,低位字节用于计数,高位字节存放初值;方式3只适合于T0,构成两个独立的8位定时计数器。在方式O、方式1及方式3时,初值不能自动装入,当定时时间已到或计数次数已满时,若要进行下一次定时计数,必须利用软件装入初值,否则,系统会按上限自动定时或计数,即以O初值进行定时或计数;而在方式2时,初值可自动装入,只需向高位字节写入一次初值,则当低位字节定时时间到(或计数满)时,高位字节的初值会自动装入低位字节,且高位字节的值保持不变。当系统需用MCS-51单片机的串行接口进行串行通信时,定时计数器T1被固定为波特率发生器,因此,在软时钟设计中,总是选择T0作为定时器。

  二、软时钟程序设计方法1—0.1 s计数法

  0.1 s计数法的基本原理如下:

通过设置定时计数器0每经过0.1 s请求一次中断,中断处理程序会令软时钟的基准0.1 s单元增加1,而该单元每增加10次,再令软时钟的秒单元增加1,以此类推,按照时间进位令分、时、日、月直至年单元增加1。设CPU所接晶体振荡器的振荡频率为6 MHz,则1个机器周期为2μs,当T0作为定时器工作时,定时器溢出,即中断周期:T=2×TC×10-6 s,式中TC为时间常数。令中断周期T=O.1 s,可得:TC=0.1/(2×10-6)=50 000=0C350H,此时间常数决定了T0必须为16位定时器,故设置为工作方式1。由于是加法计数器,初值IC应为时间常数TC的补码,所以IC=216-TC=10000H-0C350H=3CBOH,修正以后,取IC=3CB4H,有关程序段具体设计如下。

  初始化程序:


  由上述程序可知,作为16位定时器使用时,T0不能自动装入初值,每次进入中断服务程序后,首先必须用程序装入初值,下一次定时实际上是从装入初值低位字节后开始的,所以在设定T0中断为高优先级以及CPU对T0中断请求的响应无等待延时的理想情况下,1个中断周期所包含的实际时间t=初值到计数满所需时间+入口引导时间+装入初值低位字节时间。


上一页 1 2 下一页

评论


相关推荐

技术专区

关闭