单片机课程设计---IO口的扩展与应用.doc_第1页
单片机课程设计---IO口的扩展与应用.doc_第2页
单片机课程设计---IO口的扩展与应用.doc_第3页
单片机课程设计---IO口的扩展与应用.doc_第4页
单片机课程设计---IO口的扩展与应用.doc_第5页
已阅读5页,还剩13页未读 继续免费阅读

下载本文档

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

文档简介

单片机课程设计宝鸡文理学院单片机技术课程设计说明书i/o口的扩展与应用目 录1. 概述错误!未定义书签。2. 分项说明错误!未定义书签。2.1 xxxxxx错误!未定义书签。2.2 xxxxxx错误!未定义书签。3. 分项说明错误!未定义书签。3.1 xxxxxx错误!未定义书签。3.2 xxxxxx错误!未定义书签。4. 结束语错误!未定义书签。参考文献错误!未定义书签。附 录错误!未定义书签。附录1:程序清单错误!未定义书签。附录2:设计图纸错误!未定义书签。附录3:元器件目录表错误!未定义书签。注:整个设计说明书撰写完毕之后,请对目录域做以下修改:1. 目录更新:右击以上目录域,选“更新域”“更新整个目录”;2. 目录格式更改:生成的目录是5号字,必须修改,方法如下:(1) 选中目录域的全部区域;(2) 将字体改为小4号字体;(3) 将段落的行间距改为固定值18磅。(文档完成后请将注文删除课题名称:i/o口的扩展与应用1.概念1.1课题名称概述:在单片机家族的众多成员中,mcs-51系列单片机以其优越的性能、成熟的技术、高可靠性和高性价比,占领了工业测控和自动化工程应用的主要市场,并成为国内单片机应用领域中的主流机型。mcs-51单片机的并行口有p0、p1、p2和p3,由于p0口是地址数据总线口,p2口是高8位地址线,p3口具有第二功能,这样,真正可以作为双向io口应用的就只有p1口了。这在大多数应用中是不够的,因此,大部分mcs-51单片机应用系统设计都不可避免的需要对p0口进行扩展。在较为复杂的控制系统(尤其是工业控制系统,如可编程控制器)中,经常需要扩展i/o口。常用的i/o接口芯片有74hc系列锁存器/寄存器、8255和8155等。同时要求可编程并行i/o应具有以下功能:(1)具有缓冲、锁存功能的数据端口每个端口都具有与cpu交换必须的状态和控制信息,也具有与外设交换必须的状态和控制信息(的握手信号)(2)具有中断方式实现i/o的有关电路(3)片选和连接控制电路(4)可通过cpu对芯片的编程,选择数据端口、数据传送方向,选择查询或中断通信方式8255是intel公司生产的可编程并行i/o接口芯片,有3个8位并行i/o口。具有3个通道3种工作方式的可编程并行接口芯片(40引脚)。 其各口功能可由软件选择,使用灵活,通用性强。8255可作为单片机与多种外设连接时的中间接口电路。8255a可编程并行输入/输出接口芯片是intel公司生产的标准外围接口电路。具有40条引脚,采用双列直插式封装。它有a、b、c 三个端口,可以通过编程的方法来设定端口的各种i/o功能。由于它功能强,又能方便地与各种微机系统相接,而且在连接外部设备时通常不需要再附加外部电路,所以得到了广泛的应用。单片机由ram、rom、cpu构成,定时,计数和多种接口于一体的微型控制器。它体积小,成本低,功能强,广泛应用于智能产业和工业自动化上。而51系列单片机是个单片机中最为典型和最有代表的一种。这次课程设计通过对它的学习、应用,从而达到学习、设计、开发软、硬件的能力。本次设计主要设计了一个基于8051单片机来扩展外围芯片,实现相应的功能,通过编写相应程序来控制51单片机,进而实现按键采集和功能。1.2课题设计目的:(1)进一步熟悉和掌握单片机的结构及工作原理(2)巩固和加深对单片机原理知识的理解,提高学生综合运用课程所学知识的能力及相应得自学能力,并初步建立起开发单片机应用系统的系统概念和整体设计的思想。(3)通过课程设计,掌握以单片机核心的电路设计的基本方法和技术,了解相关电路参数的计算方法。(4)通过实际程序设计和调试,逐步掌握模块化程序设计方法和调试技术。(5)通过完成一个包括电路设计和程序开发的完整过程,使自己了解开发单片机应用系统的全过程,为今后从事设计开发工作打下基础。(6)掌握单片机的接口技术和常用扩展接口芯片如8255等的外特性、使用及控制方法,熟悉汇编程序设计方法,能够达到熟练调试程序的程度。(7)根据个人的设计调试过程,按照课程设计报告的规范撰写设计要求。1.3课题设计要求:结合51单片机,8255,、74ls373等芯片完成单片机设计。根据设计原理图、程序流程图、编写程序并调试,说明所设计电路的功能,以及各个功能模块的作用。原理图设计要求:该图设计要符合项目的工作原理,连线要正确。图中所使用的元件要合理选用,器件参数要正确标明。cpu、外围器件、扩展接口、输入输出装置要一应俱全。程序设计要求:写程序是要根据要求将总体功能分解成若干个子功能模块,每个功能模块完成一个特定的功能。根据总体要求及分解的功能模块,确定各功能模块之间的关系,设计出完整的程序流程图。编写程序,并执行该程序进行调试,检查该程序、是否达到设计要求,若未达到,修改程序,直到达到要求为止。1.4课题设计内容:在较为复杂的控制系统(尤其是工业控制系统,如可编程控制器)中,经常需要扩展i/o口。常用的i/o接口芯片有74hc系列锁存器/寄存器、8255和8155等。8255是intel公司生产的可编程并行i/o接口芯片,有3个8位并行i/o口。具有3个通道3种工作方式的可编程并行接口芯片(40引脚)。 其各口功能可由软件选择,使用灵活,通用性强。8255可作为单片机与多种外设连接时的中间接口电路。在熟悉和掌握单片机的结构及工作原理的条件下,按扩展8255接口芯片的硬件要求,读取a口上8个按键的开关状态,b口输出数据并且驱动发光二极管显示按键状态。c口经光电隔离驱动220v40w交流白灼灯(与发光二极管状态一致),设计出相应的电路原理图及程序图。最后在仿真软件上调试并运行正确。1.5课题设计思路:在实验台上8255的三个通道pa0pa7;pb0pb7;pc0pc7都有引出插孔可以与其它电路连接。所设计的系统功能为:读取a口上8个按键的开关状态,b口输出数据并且驱动发光二极管显示按键状态。c口经光电隔离驱动220v40w交流白灼灯(与发光二极管状态一致)课题设计步骤:(1)选择符合要求的芯片,了解该芯片的内部结构及原理(2)按要求设计出原理图所包含的模块,大致有控制模块、扩展模块等(3)把设计好的各个模块用导线连接起来,使之成为一个能够控制的整体(4)编写与原理图相对内应的程序,通过韦福软件检查程序的正确性(5)在仿真软件中进行调试,调试正确后打印出原理图和程序1.6设计方案论证:根据设计内容要求,提出了如下三种方案:方案一:8255是intel公司生产的可编程并行i/o接口芯片,有3个8位并行i/o口。具有3个通道3种工作方式的可编程并行接口芯片(40引脚)。 其各口功能可由软件选择,使用灵活,通用性强。8255可作为单片机与多种外设连接时的中间接口电路。如图1-1所示。p0.0p0.1p0.2p0.3p0.4p0.5p0.6p0.7wrrdrdwrresetcsa1a0d7d6d5d4d3d2d1d0papbpc8255a8031alegoed7d6d5d4d3d2d1d0q7q6q5q4q3q2q1q0ea74ls373方案一:8255a与单片机的连接系统结构框图方案二:在80c51单片机应用系统中,采用74hc系列的锁存器和触发器通过p0口也可以构成各种类型的输入/输出接口,这种i/o口具有电路简单、成本低、配置灵活方便等优点。故在单片机应用系统中也被广泛采用。方案三:利用ttl芯片、coms锁存器、三态门等接口芯片把p0接口扩展,常选用74ls273、74ls373、74ls244等芯片在p2.0为0时,74ls244和74ls273都全被选通,二者的口地址都为feffh(这个地址不是唯一的,只要保证p2.0=0,其他地址位无关)。由于分别受/rd和/wr控制,因而两个信号不可能同时为0(执行输入指令,如movx a,dptr或movx a,ri时,/rd有效;执行输出指令,如movx dptr,a或movx ri时,/wr有效),所以逻辑上二者不会发生冲突。1.7课题预期成果:当一接口为高电平时,与之相对应的按键被按下,二极管导通发光,白炽灯被点亮。例如当在仿真软件中设置a口的第三个按键状态为高电平时,相对应的有原理图中a口的第三个按键被按下,同时b口第三个发光二极管导通发光,c口的交流白炽灯点亮。1.8课题设计价值:(1)通过这个课程设计使自己进一步熟悉和掌握了单片机的结构与工作原理(2)巩固和加深了对单片机知识的理解,提高了综合运用能力(3)初步建立了单片机系统概念和整体模块的设计思想(4)编写程序时要根据要求将总体功能分解成若干个子模块,设计出完整的程序流程图(5)本次课程设计实现了8255芯片i/o的扩展与运用,掌握了i/o口的控制逻辑(6)了解了查询方式与中断方式的比较,输入输出信号的可靠性及保护2、分页说明系统硬件设计基于单片机对8255芯片i/o口的扩展与应用,设计的控制原理图如图2-1所示。系统由电源控制模块、译码器模块、扩展模块、光电隔离驱动模块四个部分组成。2.1电源控制模块电源控制模块电路如图2-2所示,主控器采用at89c51。引脚如图2-3所示。图2-2 电源控制模块电路at89c51是一种带4k字节flash存储器(fperomflash programmable and erasable read only memory)的低电压、高性能cmos 8位微处理器,俗称单片机。at89c2051是一种带2k字节闪存可编程可擦除只读存储器的单片机。单片机的可擦除只读存储器可以反复擦除1000次。该器件采用atmel高密度非易失存储器制造技术制造,与工业标准的mcs-51指令集和输出管脚相兼容。由于将多功能8位cpu和闪烁存储器组合在单个芯片中,atmel的at89c51是一种高效微控制器,at89c2051是它的一种精简版本。at89c单片机为很多嵌入式控制系统提供了一种灵活性高且价廉的方案。at89c51主要特性:(1)与mcs-51 兼容 (2)4k字节可编程flash存储器 (3)寿命:1000写/擦循环 (4)数据保留时间:10年 (5)全静态工作:0hz-24mhz (6)三级程序存储器锁定 (7)1288位内部ram (8)32可编程i/o线 (9)两个16位定时器/计数器 (10)5个中断源 (11)可编程串行通道 (12)低功耗的闲置和掉电模式 (13)片内振荡器和时钟电路at89c51管脚说明:vcc:供电电压。 gnd:接地。 p0口:p0口为一个8位漏级开路双向i/o口,每脚可吸收8ttl门电流。当p0口的管脚第一次写1时,被定义为高阻输入。p0能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。在fiash编程时,p0 口作为原码输入口,当fiash进行校验时,p0输出原码,此时p0外部必须被拉高。 p1口:p1口是一个内部提供上拉电阻的8位双向i/o口,p1口缓冲器能接收输出4ttl门电流。p1口管脚写入1后,被内部上拉为高,可用作输入,p1口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故。在flash编程和校验时,p1口作为第八位地址接收。 p2口:p2口为一个内部上拉电阻的8位双向i/o口,p2口缓冲器可接收,输出4个ttl门电流,当p2口被写“1”时,其管脚被内部上拉电阻拉高,且作为输入。并因此作为输入时,p2口的管脚被外部拉低,将输出电流。这是由于内部上拉的缘故。p2口当用于外部程序存储器或16位地址外部数据存储器进行存取时,p2口输出地址的高八位。在给出地址“1”时,它利用内部上拉优势,当对外部八位地址数据存储器进行读写时,p2口输出其特殊功能寄存器的内容。p2口在flash编程和校验时接收高八位地址信号和控制信号。 p3口:p3口管脚是8个带内部上拉电阻的双向i/o口,可接收输出4个ttl门电流。当p3口写入“1”后,它们被内部上拉为高电平,并用作输入。作为输入,由于外部下拉为低电平,p3口将输出电流(ill)这是由于上拉的缘故。 p3口也可作为at89c51的一些特殊功能口,如下表所示: 口管脚 备选功能 p3.0 rxd(串行输入口) p3.1 txd(串行输出口) p3.2 /int0(外部中断0) p3.3 /int1(外部中断1) p3.4 t0(记时器0外部输入) p3.5 t1(记时器1外部输入) p3.6 /wr(外部数据存储器写选通) p3.7 /rd(外部数据存储器读选通) p3口同时为闪烁编程和编程校验接收一些控制信号。 rst:复位输入。当振荡器复位器件时,要保持rst脚两个机器周期的高电平时间。 ale/prog:当访问外部存储器时,地址锁存允许的输出电平用于锁存地址的地位字节。在flash编程期间,此引脚用于输入编程脉冲。在平时,ale端以不变的频率周期输出正脉冲信号,此频率为振荡器频率的1/6。因此它可用作对外部输出的脉冲或用于定时目的。然而要注意的是:每当用作外部数据存储器时,将跳过一个ale脉冲。如想禁止ale的输出可在sfr8eh地址上置0。此时, ale只有在执行movx,movc指令是ale才起作用。另外,该引脚被略微拉高。如果微处理器在外部执行状态ale禁止,置位无效。 /psen:外部程序存储器的选通信号。在由外部程序存储器取指期间,每个机器周期两次/psen有效。但在访问外部数据存储器时,这两次有效的/psen信号将不出现。 /ea/vpp:当/ea保持低电平时,则在此期间外部程序存储器(0000h-ffffh),不管是否有内部程序存储器。注意加密方式1时,/ea将内部锁定为reset;当/ea端保持高电平时,此间内部程序存储器。在flash编程期间,此引脚也用于施加12v编程电源(vpp)。 xtal1:反向振荡放大器的输入及内部时钟工作电路的输入。 xtal2:来自反向振荡器的输出。at89c51振荡器特性:xtal1和xtal2分别为反向放大器的输入和输出。该反向放大器可以配置为片内振荡器。石晶振荡和陶瓷振荡均可采用。如采用外部时钟源驱动器件,xtal2应不接。有余输入至内部时钟信号要通过一个二分频触发器,因此对外部时钟信号的脉宽无任何要求,但必须保证脉冲的高低电平要求的宽度。2.2译码器模块译码器模块电路如图2-4所示,采用74ls373元器件。引脚如图2-5所示。74ls373是常用的地址锁存器芯片,它实质是一个是带三态缓冲输出的8d触发器,在单片机系统中为了扩展外部存储器,通常需要一块74ls373芯片。74ls373引脚:(1) 1脚是输出使能(oe),是低电平有效,当1脚是高电平时,不管输入3、4、7、8、13、14、17、18如何,也不管11脚(锁存控制端,g)如何,输出2(q0)、5(q1)、6(q2)、9(q3)、12(q4)、15(q5)、16(q6)、19(q7)全部呈现高阻状态(或者叫浮空)。(2)当1脚是低电平时,只要11脚(锁存控制端,g)上出现一个下降沿,输出2(q0)、5(q1)、6(q2)、9(q3)、12(q4)、15(q5)、16(q6)、19(q7)立即呈现输入脚3、4、7、8、13、14、17、18的状态。锁存端le 由高变低时,输出端8 位信息被锁存,直到le 端再次有效。 当三态门使能信号oe为低电平时,三态门导通,允许q0q7输出,oe为高电平时,输出悬空。当74ls373用作地址锁存器时,应使oe为低电平,此时锁存使能端c为高电平时,输出q0q7 状态与输入端d1d7状态相同;当c发生负的跳变时,输入端d0d7 数据锁入q0q7。51单片机的ale信号可以直接与74ls373的c连接。74ls373 的输出端 o0o7 可直接与总线相连。 当三态允许控制端 oe 为低电平时,o0o7 为正常逻辑状态,可用来驱动负载或总线。当 oe 为高电平时,o0o7 呈高阻态,即不驱动总线,也不为总线的负载,但锁存器内部的逻辑操作不受影响。 当锁存允许端 le 为高电平时,o 随数据 d 而变。当 le 为低电平时,o 被锁存在已建立的数据电平。当 le 端施密特触发器的输入滞后作用,使交流和直流噪声抗扰度被改善 400mv。 引出端符号: d0d7 数据输入端 oe 三态允许控制端(低电平有效) le 锁存允许端 o0o7 输出端 74ls373真值表如下: dnleoeonhhlhlhllxllq0xxh高阻态图2-4译码器模块电路2.3扩展模块扩展模块电路如图2-6所示,采用8255元器件。引脚如图2-7所示。8255概述:8255是intel公司生产的可编程并行i/o接口芯片,有3个8位并行i/o口。具有3个通道3种工作方式的可编程并行接口芯片(40引脚)。 其各口功能可由软件选择,使用灵活,通用性强。8255可作为单片机与多种外设连接时的中间接口电路。 8255作为主机与外设的连接芯片,必须提供与主机相连的3个总线接口,即数据线、地址线、控制线接口。同时必须具有与外设连接的接口a、b、c口。由于8255可编程,所以必须具有逻辑控制部分,因而8255内部结构分为3个部分:与cpu连接部分、与外设连接部分、控制部分。 8255引脚功能:reset:复位输入线,当该输入端处于高电平时,所有内部寄存器(包括控制寄存器)均被清除,所有i/o口均被置成输入方式。 cs:芯片选择信号线,当这个输入引脚为低电平时,即/cs=0时,表示芯片被选中,允许8255与cpu进行通讯;cs=1时,8255无法与cpu做数据传输. rd:读信号线,当这个输入引脚为低电平时,即/rd=0且/cs=0时,允许8255通过数据总线向cpu发送数据或状态信息,即cpu从8255读取信息或数据。 wr:写入信号,当这个输入引脚为低电平时,即/wr=0且/cs=0时,允许cpu将数据或控制字写入8255。 d0d7:三态双向数据总线,8255与cpu数据传送的通道,当cpu 执行输入输出指令时,通过它实现8位数据的读/写操作,控制字和状态信息也通过数据总线传送。 pa0pa7:端口a输入输出线,一个8位的数据输出锁存器/缓冲器, 一个8位的数据输入锁存器。 pb0pb7:端口b输入输出线,一个8位的i/o锁存器, 一个8位的输入输出缓冲器。 pc0pc7:端口c输入输出线,一个8位的数据输出锁存器/缓冲器, 一个8位的数据输入缓冲器。端口c可以通过工作方式设定而分成2个4位的端口, 每个4位的端口包含一个4位的锁存器,分别与端口a和端口b配合使用,可作为控制信号输出或状态信号输入端口。 a1,a0:地址选择线,用来选择8255的pa口,pb口,pc口和控制寄存器。 当a1=0,a0=0时,pa口被选择 当a1=0,a0=1时,pb口被选择 当a1=1,a0=0时,pc口被选择当a1=1,a0=1时,控制寄存器被选择图2-6扩展模块电路8255a的编程控制字2.4光电隔离驱动模块光电隔离驱动模块电路如图2-7所示。过程通道是系统输入、输出以及单片机之间进行信息传输的途径。抑制过程通道的干扰主要是采用观点隔离技术。光电耦合器(optical coupler,英文缩写为oc)亦称光耦合器,简称光耦。光耦合器以光为媒介传输电信号。它对输入、输出电信号有良好的隔离作用,所以,它在各种电路中得到广泛的应用。目前它已成为种类最多、用途最广的光电器件之一。光耦合器一般由三部分组成:光的发射、光的接收及信号放大。输入的电信号驱动发光二极管(led),使之发出一定波长的光,被光探测器接收而产生光电流,再经过进一步放大后输出。这就完成了电光电的转换,从而起到输入、输出、隔离的作用。由于光耦合器输入输出间互相隔离,电信号传输具有单向性等特点,因而具有良好的电绝缘能力和抗干扰能力。又由于光耦合器的输入端属于电流型工作的低阻元件,因而具有很强的共模抑制能力。所以,它在长线传输信息中作为终端隔离元件可以大大提高信噪比。在计算机数字通信及实时控制中作为信号隔离的接口器件,可以大大增加计算机工作的可靠性。 光耦合器的主要优点是:信号单向传输,输入端与输出端完全实现了电气隔离,输出信号对输入端无影响,抗干扰能力强,工作稳定,无触点,使用寿命长,传输效率高。光耦合器是70年代发展起来产新型器件,现已广泛用于电气绝缘、电平转换、级间耦合、驱动电路、开关电路、斩波器、多谐振荡器、信号隔离、级间隔离 、脉冲放大电路、数字仪表、远距离信号传输、脉冲放大、固态继电器(ssr)、仪器仪表、通信设备及微机接口中。在单片开关电源中,利用线性光耦合器可构成光耦反馈电路,通过调节控制端电流来改变占空比,达到精密。光电隔离的实现:1、adc、dac通常采用将adc、dac与单片机之间的电气联系切断。(1)对a/d、d/a变换前后的模拟信号进行隔离,是常用的一种方法。(2)在i/o与a/d、d/a之间进行数字隔离图2-7光电隔离驱动模块电路2、开关量隔离常用的开关量隔离器件有继电器、光电隔离器、光电隔离固态继电器。用继电器对开光量进行隔离时,要考虑到继电器线包的反电动势的影响,驱动电路的器件必须能耐高压。为了吸收继电器线包的反电动势,通常在线包两端并联一个二极管。对于开关量的输入,一般用电流传输的方法。3、分页说明系统软件说明i/o口扩展与应用的控制系统主要分为

温馨提示

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

评论

0/150

提交评论