预览加载中,请您耐心等待几秒...
1/10
2/10
3/10
4/10
5/10
6/10
7/10
8/10
9/10
10/10

亲,该文档总共19页,到这已经超出免费预览范围,如果喜欢就直接下载吧~

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

PAGE\*MERGEFORMAT22020年4月19日微机原理课程设计电子时钟设计文档仅供参考,不当之处,请联系改正。级微机原理课程设计实验报告设计题目:电子时钟设计班级:电信10102班分组名单:-6-28目录第一章设计部分1.1设计目的…………………………………………………………………………11.2设计要求…………………………………………………………………………11.3设计思路…………………………………………………………………………1第二章实现部分2.1、分析论证2.1.1显示模块……………………………………………………………………12.1.2时钟运算模块………………………………………………………………12.1.3对时模块……………………………………………………………………22.2、原理说明………………………………………………………………………22.3、设计电路图……………………………………………………………………22.3.18086最小工作方式…………………………………………………………22.3.2秒脉冲发生器………………………………………………………………32.3.3时、分调整电路……………………………………………………………32.3.4.显示电路………………………………………………………………………42.4、元件功能说明2.4.1.8253的主要功能……………………………………………………………42.4.2.D触发器74ls273管脚排列图及功能表介绍………………………………52.4.3单向总线驱动器74ls244功能介绍…………………………………………52.5、程序清单…………………………………………………………………………62.6、调试过程遇到问题及解决方法…………………………………………………9第三章电子时钟使用说明3.1电子时钟按键说明第四章学习心得附录参考文献………………………………………………………………………………9第一章设计部分1.1设计目的学习掌握protues软件功能及其使用方法熟练掌握TND86/88教学系统的基本操作和调试程序的各种指令。熟练掌握8086CPU的使用与编程调试程序的方法。掌握8253定时/计数器的工作原理、工作方式及其应用编程。练习7SEG-MPX8-CA-RED数码管的显示编程方法。1.2、设计要求利用8253定时器设计一个具有时、分、秒显示的电子时钟,并定义一个启动键,当按下该键时时钟从当前设定值(可在显示缓冲区中予置)开始走时。1.3、设计思路电子时钟主要由显示模块、对时模块和时钟运算模块三大部分组成。其中对时模块和时钟运算模块要对时、分、秒的数值进行操作,而且秒计算到60时,要自己清零并向分进1;分计算到60时,要自己清零并向时进1;时计算到24时,要清零。这样,才能循环记时。显示时利用7段显示器显示六位十进制数据。前两个显示小时,中间两个显示分钟,后两个显示秒。时钟的运算是利用中断来实现的,利用8253的模式三输出一定频率的方波作为触发中断的条件。8253A可编程定时/计数器的输入时钟为100KHz,设定时/计数器0的计数初值为100,工作在方式3,即方波发生器,其输出的1KHz方波作定时/计数器2的时钟。定时/计数器2的初值设为1000,工作在方式2,即每隔1s输出负脉冲,取反后用作不可屏蔽中断的中断申请信号,在中断服务程序中计算时间,并经过74ls273并行输出到数码管显示。第二章实现部分2.1、分析论证2.1.1、显示模块利用数码管的显示功能来设计。数码管是由八个条形发光二极管组成的,这些发光二极管的阴极是互相连接在一起的,因此称为共阴极数码管。经过在这八个发光二极管的阳极加+5V或0V的电压使不同的二极管发光,形成不同的字符和数字。电子时钟用到的是0到9十个数字,她们所对应的字符表依次是3FH、06H、5BH、4FH、66H、6DH、7DH、07H、7FH、6FH。该模块显示时先将保存在数据单元的当前时间包括小时和分钟读取出来,把十六进制数字转化成十进制用四个字节分别存放小时和分钟,并把这四个数值经过74ls273端口输出给数码管显示。2.1.2、时钟运算模块该模块的主要功能是对时、分、秒的运算,并把运算出的最终结果存到事先已经开辟的内存单元里,以便显示模块即时地显示出来。该模块能够细分为秒定时模块和运算模块。秒定时模块负责提供中断信号,由于CPU运算模块中的指令消耗一定的时间,因此中断信号最好经过硬件来实现,选择的是8253定时/计数器,但又因为8253所能提供的信号的周期时毫秒级的,因此必须经过软件的方法在运算模块中设置一个统计中断次数的变量,而且这一变量必须事先在内存里开辟存储单元。中断信号是8253的计数器2工作方式为方式2时,同过设置计数器2