电梯控制系统设计.doc_第1页
电梯控制系统设计.doc_第2页
电梯控制系统设计.doc_第3页
电梯控制系统设计.doc_第4页
电梯控制系统设计.doc_第5页
已阅读5页,还剩29页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

长春职业技术学院电气自动化专业毕业论文第一章绪论1.1课题的主要研究内容及设计步骤本课题的主要任务是完成一个电梯系统的调度模块,即根据每个楼层不同顾客的按键需求,让电梯做出合理的判断,正确高效地知道电梯完成各项载客任务。根据此任务,本课题需要研究的内容有:1、根据系统的技术要求,进行系统硬件的总体方案设计;2、学习单片机的相关知识,并且加以运用;3、选择恰当的芯片,并对其内部协议有所掌握,便于应用。4、研究C语言编程,并且规定电梯的工作规则,用C语言加以实现;5、对软件和硬件进行调试,让其协调工作,完成指定任务。结合以上内容,本课题的设计方案步骤如下:关于硬件部分:首先,对实际的电梯系统进行模拟,一般情况下,一个电梯应该具备相关按键、显示二极管、数码管等,由于这是一个调度模块,故没有设计具体的轿厢等机械部分。然后,结合这些实物,选择恰当的芯片,并分成若干模块,安排好各自之间的关系。由于其有诸多按键和显示环节,而单片机的I/O口管脚资源实在有限,故需要I/O口扩展,用以管理二极管;同时要有专门的按键控制芯片,从而便于按键管理。在此,我分别选择了82C55和8279芯片。接着,要完成电路图的设计,画出PCB板,焊接相关器件后进行硬件调试,看是否好用并加以适当的更正。关于软件部分:处于最底层的是对两个芯片的寄存器读写工作,完成后方可进行更高层的应用程序调试。为了使硬件简单化,我选择了模拟时序的方法读写寄存器,这比总线操作的方法节省了锁存器。然后是关于电梯调度时所遵循的原则作出规定,其必须基于高效与人性化两个原则。最后是使用C语言将规定程序化,以便电梯真正的运作。当然,二者的关系并不是分离的,它们是相辅相成,硬件依据软件来验证,软件依据硬件来调试。经过一个个的发现问题、一个个的解决问题,最终做出完美的电梯调度模块。1.2课题的开发环境简介 1.2.1电路图制作软件Altium designer 7.0Altium Designer 7.0 不断通过为高速设计提供各种功能来提高用户生产力,这些功能包括交互式长度调整和 PCB 层片增强等功能。新增的库工具和各种新功能将 Altium Designer 提升成为统一的电子产品开发解决方案。这款最新的更新程序将进一步增强您的能力,让您能够在更短的“设计到制造”周期内生产更为尖端、更具创新性的电子产品。Altium Designer 提供了唯一一款统一的应用方案,其综合电子产品一体化开发所需的所有必须技术和功能。Altium Designer 在单一设计环境中集成板级和FPGA系统设计、基于FPGA和分立处理器的嵌入式软件开发以及PCB版图设计、编辑和制造。并集成了现代设计数据管理功能,使得Altium Designer成为电子产品开发的完整解决方案一个既满足当前,也满足未来开发需求的解决方案。1.2.2C51的程序开发软件Keil单片机开发中除必要的硬件外,同样离不开软件,我们写的汇编语言源程序要变为CPU可以执行的机器码有两种方法,一种是手工汇编,另一种是机器汇编,目前已极少使用手工汇编的方法了。机器汇编是通过汇编软件将源程序变为机器码,用于MCS-51单片机的汇编软件有早期的A51,随着单片机开发技术的不断发展,从普遍使用汇编语言到逐渐使用高级语言开发,单片机的开发软件也在不断发展,Keil软件是目前最流行开发MCS-51系列单片机的软件,这从近年来各仿真机厂商纷纷宣布全面支持Keil即可看出。Keil提供了包括C编译器、宏汇编、连接器、库管理和一个功能强大的仿真调试器等在内的完整开发方案,通过一个集成开发环境(uVision)将这些部份组合在一起。运行Keil软件需要Pentium或以上的CPU,16MB或更多RAM、20M以上空闲的硬盘空间、WIN98、NT、WIN2000、WINXP等操作系统。掌握这一软件的使用对于使用51系列单片机的爱好者来说是十分必要的,如果你使用C语言编程,那么Keil几乎就是你的不二之选(目前在国内你只能买到该软件、而你买的仿真机也很可能只支持该软件),即使不使用C语言而仅用汇编语言编程,其方便易用的集成环境、强大的软件仿真调试工具也会令你事半功倍。Keil C51 软件是众多单片机应用开发的优秀软件之一,它集编辑,编译,仿真于一体,支持汇编,PLM 语言和 C 语言的程序设计,界面友好,易学易用。1.3 设计功能要求本设计是为一八层电梯设计一调度系统,即使电梯能够合理高效地运行,完成各楼层顾客的接送任务。形象地说,就是要应对不同楼层顾客的不同需求,作出合理高效的判断,使所有顾客在整体运用时间最短的条件下将其运往各自的目的地。这个设计的成品应该可以作为真实电梯的控制系统一样,遵守以下两个原则:一是高效性,二是人性化。而实际电梯所面临的情况无比复杂,故本设计的难点除了硬件上面外,还有对这些复杂的情况归类化,分为若干个基本情况,另外是用恰当的C语言描述来表达这些复杂的逻辑。1.4 本文内容安排在本设计制作的过程中,我查阅阅了大量的相关资料、期刊,并在导师的指导帮助下仔细地进行了斟酌。现将论文的章节安排再次做些简要的说明:第一章,即绪论部分,先对电梯的背景知识等做些介绍,并且对与本设计的设计步骤与重点加以说明,简单介绍了两个与毕设有关的开发软件。第二章,详细地阐述了设计中所用到的各个模块的硬件电路及其工作原理。其中包括单片机最小系统、82C55发光二极管控制模块、8279键盘控制模块和串口下载模块等。第三章,以硬件的物理连接作为基石,以读写芯片内部数据与命令寄存器作为基础,以电梯判决函数作为核心,本章详细地讲述了软件系统的工作原理,并对各个重要函数都有相关的说明。34长春职业技术学院电气自动化专业毕业论文第二章系统的硬件设计2.1硬件电路2.1.1单片机最小系统模块单片机是指一个集成在一块芯片上的完整计算机系统。尽管他的大部分功能集成在一块小芯片上,但是它具有一个完整计算机所需要的大部分部件:CPU、内存、内部和外部总线系统,目前大部分还会具有外存。同时集成诸如通讯接口、定时器,实时时钟等外围设备。而现在最强大的单片机系统甚至可以将声音、图像、网络、复杂的输入输出系统集成在一块芯片上。单片机最小系统,或者称为最小应用系统,是指用最少的元件组成的单片机可以工作的系统。在本设计中,最小系统应该包括:单片机、晶振电路、复位电路等。如图2.1所示,晶振电路由C1与C2和晶振组成,晶振是给单片机提供工作信号脉冲的。它的速率就是单片机的工作速率,简单地说,没有晶振,就没有时钟周期,没有时钟周期,就无法执行程序代码,单片机就无法工作。并在晶振的两引脚处接入两个10pF-50pF的瓷片电容接地用来削减偕波对电路的稳定性的影响。复位电路采取的为手动按键复位电路,由电容C13,电阻R11、R12和开关RESET组成,当单片机的复位引脚RESET出现2个机器周期以上的高电平时,单片机就执行复位操作。如果RST持续为高电平,单片机就处于循环复位状态。每次复位后,单片机的程序都会从第一条开始从新执行。另外,还额外设计了滤波防干扰电路,由C13与R12组成,电源先经过它们再接入单片机的Vcc,可以有效的减少其中的杂波带来的干扰。2.1.2可编程I/O扩展芯片82C55模块8255是Intel公司生产的可编程并行I/O接口芯片,有3个8位并行I/O口。具有3个通道3种工作方式的可编程并行接口芯片(40引脚)。 其各口功能可由软件选择,使用灵活,通用性强。8255可作为单片机与多种外设连接时的中间接口电路。D7D0(data bus):三态、双向数据线,与CPU数据总线连接,用来传送数据。(chip select):片选信号线,低电平有效时,芯片被选中。A1, A0(port address):地址线,用来选择内部端口。(read):读出信号线,低电平有效时,允许数据读出。(write):写入信号线,低电平有效时,允许数据写入。RESET(reset):复位信号线,高电平有效时,将所有内部寄存器(包括控制寄存器)清0。PA7PA0(port A):A口输入/输出信号线。PB7PB0(port B):B口输入/输出信号线。PC7PC0(port C):C口输入/输出信号线。VCC:5V电源。 GND:电源地线。 8255作为主机与外设的连接芯片,必须提供与主机相连的3个总线接口,即数据线、地址线、控制线接口。同时必须具有与外设连接的接口A、B、C口。由于8255可编程,所以必须具有逻辑控制部分,因而8255内部结构分为3个部分:与CPU连接部分、与外设连接部分、控制部分。1、与CPU连接部分根据定义,8255能并行传送8位数据,所以其数据线为8根D0D7。由于8255具有3个通道A、B、C,所以只要两根地址线就能寻址A、B、C口及控制寄存器,故地址线为两根A0A1。此外CPU要对8255进行读、写与片选操作,所以控制线为片选、复位、读、写信号。各信号的引脚编号如下:(1)数据总线DB:编号为D0D7,用于8255与CPU传送8位数据。(2)地址总线AB:编号为A0A1,用于选择A、B、C口与控制寄存器。(3)控制总线CB:片选信号、复位信号RST、写信号、读信号。当CPU要对8255进行读、写操作时,必须先向8255发片选信号选中8255芯片,然后发读信号或写信号对8255进行读或写数据的操作。2、与外设接口部分根据定义,8255有3个通道A、B、C与外设连接,每个通道又有8根线与外设连接,所以8255可以用24根线与外设连接,若进行开关量控制,则8255可同时控制24路开关。各通道的引脚编号如下:(1)A口:编号为PA0PA7,用于8255向外设输入输出8位并行数据。(2)B口:编号为PB0PB7,用于8255向外设输入输出8位并行数据。(3)C口:编号为PC0PC7,用于8255向外设输入输出8位并行数据,当8255工作于应答I/O方式时,C口用于应答信号的通信。3、控制器8255将3个通道分为两组,即PA0PA7与PC4PC7组成A组,PB0PB7与PC0PC3组成B组。如图7.5所示,相应的控制器也分为A组控制器与B组控制器,各组控制器的作用如下:(1)A组控制器:控制A口与上C口的输入与输出。(2)B组控制器:控制B口与下C口的输入与输出。在本设计中,8255与单片机间的通信采取的时模拟时序的方法。单片机的P0口只是用作了数据线,这样与以往的采用P0口数据地址线分时复用的方法相比,简化了电路构造(因为这样可以少用一个芯片74HC573)。具体的电路子模块如图2.3所示,三组扩展管脚均得到了充分的利用。PA口与PB口负责每层楼的上下按键显示灯的亮灭,而PC口负责电梯所到达当前楼层的楼层显示工作。同时,由于干扰等原因,82C55所输出的电压值偶尔偏低,这样直接驱动二极管时,可能会出现显示昏暗甚至不亮的问题,故而在此加上了一个非门,可以起到提高电平值的作用。P1与P2为两个220欧的排阻,用于限流作用,以防二极管由于电压过高所导致的可能被烧坏。芯片82C55的数据口D0D7分别与单片机的P0口各管脚相连,进行数据的传输。而和也当然与单片机的和相连,方便数据或者命令的读与写。其寻址管脚A0与A1分别与单片机的P20与P21相连,操作时只需对P2口的对应两管脚输出合理的高低电平组合,即可选中芯片82C55的相应寄存器,进而进行相应操作。芯片的片选由单片机的P26控制,且低电平有效。其复位管脚RESET与单片机的复位管脚可直接相连。当然,有时芯片82C55的反应没有单片机快速,此时可以进行“软复位”,即让其复位管脚RESET与单片机的某个闲置的I/0管脚相连,通过人为的控制此管脚的高低电平及其时间来对芯片82C55进行复位。即让此I/O管脚输出高电平,且保持一段时间,保证在此时间段内,芯片82C55有足够的时间复位后,再让此管脚恢复低电平即可。另外,本设计中所用的数码管为共阳型。其引脚分布如图2.4所示。有图可知,当要显示特定字符时,只需向其相应段的管脚输入低电平,此段即亮;反之同理,若要其某段不亮,只需输入高电平即可。了解此原理便可方便对其的编程工作。2.1.3可编程按键控制芯片82C79模块Intel8279芯片是一种通用的可编程序的键盘、显示接口器件,单个芯片就能完成键盘输入和LED显示控制两种功能。其引脚分布如图2.5所示。8279包括键盘输入和显示输出两个部分。键盘部分提供的扫描方式,可以和64个按键或传感器的阵列相连。能自动消除开关抖动以及为N个键同时按下提供保护。主要管脚的定义为:(片选):输入线,当=0时8279被选中,允许CPU对其读、写,否则被禁止。A0(数据选择):输入线。当A0=1时CPU写入数据为命令字,读出数据为状态字;A0=0时CPU读、写的字节均为数据。DB0DB7:与单片机通信的数据引脚,用于传送数据。Vcc、GND:电源端与地端,用于给芯片提供电源。、(读、写信号):输入线。低电平有效,来自CPU的控制信号,控制8279的读、写操作。IRQ(中断请求):输出线。高电平有效。在键盘工作方式中,当FIFO/传感器RAM存有数据时,IRQ为高电平。CPU每次从RAM中读出数据时,IRQ变为低电平。若RAM中仍有数据,则IRQ再次恢复高电平。在传感器工作方式中,每当检测到传感器状态变化时,IRQ就出现高电平。SL0SL3(扫描线):输出线。用来扫描键盘和显示器。它们可以编程设定为编码(4中取1)或译码输出(16取1)。RL0RL7(回复线):输入线。它们是键盘矩阵或传感矩阵的列(或行)信号输入线。SHIFT(移位信号):输入线、高电平有效。该输入信号是键盘数据的最高位(D7),通常用来扩充键开关的功能,作为控制功能键用。在选通输入方式时,该信号的上升沿可将来自RL0RL7的数据存入FIFO RAM中。在传感器输入下,该信号无效。OUTA0OUTA3(A组显示信号):输出线。OUTB0OUTB3(B组显示信号):输出线。这两组引线都是显示数据输出线,与多位数字显示的扫描线SL0SL3同步,两组可以独立使用,也可以合并使用。BD(显示消隐):输出线。低电平有效。该信号在数字切换显示或使用消隐命令时,将显示消隐。其八位并行数据管脚分别与单片机的P0口各管脚相连。读写信号端也分别与单片机的对应。而其片选由P27控制,低电平有效。其CLK管脚与ALE相连,单片机正常工作时,ALE管脚输出方波,频率为单片机工作频率的六分之一。而芯片82C79的扫描键盘的频率正是由此而产生,当然i用这么高的频率,还需要继续对其分频后方可供82C79使用。复位键同样与单片机的复位键相通。而至于有些管脚如BD、SHIFT、CNTL/S等由于在此设计中无甚意义,故均将其接地处理。其工作机理为:82C79的SL0SL2在芯片工作时,不断以固定的频率输出低电平,当然是同一时间只选择其中一根线为低电平,其他还未高电平,同时扫描RL0RL7端,若得到某各端口返回低电平,在经过消抖处理后仍为低电平,则说明SL0SL2当前输出低电平的那根线与RL0RL7当前返回低电平的那根线的交叉处的那个开关被按下了。那么芯片82C79会自动将该按键按照规定的协议翻译为相应的键值(每个按键都有自己唯一的键值标示,这便于在编写程序时读取键值进而进行散转),存储与FIFO寄存器中,同时,由于该寄存器中存有单片机未读取的值,IRQ管脚就会自动输出高电平,再经过非门后对单片机的INT0产生中断,此时只需在编程时在中断程序中对其进行相应处理即可。2.1.4MAX232串口下载模块与附加电源模块等由于程序绝不可能第一次编写完就可以达到预设的目的,其间要经过很多次的更改修正,故为了便于程序的调试工作,我在此电路板上增设了一个MAX232串口下载模块,这样便可以不用取下单片机去其他的电路板上下载,而直接便可以在此电路板上完成了。同时为便于电源的引入,我选择了电脑USB口输出的5V直流电源,这样无需再用大型的电源设备,随处便可以调试。MAX232电路时该芯片数据手册中提供的典型应用图。MAX232是一个电荷泵器件,它采用开关电容技术将5V电压升压和获取负电压。至于电源模块,便比较简单了,USB口通常有四条引出线,其中边缘两根便为电源线,一个为+5V直流端,一个为地端。中间两根为差分信号线D+与D-,负责信号的串行通信。但由于此处只用做电源功能,故中间两根无需接入。+5V直流端通过一个按键开关并经过一10微法的电容滤波后接入Vcc,供整个电路板供电。当电源导通后,电源指示二极管会高亮。同时,基于人性化处理,在电梯上下行时,我专门用若干个二极管排列成上下箭头的形状,如图所示。中间的四个发光二极管组成一竖线型,并处于常亮状态,当电梯上行时,与单片机P13管脚连接的UP端将输出低电平,经过一非门后使组成上三角的四个发光二极管点亮,从而形成以向上箭头;同理,当下行时,与单片机P11脚相连的DOWN端将输出低电平,使组成下三角的四个发光二极管导通,形成向下箭头,如图2.8所示。2.2 本章小结本章对设计中的硬件环节作了详细的介绍,将其分为若干模块,分别为单片机最小系统模块、82C55发光二极管显示模块、8279键盘控制与数码管显示模块、串口下载模块、电源模块等。它们均具有不可或缺的功能及特点。整个硬件系统的工作机理为:单片机最小系统为整个系统提供最基本的运行环境,8279通过扫描按键是否按下,向单片机发出中断,单片机进行相应处理,并通过82C55控制发光二极管的两灭、通过8279控制当前楼层的显示。第三章芯片基本读写的实现3.1单片机对芯片82C55的基本读写与一般其他的芯片类似,对82C55芯片的操作,一般也即对其内部寄存器的操作。其内部寄存器分为两类,一类为命令寄存器,另一类为数据寄存器。很明显,由于82C55的功能为将一组单片机I/O口扩展为三组I/O口,那么肯定要有三组数据寄存器,分别对应着它的三组I/O口,即PA口,PB口与PC口,那么82C55芯片便有四个寄存器,正好可以用两位的地址线进行寻址(即管脚A0与A1)。具体的说,其过程为:开始选中该芯片(低电平有效),而后设置好所要读写的寄存器的地址,也即设置好A0与A1的数值组合,若为读寄存器,则让单片机读引脚P37为低电平,反之若为写寄存器,则让单片机写引脚P36为低电平,然后把要读或者写的数据放到数据口P0口上(需要注意的是,当单片机读寄存器时,对于其自身来说,是输入数据,故此时需先让P0口值为高电平0xff为下一步的输入做准备,而此流程图的最后一步即为这种情况做准备的),一段短短的稳定时间后再让读引脚或者写引脚为高电平,则在由低到高的跳变中,数据得到了转移。然后再片选无效,以防以后的数据传输产生相互干扰。最后数据口P0置为0xff,为方便下次可能的输入做准备。3.2芯片82C55的初始化3.2.1芯片82C55的逻辑构造1、三个并行输入输出端口(端口A、端口B、端口C) 8255A有A、B、C三个并行输入输出端口(简称为A口、B口、C口),其功能全部由程序设定,每个端口都有自己的特点。A口、B口通常作为独立的I/O端口使用,C口也可以作为一般的I/O端口使用,但当A口、B口作为应答式的I/O口使用时,C口分别用来为A口、B口提供应答控制信号。2、读/写控制逻辑读/写控制逻辑用于管理数据、控制字或状态字的传送,其控制信号有以下几种:(1) 片选信号,低电平有效允许8255A与CPU交换信息。(2) 读信号,低电平有效允许CPU从8255A端口中读取数据或状态信息。(3) ,写信号,低电平有效允许CPU将数据、控制字写入到8255A中。(4) RESET,复位信号,高电平有效。清除8255A所有控制寄存器内容,并将各端口置成输入方式。(5) A1、A0,8255A片内端口寻址地址。3、A组和B组控制电路A组和B组控制电路接受读/写控制逻辑的信号和CPU送入的控制字,然后决定各端口的功能。A组控制电路控制A口和C口的高4位(PC7PC4);B组控制电路控制B口和C口的低4位(PC3PC0)。还可根据控制字的要求对C口的某位实现置0或置1的操作。4、数据总线缓冲器数据总线缓冲器是一个双向三态的8位缓冲器,可与系统的数据总线直接相连,实现CPU和8255A之间的信息传送。82C55芯片内部有四个寄存器,即命令寄存器、PA口寄存器、PB口寄存器、PC口寄存器。其中,向命令中写入数据可以控制芯片各扩展口的工作方式。向后三者寄存器中写入数据,芯片会自动将其取出,并以高低电平的形式分布于各相应管脚。并且,三组扩展口在作为输出时,均具有锁存功能。由于有四组口,故相应的应该有两位地址来对其寻址。芯片上的A0、A1即为此而设计,当A0=0,A1=0时,寻址的为PA口寄存器;当A0=1,A1=0时,寻址的为PB口寄存器;当A0=0,A1=1时,寻址的为PC口寄存器;当A0=1,A1=1时,寻址的为命令(控制)寄存器。具体的端口选择与操作功能如表3.1所示表3.18255A端口选择及操作功能表A1A0端口及操作功能00010端口A数据总线输入操作(读)01010端口B数据总线10010端口C数据总线00100数据总线端口A输出操作(写)01100数据总线端口B10100数据总线端口C11100数据总线控制寄存器1未选中8255A,数据总线三态11010非法状态(不能读控制寄存器)110数据总线三态3.2.2芯片82C55的工作方式该芯片具有三种可选的工作方式,分别便于不同情况时供使用者以更为方便的选择。现对其工作方式做一简要介绍如下:1、方式0基本输入输出方式(1) 方式0的工作特点方式0称为基本输入输出方式,该方式下可将3个数据端口划分为4个独立的部分:A口和B口作为两个8位端口,C口的高4位和低4位可以用作两个4位端口(当然也可以作为一个8位端口),各个端口都可以独立用作输入或输出。其特性如下:1. 任何端口都具有输出及输入功能。2. 输出时,各Port 均有锁定功能,能将信号锁定在最后一次的输出状态上。3. 输入无锁定功能,数据收到后,端口上的信号将不会保留最后一次输入的状态。4. 有2 个8 位端口(PA 和PB)及2 个4 位端口(PC0PC3 和PC4PC7)可供利用。5. 共可组成16 种不同的输出入状态。(2) 方式0的使用场合方式0使用在无条件传送和查询式传送两种场合。2、方式1选通输入输出方式(1) 方式1的工作特点方式1是一种选通输入输出方式。在这种工作方式下,端口A、端口B和端口C被分为两个组。端口A和端口B用作数据的输入/输出,端口C的一些引脚信号被规定为端口A、B的联络信号,这些联络信号和C口的各引脚保持固定的对应关系,不能用程序改变。1. A/B口输入的联络信号STB :输入选通信号,低电平有效,外设输入;当该信号有效时,使8255的A/B口接收外设的8位数据。信号通过PC4/ A口、 PC2/ B口引入。IBF:输入满信号,高电平有效,8255输出;当该信号有效时,表示8255已接收数据。信号通过PC5/ A口、 PC1/ B口引出。INTR:中断请求信号,高电平有效,8255输出;当该信号有效时, 8255向CPU申请中断(读取数据),信号通过PC3/ A口、 PC0/ B口引出。INTE:中断允许标志,是否允许发出中断申请( INTR );当设置PC4=1( A口的标志), PC2=1 ( B口的标志)时,中断允许。2. A/B口输出的联络信号OBF :输出满信号,低电平有效, 8255输出; 当该信号有效时,通知外设,A/B口的数据准备好。信号通过PC7/ A口、 PC1/ B口引出。ACK:外设回答信号,低电平有效;当该信号有效时,表示外设已空闲。信号通过PC6/ A口、 PC2/ B口引入。INTR:中断请求信号,高电平有效,8255输出;当该信号有效时, 8255向CPU申请中断(输入数据),信号通过PC3/ A口、 PC0/ B口引出。INTE:中断允许标志,是否允许发出中断申请( INTR );当设置PC6=1( A口的标志), PC2=1 ( B口的标志)时,中断允许。方式1的工作特点可归纳如下:端口A和端口B均可工作在方式1输入或输出方式。若端口A和端口B中只有一个工作在方式1,而另一个工作在方式0,则端口C中有3位作为方式1的联络信号,端口C其余5位均可工作在方式0的输入或输出方式。若端口A和端口B都工作在方式1,则C口中6位作其联络信号,剩下的2位还可工作在方式0的输入输出方式。方式1有两种用法:(1) 中断方式。将两个INTE置为1,A组和B组可以使用各自的INTR信号申请中断。(2) 查询方式。微处理器通过读端口C,可以查询IBF、OBF#信号的当前状态,决定是否立即进行数据传输。3、方式2双向输入输出方式方式2只适用于端口A,是双向的输入输出传输方式。在方式2,外设可以在A口的8位数据线上分时向8255A发送数据或从8255A接收数据,但不能同时进行。该方式需占用端口C的5位作为联络信号。端口A工作于方式2时,端口B可选方式0或方式1。3.2.3芯片82C55的初始化由以上的分析可知,对芯片82C55的初始化,实质上即是规定好它每个扩展口是作为什么方式使用,即是输入还是输出,并且工作于何种方式。根据本设计的需求可知,我们只需用到两组扩展口PA和PB,并且他们均是用于控制二极管的亮灭,可见是作为输出使用的;并且他们不需要其他的控制,即只要求作为最基本的输出即可,也即工作于方式0便可。而这一切,均可以通过芯片的方式控制字来加以限定。由以上要求,我们可以得到该控制字的数值为0x80(二进制为1000 0000)。最后,再把这一命令控制字发送到82C55的命令寄存器即可,命令寄存器对应的地址为A0=1,A1=1。3.3对芯片8279的基本读写与初始化3.3.1芯片8279的基本读写与82C55类似,由于未用诸如74HC573之类的锁存器,P0口无法实现数据与地址的复用功能,对8279的读写控制也是基于模拟时序的基础上进行的。并且他们的时序操作图大概类似,故在此不再赘述。3.3.2芯片8279的初始化对该芯片的初始化,也即规定好该芯片的工作方式等,当然由于其功能较为强大,故对其操作的语句也相对多些。一般来说,对8279操作的命令分为八种,分别为:1、键盘/显示器方式命令;2、时钟编程命令;3、读键字命令;4、读显示缓冲器命令;5、写显示缓冲器命令;6、显示器禁止写入/熄灭命令;7、清楚命令;8、结束中断/错误方式设置命令。现分别介绍如下:1、键盘/显示方式设置命令字(表3.2)表3.2 键盘/显示方式设置命令格式D7D6D5D4D3D2D1D0000DDKKK其中:D7、D6、D5=000方式设置命令特征位。DD(D4、D3):来设定显示方式,其定义如下(表3.3):表3.3 D3、D4显示方式 D4 D3显示方式0 08个字符显示,左入口开始0 116个字符显示,左入口开始(复位后状态)1 08个字符显示,右入口开始1 116个字符显示,右入口开始所谓左入口,即显示位置从最左一位(最高位)开始,以后逐次输入的显示字符逐个向右顺序排列; 所谓右入口,即显示位置从最右一位(最低位)开始,以后逐次输入的显示字符时,已有的显示字符逐个向左顺序移动。KKK(D2、 D1、 D0):用来设定七种键盘、显示工作方式(表3. 4):表3.4 D2、D1、D0操作方式D2 D1 D0操作方式0 0 0外部编码扫描键盘(16取1),双键互锁0 0 1内部译码扫描键盘(4取1),双键互锁0 1 0外部编码扫描键盘N键依次读出0 1 1内部译码扫描键盘N键依次读出1 0 0外部译码扫描传感器矩阵方式1 0 1内部译码扫描传感器矩阵方式1 1 0选通输入方式,外部编码显示扫描1 1 1选通输入方式,内部译码显示扫描双键锁定与N键轮回是多键按下时的两种不同的保护方式。双键锁定为两键同时按下提供的保护方法。再消颤周期里,如果有两键同时按下,则只有其中一个键弹起,而另一个键保持在按下位置时,才被认可。N键轮回为N键同时按下的保护方法。当有若干键按下时,键盘扫描能够根据发现他们的顺序,依次将它们的状态送入FIFO RAM中。2、程序时钟命令(表3.5)表3.5程序时钟命令格式D7D6D5D4D3D2D1D0001PPPPP其中:D7、D6、D5=001为时钟命令特征位。PPPPP( D4、D3、D2、D1、D0)用来设定外部输入CLK端的时钟进行分频的分频数N。N取值为231。例如外部时钟频率为2MHZ,PPPPP被置为10100(N=20),则对输入的外部时钟20分频,以获得8279内部要求的100KMZ的基本频率。3、读FIFO/传感器RAM命令(表3.6)表3.6 读FIFO/传感器RAM命令格式D7D6D5D4D3D2D1D0010AIXAAA其中:D7D6D5 =010为读FIFO/传感器RAM命令特征位。该命令字只在传感器方式时使用。在CPU读传感器RAM之前,必须使用这条命令来设定传感器RAM中的8个地址(每个地址一个字节)。AAA(D2、D1、D0)为传感器RAM中的八个字节地址。AI(D4)为自动增量特征位。当AI=1时,每次读出传感器RAM后地址自动加1使地址指针指向下一个存储单元。这样,下一个数据便从下一个地址读出,而不必重新设置读FIFO/传感器RAM命令。在键盘工作方式中,由于读出操做严格按照先入先出顺序,因此,不需使用此命令。4、读显示RAM命令(表3.7)表3.7 读显示RAM命令格式D7D6D5D4D3D2D1D0011AIAAAA其中:D7D6D5 =011为读显示RAM命令字的特征位。该命令用来设定将要读出的显示RAM地址。AAAA(D3、D2、D1、D0)用来寻址显示RAM命令字的特征位。由位显示RAM中有16个字节单元故需要4位寻址。AI(D4)为自动增量特征位。当AI=1时,每次读出后地址自动加1指向下一地址。5、写显示RAM命令(表3.8)表3.8 写显示RAM命令格式D7D6D5D4D3D2D1D0100AIAAAA其中:D7D6D5 =100为写显示RAM命令字的特征位。在写显示器RAM之前用该命令用来设定将要写入的显示RAM地址。AAAA(D3、D2、D1、D0)为将要写入的存储单元地址。AI(D4)为自动增量特征位。当AI=1时,每次写入后地址自动加1指向下一次写入地址。6、显示禁止写入/消隐命令特征位(表3.9)表3.9 显示禁止写入/消隐命令格式D7D6D5D4D3D2D1D0101XIWAIWBBLABLB其中:D7D6D5 =101为显示禁止写入/消隐命令特征位。IW/A、IW/B(D3、D2)为A、B组显示RAM写入屏蔽位。由于显示寄存器分成A、B两组,可以单独送数,故用两位来分别屏蔽。当A组的屏蔽位D3=1时,A组的显示RAM禁止写入。因此,从CPU写入显示器RAM数据时,不会影响A的显示。这种情况通常在采用双4位显示器时使用。因为两个双四位显示器是相互独立的。为了给其中一个双四位显示器输入数据而又不影响另一个四位显示器,因此必须对另一组的输入实行屏蔽。BL/A、BL/B(D1、D0)为消隐显示位。用于对两组显示输出消隐。若BL=1时,对应组的显示输出被消隐。当BL=0时,则恢复显示。7、清除命令(表3.10)表3.10 清除命令格式D7D6D5D4D3D2D1D0110CDCDCDCFCA其中:D7D6D5 =110清除命令特征位。CDCDCD(D4D3D2)用来设定清除显示RAM方式,共有四种消除方式(表3.11)。表3.11 D4D3D2消除方式D4 D3 D2清除方式1 0 X将显示RAM全部清零1 1 0将显示RAM清成20H(A组=0010,B组=0000)1 1 1将显示RAM全部置10 X X不清除(CA =0)CF(D1)用来置空FIFO存储器,当=1时,执行清除命令后,FIFO RAM被置空,使中断输出线复位。同时,传感器RAM的读出地址也被置0。CA(D0)为总清的特征位。它兼有CD和CF的联合效能。在CD=1时,对显示的清除方式由D3、D2的编码决定。清除显示RAM约需160S。在此期间FIFO状态时的最高位DU=1,表示显示无效。CPU不能向显示RAM写入数据。8、结束中断/错误方式设置命令(表3.12)表3.12 结束中断/错误方式设置命令格式D7D6D5D4D3D2D1D0111EXXXX其中:D7D6D5 =111为该命令的特征位。此命令有两种不同的作用。(1)作为结束中断命令。在传感器工作方式中使用。每当传感器状态出现变化时,扫描检测电路将其状态写入传感器RAM,并启动中断逻辑,使IRQ变高,向CPU请求中断,并且禁止写入传感器RAM。此时,若传感器RAM读出地址的自动递增特征没有置位(AI=0),则中断请求IRQ在CPU第一次从传感器RAM读出数据时就被清除。若自动递增特征已置位(AI=1),则CPU对传感器RAM的读出并不能清除IRQ,而必须通过给8279写入结束中断/错误方式设置命令才能使IRQ变低。因此在传感器工作方式中,此命令用来结束传感器RAM的中断请求。(2)作为特定错误方式设置命令。在8279已被设定为键盘扫描N键轮回方式以后,如果CPU给8279又写入结束中断/错误方式设置命令(E=1),则8279将以一种特定的错误方式工作。这种方式的特点是:在8279的消颤周期内,如果发现多个按键同时按下,则FIFO状态字中的错误特征位S/E将置1,并产生中断请求信号和阻止写入FIFO RAM。上述八种用于确定8279操作方式的命令字皆由D7D6D5特征位确定,输入8279后能自动寻址相应的命令寄存器。因此,写入命令字时唯一的要求是使数据选择信号A0=1。8279只有一位地址线A0,那么当然只可以寻址两个寄存器。实际上也是如此的,当A0=0时,寻址的为其内部的数据寄存器;当A0=1时,寻址的为其内部的控制寄存器。那么其控制命令有多种,单一的一个命令寄存器又是何以分辨如此多的命令呢?如上面所示,命令寄存器的八位中,高三位为命令的分辨符。故若想输入不同的命令,只需写入相应的高三位数据即可。对8279的初始化供分为三步,即先后输入三个命令。首先,我们要对芯片内部的各寄存器进行类似于复位的清零操作,方便以后的使用;其次,由于本设计中8279主管22各按键,而按键按下时又有多种复杂的情况,诸如同时有若干按键按下等,我们要选择此种情况的处理方式;再者,由于8279对按键实际上是通过扫描的方式确定有无按键按下,故我们还要设置好扫描的频率等,由硬件电路知道,8279有一时钟输入引脚CLK接于单片机的ALE引脚上,在单片机正常工作时,ALE引脚输出的为晶振频率六分之一的脉冲,这正是8279扫描的时钟源,当然,8279的扫描频率不可能达到单片机晶振的输出频率那么高,其实际的最大扫描频率为100KH左右,故我们需要一设置分频命令。那么这三个命令的命令字是如何得到的呢?参考上面命令字的格式可以知道:(1)清除寄存器命令的高三位特征位应该为110,又由于我们是将显示RAM全部清零,故D4到D2位应该选择为100,由于对显示RAM的清除方式选择由D3和D2控制,故要求其D0位为1。故最终得到的命令字为11010001,转换为十六进制即为0xd1。(2)设置按键方式中,其特征位的代码为000。由于未用到显示功能,故其对应控制位D4与D3可以随便设置,在此均设置为00。至于按键工作方式的选择,我们只所以选择内部译码扫描键盘N键依次读出的方式,是结合实际情况的结果。双键互锁的方法是当键盘同时有两个键按下时,任何一个键值均不能进入FIFO RAM中,直至仅剩一个键保持闭合时,该键值才能进入到FIFO RAM中。而N键依次读出方式,是N个键同时按下的保护方法。当有若干个键同时按下时,在键盘的扫描过程中根据发现它们的先后顺序进行识别,并以此将它们的状态送入FIFO RAM中。对比我们可以发现,现实中偶尔会发生不同楼层会有不同人同时按下不同按键的情况发生,这时若选择双键互锁的方式,则谁的键值都不能传达给内部寄存器,这是很不方便的,故在此,我们选择了N键依次读出的方式。对于市内部译码还是外部编码的扫描方式,我们也可以根据其特点进行选择:编码方式,也称为外部译码方式,计数器以二进制方式计数,4位计数状态从扫描线SL0SL3输出,经外部译码器译出16位扫描线,为键盘和显示器提供16取1的扫描线。而译码方式,也称为内部译码方式,扫描计数器的低2位经内部译码后从SL0SL3输出,故此时提供了4取1的扫描译码。由电路图我们可以看出,实际上我们仅仅用到了SL0SL3中的前三根线(因为按键不是太多,三乘八的矩阵键盘已足够使用),故四取一得译码方式便成为了我们的首选,其对应代码为D2D1D0=011。最终我们得到完整的命令符为0000 0011,也即十六进制中的0x03。(3)设置分频命令字。其对应特征位为001.由于电路板上,单片机的晶振为6MHz,ALE脚输出的脉冲频率为晶振的六分之一,即1MHz,而8279的基本频率为100KHz,故我们设置的分频系数应该为1M/100K=10(十进制),对应的二进制为01010。最后可得完整二进制与十六进制命令码分别为00101010和0x2a。3.5 本章小结本章重点介绍了82C55和8279两种芯片的管脚分布及使用方法,特别是两种芯片内部寄存器的数据结构,对它们的了解是参数选择的依据,只有选择正确适当,整个系统才有可能按照我们的设计去运行。最后对照其数据结构,结合我们设计的需求,详细介绍了整个系统参数选取的过程。并且用流程图的方式说明了其初始化的方式。第四章 系统的高层软件设计4.1单片机中断处理函数本设计主要用到了单片机的中断系统。当8279扫描到有按键按下时,便会将键值存储起来,并在IRQ引脚输出高电平发出中断,通知单片机进行相关处理。在此详细介绍下中断的相关设置以及中断处理中都进行了哪些操作(如图4.1所示)。4.1.1 单片机有关中断的相关设置主要表现为对其中的一些相关寄存器的设置。由于用到的是外部中断0,其优先级别最高,故在此只需设置单片机特殊功能寄存器里的中断允许控制寄存器IE和定时/计数器控制寄存器TCON。二者的数据结构如表4.1和表4.2所示。表4.1 中断允许与禁止寄存器IEEA/ET2ESET1EX1ET0EX0其中:EA为单片机中断允许控制位,当其置位时表示允许单片机接收中断。后面六位依次为定时器2中断、串口中断、定时器1中断、外部中断INT1定时器0中断和外部中断INT0的中断允许控制位,哪一位置1,就代表允许相应的中断。本设计中用到的为外部中断0的中断,故需将EX0和EA置位。表4.2 定时/计数器控制寄存器TCONTF1TR1TF0TR0IE1IT1IE0IT0该寄存器包含有关于定时控制与溢出和外部中断的触发方式与中断请求标志的相关设置。其中高四位和定时器有关,在此没有用到。第四位中,最低两位中的IE0和IT0时与外部中断0有关的。当外部中断0有中断呼叫时,IE0会自动置一,也即作为中断发生的一种标志。而IT0是关系到中断是以何种方式触发的。当IT0=0时,则为电平触发方式;当IT0=1时,则为边沿触发方式。在此,考虑实际情况,选择边沿触发方式较为合理,故要设置IT0=1。4.1.2 读取8279数据寄存器当单片机收到来自于8279的中断请求时,基于3.5.1中关于中断的一些设置,单片机会自动的响应中断,由于8279是由于其扫描到有按键按下,才发出中断,故我们第一步要把它扫描到得键值读回,这样才可以判断是哪个键按下,进而进行其他后续操作。读8279的数据寄存器时,由于其内部只有一个数据寄存器,那么如何保证所读到得正好是我们想要的键值数据呢?在8279的相关协议中,规定在读取键值之前,需要先向其命令寄存器中输入读键值命令0x40。随后键值即会自动的装入数据寄存器中,便于读出。该函数在执行完成后,便会返回一个unsigned char型的数据,也即为键值。4.1.3分析键值,判断哪个按键按下单片机在读取到键值后,自然会分析该键值来自于哪一层楼的哪个按键。然后才可以把该按键对应的二极管打亮(实际中的电梯也是如此)。那么首先,单片机是如何分析键值的呢?8279在控制诸多按键时,按键是按照行与列均匀分布的,特定的行与特定的列处的每个按键,均对应有特定的键值。首先可以人为地规定每个按键在电梯中所处的位置。例如规定位于SL0列与RL0行的按键即为三楼上行呼叫的按键等等(具体可参照电路图)。它有自己固定的键值。那么在都回键值后,只需用一个switch-case语句进行散转即可。在此说明下按键的键值是如

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论