AT89C51八位数字频率计程序设计与实现

需积分: 12 2 下载量 101 浏览量 更新于2024-09-19 收藏 38KB DOC 举报
"这篇资源是关于使用AT89C51单片机设计一个八位数字频率计的汇编语言源程序。程序涉及到定时器、中断处理、计数器以及BCD码转换等功能,用于测量并显示输入信号的频率。" 在微控制器应用中,AT89C51是一款广泛应用的8位单片机,它具有四个8位I/O端口、两个16位定时/计数器、以及可编程的片上振荡器和时钟电路。在这个项目中,AT89C51被用来构建一个八位数字频率计,能够显示输入信号的频率。 程序的核心部分涉及到了定时器T1作为定时器,T0作为计数器。定时器的工作模式通过设置TMOD寄存器来设定,例如,设置TMOD = #25H,这通常意味着T1工作在模式2(16位定时器),T0工作在模式1(8位自动重装载定时器)。 中断是实时系统中的关键机制,这里使用了定时器T1的中断(入口地址为001BH)。在中断服务子程序中,对计数器的值进行处理,计算出频率。中断服务程序首先保存了堆栈中的累加器A和状态寄存器PSW,然后进行计数,当达到1秒的定时时标后,关闭计数闸门,停止计数,并将T0的计数值存储到内存的特定地址(21H和22H),随后调用二进制转BCD码程序,以便将计算结果转化为可以显示的形式。 二进制转BCD码是将二进制数转换为适合七段数码管显示的BCD(二进十进制)码的过程。在这个程序中,这个过程可能由名为COUNT的子程序实现,它将二进制的频率值转换为BCD码,然后通过动态扫描的方式驱动数码管显示。动态扫描技术可以减少所需的I/O端口,通过快速切换不同数码管的显示,使得所有数码管看似同时亮起。 此外,程序还设置了P3.0和P3.1引脚,分别用于控制LS393清零和计数闸门,这些是频率计硬件中的重要组成部分。P0、P2和P3端口用于连接数码管的段选和位选,以实现数码管的显示。 整个程序通过循环执行,不断读取计数值,计算频率,并更新数码管的显示。在程序的主循环(MAIN)中,初始化了定时器、计数器、中断标志和SP(堆栈指针)等寄存器,为后续的频率测量做好准备。 总结起来,这个项目展示了如何利用AT89C51单片机的定时器和中断功能,结合汇编语言编程,实现一个基本的八位数字频率计。它涉及了硬件接口、中断处理、计数原理以及二进制到BCD码的转换,是学习单片机控制和数字电子技术的典型实例。