课程设计报告(2013—2014年度第一学期)名称:微机原理及应用题目:8255/273实现六位简单计算器院系:控计学院班级:创新自动化1101学号:1111190324学生姓名:杨扬同组人:谢伟戈,庄登祥,苏晴指导教师:杨国田设计周数:1周成绩:日期:2014年1月3日一、课程设计的目的与要求目的:在微机原理及应用课程中分别学过了微机原理各个基本组成模块的原理和编程技术的基础上,综合应用各部分知识,在实验室现有设备的情况下,设计一个具有一定功能的应用系统,达到对各部分知识加深理解、融会贯通的目的,并进一步锻炼学生的动手能力和综合分析能力,同时培养学生的团队精神。要求每个同学独立完成自己分担的部分,整体方案可以组内同学讨论确定。要求:能完成六位十进制数的加、减、乘、除运算以及平方运算,操作过程与普通计算器相同,即先输入一个操作数,然后按下“+”“—”“×”“÷”键,再输入下一个操作数,按等号键开始运算并显示结果,若结果超过六位,则显示“E”。要求尽量与真实计算器相似。任务:我负责的是软件整体构建,和对加法,减法,乘法,除法,平方,清零以及带小数运算程序的编写和调试。二、设计正文将可编程外围接口芯片8255A与键盘和七段LED连接,通过对8255A编程及对键盘的操作实现计算功能。键盘码包括数字0~9、运算符号“+”“-”“*”“/”“=”和清零“CL”键。首先利用程序不断扫描件键盘是否有输入,如果没有就一直扫描,如果有就停止扫描,完成输入。通过键盘依次输入第一个运算数字、运算符号、第二个运算数字、“=”,在七段LED灯上显示运算结果,期间数字输入有误可按“C”键之后重新输入。三、课程设计总结1.本次课程设计选择了简易计算器设计的题目,不仅使我加深了对接口程序设计的认识,对可编程并行I/O接口芯片8255的工作原理也有了进一步的了解,更重要的是培养了我们发现问题,解决问题的能力。2.根据微机原理课程所学相关知识及实验教程相关内容,在基于proteus平台,使用汇编语言,以8086为核心的情况下,配合可编程并行接口器件8255A,LED数码管等器件实现可进行简单六位数加减乘除法及清零扩展功能的十进制计算器。在课程设计实践中,我们不仅锻炼了实际动手能力,培养了团队精神和严肃认真的工作态度,更增强了自己在实际的工程设计中查阅资料,撰写设计报告表达设计思想和结果的能力。3.在编程过程中,需要很多细节的注意和推敲。本来很简单的想法,到了实际的编程过程中,就发现并不是那么简单。如减法的每次循环过程中的借位,时时刻刻都得注意,稍不留神就可能出错。编程不仅使我们对微机有了更深的理解,也教会了我们不要眼高手低,得脚踏实地,帮我们养成了严谨的思想。还有,本次课设中有各种新的知识不在课本中,就需要我们去查阅资料,上网搜索之类。在这个过程中,不仅仅是反映在这几页报告中的知识,更多的也有如protues的作图,仿真过程中的各类问题的解决方法;以及键盘的各类知识。有些东西,我们天天接触,但要是让我们亲自做一下的时候,可能就会暴露出我们更多的问题。很感谢能有这样的机会去用已有的知识做一些我们力所能及的事。四、参考文献[1]《清华大学TPC-2003A实验指导书》,2006版[2]李继灿,《新编16/32位微型计算机原理及应用》,清华大学出版社,第四版,2008年[3]杨国田,高明明《微机原理实验指导书》校内待出版,第一版,2002年3月附录1.软件设计流程图2.硬件设计概要:加号?减号?乘号?除号?等号?清零?设加标志设减标志设乘标志设除标志进行加减乘除运算,保存结果清零显示屏是否溢出?出》?结果为E放键?有标志?清零显示屏,清标志保存数据显示扫描开始8255初始化有无按键?显示扫描是数字键?N[键入文档的引述或关注点的摘要。您可将文本框放置在文档中的任何位置。可使用“Y[键入文档的引述或关N[键入文档的引述或关注N[键入文档的引述或关注点的摘要N[键入文档的引述或关注点的摘要。您可将N[键入文档的引述或关注点的摘要。您可将文本框放N[键入文档的引述或关注点的摘要。您可将文本框放置在文档Y[键入文档的引述或关注点的摘要。您可将文本框放置在文Y[键入文档的引述或关注点的摘要。您可将文本框放置在文档中的任Y[键入文档的引述或关注点的摘要。您可将文本框放置在文Y[键入文档的引述或关注点的摘要。您可将文本框Y[键入文档的引述或关注点的摘要。您可Y[键入文档的引述或关注点的摘Y[键入文档的引述或关注点的摘要。您可Y[键入文档的引述或关注点的摘要。您可将文本框放置在文档中的任何位置。Y[键入文档的引述或关注点的摘要。您可将文本框放置在文档中的任何N[键入文档的引述或关注点的摘要。您可将文本框放置在文档中的任何N[键入文档的引述或关注点的摘要。您可将文本框放置在文档中N[键入文档的引述或关注点的摘要N[键入Y[键入小数点?设标志2.1.LED显示的功能及实现七段LED显示器由七个发光段构成,每段均是一个LED二极管。这七个发光段分别称为a,b,c,d,e,f,g,通过控制不同段的点亮和熄灭,以显示所要得到的数字。七段LED的输出功能也是通过8255的并行输出实现。LED显示数字编码表0C0H,0F9H,0A4H,0B0H,99H,92H,82H,0F8H,80H,90H,0FFH,0FFH,0FFH,0FFH,0FFH,86H,0BFH显示的字符HGFEDCBA编码011000000C0H111111001F9H210100100A4H310110000B0H41001100199H51001001092H61000001082H711111000F8H81000000080H91001000090H-10111111BFH2.2、8255工作原理2.2.1.8255引脚功能说明:D0~D7:数据线,三态双向数8位缓冲器,8255与CPU数据传送的通道,当CPU执行输入输出指令时,通过它实现8位数据的读/写操作,控制字和状态信息也通过数据总线传送。A0~A1:地址线,用于选择端口,即用其来选择A口、B口、C口或寄存器控制口。RD(低电平有效):读信号线,当这个输入引脚为低电平时,允许8255通过数据总线向CPU发送数据或状态信息,即CPU从8255读取信息或数据。WR(低电平有效):写入信号,当这个输入引脚为低电平时,允许CPU将数据或控制字写8255。CS(低电平有效):片选信号线,当这个输入引脚为低电平时,表示芯片被选中,允许8255与CPU进行通讯。RESET(高电平有效):复位输入线,当该输入端外于高电平时,所有内部寄存器(包括控制寄存器)均被清除,所有I/O口均被置成输入方式。PA0~PA7:端口A输入输出线,8位数据输入锁存器和8位数据输出锁存器/缓冲器。PB0~PB7:端口B输入输出线,8位数据输入缓冲器和8位数据输出锁存器/缓冲器PC0~PC7:端口C输入输出线,端口B输入输出线,8位数据输入缓冲器和8位数据输出锁存器/缓冲器实际使用时,可以把A口、B口、C口分成两个控制组,即A组和B组。A组控制电路由端口A和端口C的高4位(PC4~PC7)组成,B组控制电路由端口B和端口才的低4位(PC0~PC3)组成。2.2.2.8255的读写控制:8255的读/写控制逻辑电路接受CPU发来的控制口号RD、WR、RESET和地址信号A1~A0。然后根据命令端口,控制信号的要求,将端口的数据读出选信CPU或者将CPU送来的数据写入端口,各端口的工作状态。通过用输出指令对8255A的控制字寄存器编程,写入设定工作方式的控制字,可以让3个数据口以不同的方式工作,端口A可工作于3种方式的任一种,端口B只能工作于方式0和方式1,端口C除了用于输入输出端口外,还能配合A口和B口工作,为这两个端口的输入输出操作提供联系信号。2.2.3.数据总线缓冲器它是一个双向三态的8位数据缓冲器,8255A正是通过它与系统数据总线相连,用于输入/输出数据以及传送由CPU发给8255A的控制字2.2.4.定义工作方式控制字工作方式0:8255A中各端口的基本输入/输出方式。2.3微处理器8086芯片当引脚接高电平时,CPU工作于最小方式(单处理器系统方式,适合于较小规模的应用)。此时,引脚功能如下:(1)AD15~AD0:分时复用的存储器或端口的地址和数据总线。传送地址时为单向的三态输出,而传送数据时为双向三态输入/输出。(2)IO/M存储器/输入、输出控制信号(输出、三态):它用于区分CPU当前是访问存储器还是访问输入/输出端口。高电表示访问存储器,说明当前要进行CPU与存储器之间的数据传送。低电平表示访问输入/输出设备。表示当前要进行CPU与I/O端口之间的数据传送。在DMA时,它被置为浮空。(3)WR/LOCK(输出,低电平有效,三态):信号有效,即为低电平时,表示CPU正在执行存储器或I/O写操作,在写周期中,WR在T2、T2、Tw期间都有效。在DMA时,WR被置为浮空。(4)INTA:可屏蔽中断响应信号,输出,低电平有效。CPU通过信号对外设提出的可屏蔽中断请求做出响应。为低电平时,表示CPU已经响应外设的中断请求,即将执行中断服务程序。(5)ALE:地址锁存允许信号,输出,高电平有效。CPU利用ALE信号可以把AD15~AD0地址/数据、A19/S6~A16/S3地址/状态线上的地址信息锁存在地址锁存器中。(5)DT:数据发送/接收信号,输出,三态。DT/信号用来控制数据传送的方向。DT/为高电平时,CPU发送数据到存储器或I/O端口;DT/为低电平时,CPU接收来自存储器或I/O端口的数据。(6)DEN:数据允许控制信号,输出,三态,低电平有效。信号用作总线收发器的选通控制信号。当为低电平时,表明CPU进行数据的读/写操作。(7)HOLD:总线保持请求信号,输入,高电平有效。在DMA数据传送方式中,由总线控制器8237A发出一个高电平有效的总线请求信号,通过HOLD引脚输入到CPU,请求CPU让出总线控制权。(8)HLDA:总线保持响应信号,输出,高电平有效。HLDA是与HOLD配合使用的联络信号。在HLDA有效期间,HLDA引脚输出一个高电平有效的响应信号,同时总线将处于浮空状态,CPU让出对总线的控制权,将其交付给申请使用总线的8237A控制器使用,总线使用完后,会使HOLD信号变为低电平,CPU又重新获得对总线的控制权。(9)RD:读控制信号,三态,输出。当RD=0时,表示CPU执行存储器或I/O端口的读操作。是对内存单元还是对I/O端口读取数据,取决于M/IO信号。在执行DMA操作时,RD被浮空。(10)READY:“准备好”信号线,输入。该引脚接受被寻址的内存或I/O端口发给CPU的响应信号,高电平时表示内存或I/O端口已准备就绪,CPU可以进行数据传输。CPU在T3状态开始对READY信号采样。若检测到READY为低电平,表示内存或I/O端口尚未准备就绪,则CPU在T3状态之后自动插入等待状态Tw,直到READY信号变为高电平,内存或I/O端口已准备就绪,CPU才可以进行数据传输。2.4、74LS273锁存器D0~D7:出入;Q0~Q7:输出;第一脚WR:主清除端,低电平触发,即当为低电平时,芯片被清除,输出全为0(低电平);CP(CLK):触发端,上升沿触发,即当CP从低到高电平时,D0~D7的数据通过芯片,为0时将数据锁存,D0~D7的数据不变。3.键盘输入输出模块:键盘是常用信息输入元件,由一个个按钮组成。下图是一个4*4键盘结构图,将4*4键盘的八个管脚接8255的PC口,因为进行键盘扫描一般要求有一部分的I/O口工作方式是输入,另一部分I/O是输出,具体到4*4键盘则要求四个I/O口输入,另外四个输出。行信息连C口低四位,列信息连A口低四位。当进行扫描时,扫描信号由列引脚输入键盘。以0111、1011、1101和1110的顺序每次扫描不同的列,然后读取列引脚的信号就可以判断是哪个键被按下。识别键盘上哪个键被压下的过程的扫描步骤:1.检测是否所有键