单片机与PC机串行通信的毕业论文设计(共34页)_第1页
单片机与PC机串行通信的毕业论文设计(共34页)_第2页
单片机与PC机串行通信的毕业论文设计(共34页)_第3页
单片机与PC机串行通信的毕业论文设计(共34页)_第4页
单片机与PC机串行通信的毕业论文设计(共34页)_第5页
已阅读5页,还剩33页未读 继续免费阅读

下载本文档

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

文档简介

1、安徽矿业职业技术学院2015届毕业设计(论文)第 PAGE 38页,共 NUMPAGES 38页安徽矿业职业技术学院毕业(b y)课题(设计)题 目 单片机与PC串行通信(tng xn)设计 指导(zhdo)教师 陈玉宝 院 系 自动化与信息工程系 班 级 电气自动化1201 学 号 125802020120 姓 名 吴科良 二一五年六月二日安徽矿业职业(zhy)技术学院毕业(b y)课题(kt)(设计)任务书(2012届)题 目 单片机与PC串行通信设计 指导教师 陈玉宝 院 系 自动化与信息工程系 专 业 电气自动化专业 班 级 电气自动化1201 学 号 125802020120 姓 名

2、 吴科良 2014年10月1日至2015 年6月3日论文(设计(shj))方向:一、主要(zhyo)参考资料王福瑞单片微机测控系统设计大全(d qun)M北京:北京航空航天大学出版社,199806李华MCS一51系列单片机实用接口技术M北京:北京航空航天大学出版社,199307李朝青PC机与单片机&DSP数据通信技术选编(1)M北京:北京航空航天大学出版社,200312刘金伍单片机应用与实践M北京:北京航空航天大学出版社,199508课题的内容和任务要求:主要内容:该设计主要采用了AT89C51单片机与PC机的控制系统的基本知识,来完成单片机与PC机的串行通信原理。任务要求:具体可实现由AT8

3、9C51单片机发送数据(由LCD显示),PC做接收且屏幕显示;也可由PC发送数据,由8051接收并显示至LCD三、毕业论文(b y ln wn)(设计)进度安排:起 讫 日 期工 作 内 容备 注101-10.20查阅资料,完成开题报告10.25-11.20调查并完成毕业设计课题设计任务前期检查11.22-12.30熟悉系统软件的环境1.1-1.20控制平台的建立,分析和实验及程序调试2.1-5.22与同学讨论并请教专业人员中期检查6.1-6.3完成毕业设计请指导老师点评学生(签名): 年 月 日指导教师(签名): 年 月 日系毕业设计(论文)工作指导小组意见:组长(签名) 年 月 日 系毕业

4、论文工作领导小组审核意见:主管领导(签名) 年 月 日 注:1.指导教师填写,任务下达人为指导教师,指导教师和接受任务的学生(xu sheng)均应签字。2.此任务书最迟必须在学生毕业设计(论文(lnwn))开始前下达给学生。安徽矿业职业(zhy)技术学院毕业(b y)课题(kt)(设计)开 题 报 告 (2012届)题 目 单片机与PC串行通信设计 指导教师 陈玉宝 院 系 自动化与信息工程系 班 级 电气自动化1201 学 号 125802020120 姓 名 吴科良 二一五年六月二日一、选题(xun t)的意义目前,随着集成电路集成度的增加,电子计算机向微型化和超微型化方向发展,为了提高

5、系统管理的先进性和安全性,计算机工业自动控制和监测系统越来越多地采用集总分算系统。较为常见的形式是由一台做管理用的上位主计算机(主机)和一台直接参与控制检测的下位机(单片机)构成的主从式系统,主机和从机之间以通讯的方式来协调工作。主机的作用一是要向从机发送各种命令及参数:二是要及时收集、整理和分析从机发回的数据,供进一步的决策和报表。从机被动地接受、执行主机发来的命令,并且根据主机的要求(yoqi)向主机回传相应烦人实时数据,报告其运行状态。二、研究的主要内容,拟解决的主要问题(阐述(chnsh)的主要观点)用串行总线技术可以使系统的硬件设计大大简化、系统的体积减小、可靠性提高。同时,系统的更

6、改和扩充极为容易。提高工作的效率。毕业论文(设计)思路系统结构图单片机键盘LCD串行通信电平转换接口PC发声电路四、毕业论文(设计)提纲1、总体设计方案2、器件(qjin)原理3、控制系统(kn zh x tn)设计原则和设计步骤/4、结论(jiln)与结果五、主要参考文献1王福瑞单片微机测控系统设计大全M北京:北京航空航天大学出版社,1998062李华MCS一51系列单片机实用接口技术M北京:北京航空航天大学出版社,1993073李朝青PC机与单片机&DSP数据通信技术选编(1)M北京:北京航空航天大学出版社,2003124刘金伍单片机应用与实践M北京:北京航空航天大学出版社,1995085

7、刘大茂智能仪器:单片机应用系统设计M北京:机械工业出版社,1998046万福君,潘松峰单片微机原理系统设计与应用M合肥:中国科学技术大学出版社,2001017美安格斯生串行端口大全M精英科技译北京:中国电力出版社,200101指导教师意见:签名: 年 月 日系毕业设计(论文)工作指导小组意见: 签名:年 月 日系毕业设计(论文)工作领导小组意见:签名:年 月 日摘 要AT89C51是一款高性能的8位单片微型计算机,它采用了CMOS工艺和ATMEL公司的高密度NVRAMUII(易失性随机存储器)技术,片内带有一个(y )4KB的FLASH FPROM(可擦除、可编程只读存储器),作为INTEL8

8、051的换代产品,其输出引脚和指令系统与MCS一51完全兼容。由于AT89C51 单片机具有集成度高、面向控制、系统结构简单、价格便宜等诸多优点,因而在智能化仪器仪表、数据采集、数据测量等方面有着广泛的应用。但是,实际应用中单片机在数据处理能力(nngl)、人机交互等方面往往不能满足要求,因而通常用PC来弥补单片机的这些不足。例如,在工程应用中,常常由一台PC机和一台单片机构成主从式计算机测控系统。在这样的系统中,以单片机为核心的智能测控仪表(从机)作为现场测控设备,完成数据的采集、处理和控制各种任务,同时将数据传给PC机(主机),PC机将这些数据加工处理后,进行显示、打印报表等,PC机也可以

9、将各种控制命令传送给单片机,干预单片机系统的运行,从而发挥PC机的优势。随着单片机和微机技术的不断发展,特别是网络技术在测控领域的广泛应用,由PC机和多台单片机构成的多机网络测控系统已成为单片机技术发展的一个方向。它结合了单片机在实时数据采集和微机对图形处理、显示的优点。同时,windows环境下后台(huti)微机在数据库管理上具有明显的优势。二者结合,使得单片机的应用已不仅仅局限于传统意义上的自动监测或控制,而形成了向以网络为核心的分布式多点系统发展的趋势。关键词:LED PC 单片机AT89C51 串行通信 串行口目 录1、本文的设计(shj)目标11 1.1总体方案设计(shj)112

10、、硬件(yn jin)电路设计112.1 单片机AT89C5112 2.2 LCM1601原理172.3 44行列式扫描键盘18 2.4 音频功率放大器件LM38618 2.5 RS-232电平转换器件Max232183部分器件的原理分析193.1 键盘扫描的工作原理 193.2 按键发声原理204单片机软件设计214.1 CM1601软件子程序设计214.2串口通信子程序设计224.3 键盘扫描子程序设计 264.4 按键发声子程序的设计 275软硬件调试及结果 295.1 软件仿真 295.2调试 295.3结果 296、结论30参考文献31致谢(zh xi)321、本文的设计(shj)目

11、标本设计是基于MSP430F149和PC机串口通讯。在硬件上要想与PC 串口或者其它带有串口的终端设备相连接,必须要进行EIA-RS-232-C 与MSP430 电平和逻辑关系的转换,本设计采用MAX3232芯片(xn pin),完成3V5V 电平与串口电平的双向转换;本设计依据MSP430F149的串行通信模块的构成,利用其异步通信模式的特点,按照位寻址的方式设计的通信协议11总体方案设计单片机键盘LCD串行通信电平转换接口PC发声电路硬件由单片机89C51、11.059M晶振,30PF电容、22uf/25V电容、10uf/25V电容10K电阻、LCM1601、44键盘、LM386、蜂鸣器、

12、按键、Max232组成。具体可实现由AT89C51键盘(P1)发送数据(由LCD显示),PC做接收且屏幕显示该值;也可由PC键盘发送数据,由8051接收并显示至LCD。系统结构如图1-1所示。图1-1 系统结构图LCD:系统显示界面采用LCM1601,一行16字符的液晶显示模块,显示AT89C51接收或PC发来的数据。键盘:输入按键采用4行4列非编码矩阵键盘,配合液晶界面用于和PC机通信。发声电路:发声电路采用LM386作为音频放大电路,在有按键按下的时候会发出相应的按键音。串行通信电平转换(zhunhun)接口:AT89C51与PC间的串行数据通信采用(ciyng)的是最简单(jindn)的

13、TxD,RxD,GND三线制连接,从单片机TX和RX端CMOS电平到PC的标准RS-232电平的转换器件选用Maxim的Max232。2硬件电路设计总电路图见附录C。2.1 单片机AT89C51AT89C51是一种带4K字节闪烁可编程可擦除只读存储器(FPEROMFalsh Programmable and Erasable Read Only Memory)的低电压,高性能CMOS8位微处理器,俗称单片机。该器件采用ATMEL高密度非易失存储器制造技术制造,与工业标准的MCS-51指令集和输出管脚相兼容。由于将多功能8位CPU和闪烁存储器组合在单个芯片中,ATMEL的AT89C51是一种高效

14、微控制器,为很多嵌入式控制系统提供了一种灵活性高且价廉的方案。AT89C51的管脚图如图2-1所示。 图2-1 AT89C51的管脚图主要特性:与MCS-51 兼容 4K字节可编程闪烁存储器 寿命:1000写/擦循环数据保留时间:10年全静态工作:0Hz-24Hz三级程序存储器锁定128*8位内部RAM32可编程I/O线两个16位定时器/计数器5个中断源可编程串行通道低功耗的闲置和掉电模式片内振荡器和时钟(shzhng)电路 管脚说明(shumng):VCC:供电(n din)电压。 GND:接地。P0口:P0口为一个8位漏级开路双向I/O口,每脚可吸收8TTL门电流。当P1口的管脚第一次写1

15、时,被定义为高阻输入。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”时,其管脚被内部上拉电阻拉高,且作

16、为输入。并因此作为输入时,P2口的管脚被外部拉低,将输出电流。这是由于内部上拉的缘故。P2口当用于外部程序存储器或16位地址外部数据存储器进行存取时,P2口输出地址的高八位。在给出地址“1”时,它利用内部上拉优势,当对外部八位地址数据存储器进行读写时,P2口输出其特殊功能寄存器的内容。P2口在FLASH编程和校验时接收高八位地址信号和控制信号。P3口:P3口管脚是8个带内部上拉电阻的双向I/O口,可接收输出4个TTL门电流。当P3口写入“1”后,它们被内部上拉为高电平,并用作输入。作为输入,由于外部下拉为低电平,P3口将输出电流(ILL)这是由于上拉的缘故。 P3口也可作为AT89C51的一些

17、特殊功能口,如表2-1所示:表2-1 P3口的一些特殊功能口口管脚 备选功能P3.0 RXD(串行输入口)P3.1TXD(串行输出口)P3.2 /INT0(外部中断0)P3.3 /INT1(外部中断1)P3.4 T0(记时器0外部输入)P3.5T1(记时器1外部输入)P3.6 /WR(外部数据存储器写选通)P3.7/RD(外部数据存储器读选通)P3口同时为闪烁编程和编程校验接收一些控制信号。RST:复位(f wi)输入。当振荡器复位器件时,要保持RST脚两个机器周期的高电平时间。ALE/PROG:当访问外部(wib)存储器时,地址锁存允许的输出电平用于锁存地址的地位字节。在FLASH编程期间,

18、此引脚用于输入编程脉冲。在平时,ALE端以不变的频率周期输出正脉冲信号,此频率为振荡器频率的1/6。因此它可用作对外部输出的脉冲或用于定时目的。然而要注意的是:每当用作外部数据存储器时,将跳过一个ALE脉冲。如想禁止ALE的输出可在SFR8EH地址上置0。此时, ALE只有在执行MOVX,MOVC指令是ALE才起作用。另外,该引脚被略微拉高。如果微处理器在外部执行状态ALE禁止,置位无效。/PSEN:外部程序存储器的选通信号。在由外部程序存储器取指期间,每个机器周期两次/PSEN有效(yuxio)。但在访问外部数据存储器时,这两次有效的/PSEN信号将不出现。/EA/VPP:当/EA保持低电平

19、时,则在此期间外部程序存储器(0000H-FFFFH),不管是否有内部程序存储器。注意加密方式1时,/EA将内部锁定为RESET;当/EA端保持高电平时,此间内部程序存储器。在FLASH编程期间,此引脚也用于施加12V编程电源(VPP)。XTAL1:反向振荡放大器的输入及内部时钟工作电路的输入。XTAL2:来自反向振荡器的输出。AT89C51的时序:AT89C51的振荡器输入分别有引脚19(XTAL1)和引脚18(XTAL2)来完成。只要将这两个引脚接石英晶体和陶瓷电容,如图图2-2所示,就可以与CPU内部组成完整的振荡电路。AT89C51的一个机器周期含有6个状态周期,而每个状态周期为2个振

20、荡周期,因此一个机器周期共有12个振荡周期,如振荡器的频率为12MHZ,一个振荡器周期为1/12微秒,而一个机器周期为1微秒。CXTAL11918石英晶体XTAL2AT89C51C图2-2 AT89C51的振荡电路在本设计中石英晶体的频率为11.0592MHZ,陶瓷电容的取值为30PF。AT89C51的复位(f wi):单片机微处理器的复位都是以外部电路(dinl)来执行的,在CLOCK工作(gngzu)后,只要在RESET引脚上接上10MS以上的高电平,单片机微处理器便执行状态复位。寄存器的复位单片机在RESET为高电平控制下,程序计数器(PC)和特殊功能寄存器的复位如表2-2所示。单片机的

21、复位并不影响芯片内部RAM状态,只要RESET引脚保持高电平,单片机将循环复位。在复位有效期内,ALE,PSEN将输出高电平。表2-2寄存器复位后的状态寄存器复位状态寄存器复位状态PC0000HTMOD00HACC00HTCON00HB00HTH000HPSW00HTL000HSP07HTH100HDPTR0000HTL100HP0P3FFHSCON00HIP(00000)SBUF()IE(000000)PCON(00000)二、复位电路简单复位电路中,干扰易串入复位端,在大多数情况下不会造成单片机的错误复位,但会引起内部某些寄存器的错误复位,可以在RESET引脚上接上一个去耦电容。为了保证复

22、位电路的可靠性,常将RC电路接斯密特电路后再接入单片机和外围IC的RESET引脚,如图2-3所示。图2-3 AT89C51的复位电路AT89C51的串行口:(1)基本概念数据通信的传输方式:常用于数据通信的传输方式有单工、半双工、全双工和多工方式。A单工方式:数据仅按一个固定的方向传送。因为这种传输方式的用途(yngt)有限,常用于串行口的打印数据传输与简单系统间的数据采集。B双工方式:数据可以实现双向传送(chun sn),但不能同时进行,实际的应用采用某种协议实现收发开关转换。C全双工方式:允许双方同时进行数据(shj)双向传送,但一般全双工电路的线路和设备比较复杂。D多工方式:以上三种传

23、输方式都是同一线路传输一种频率信号,为了充分的利用线路资源,可通过使用多路复用器或多路集线器,采用频分、时分、或码分复用技术,即可实现在同一线路上资源共享功能,我们称之为多工传输方式。串行通信的两种通信形式A. 异步通信 在这种通信方式中,接收器和发射器有各自的时钟,他们的工作是非同步的,异步通信用一帧来表示一个字符,其内容如下:一个起始位,紧接着是若干个数据位,图 是传输45H的数据格式。B.同步通信 同步通信格式中,发送器和接收器由同一个时钟源控制,为了克服在异步传输中,每传输一帧字符都必须加上起始位和停止位,占用了传输时间,在要求传送的数据量较大的(2)MCS-51的串行和控制寄存器MC

24、S-51单片机串行口专用寄存器的SBUF为串行口的收发缓冲器,它是一个可寻址的专用寄存器,其中包含了接收器和发射器寄存器,可以实现全双工通信。但这两个寄存器具有同一地址(99H)。MCS-51的串行数据传输很简单,只要向缓冲器写入数据就可发送数据。而从接收缓冲器读出数据既可接收数据。此外,接收缓冲器前还加上一级输入移位寄存器,MCS-51这种结构的目的在于接收数据时避免发生重叠现象,文献称这种结构为双缓冲结构。而发送数据就不需要这样设计,因为发送时,CPU是主动的,不可能出现这种情况。串行通信控制寄存器(SCON),它是一个可寻址的专用寄存器,用于串行数据通信的控制,单元地址是98H,其结构格

25、式如表2-3所示。表2-3 SCON寄存器结构SCOND7D6D5D4D3D2D1D0SM0SM1SM2RENTB8RB8TIRI位地址9FH9EH8DH9CH9BH9AH99H98H下面(xi mian)我们对SCON控制位功能(gngnng)介绍如表2-4所示。1)SM0、SM1:串行口工作(gngzu)方式控制位表2-4 SCON控制位功能介绍SM0SM1工作方式功能说明00方式0移位寄存器方式(用于I/O扩展)01方式18位UART,波特率可变(T1溢出率/n)10方式29位UART,波特率为fosc/64或fosc/3211方式39位UART,波特率可变(T1溢出率/ n)2)SM2

26、:多机通信控制位多机通信是工作方式2和方式3,SM2位主要用于方式2和方式3。接收状态,当串行口工作方式2或3,以及SM2=1时,只有当接收到第9位数据(RB8)为1时,才把接收的前8位数据送入SBUF,且置位RI发出中断申请,否则会将收到的数据放弃。当SM2=0时,只有在接收到有效停止位时才启动RI,若没接收到有效停止位,则RI清“0”。在方式0中SM2应该为“0”。REN:允许接收控制位。由软件置“1”时,允许接收;软件置“0”时,不许接收。TB8:在方式3和方式3中要发送的第9位数据,需要时用软件置位和清零。TB8:在方式2和方式3中是接收到的第9位数据。在方式1时,如SM2=0,RB8

27、接收到的停止位。在方式0中,不使用RB8。TI:发送中断标志。由硬件在方式0发送完第8位时置“1”,或在其它方式中串行发送停止位的开始时置“1”。必须由软件清“0”。RI:接收中断标志。由硬件在方式0串行发射第8位结束时置“1”B:特殊功能寄存器PCONPCON:主要是是CHMOS型单片机的电源控制而设置的专用寄存器,单元地址为87H其机构格式如表2-5所示。表2-5 特殊功能寄存器PCONPCOND7D6D5D4D3D2D1D0位符号SMODGF1GF0PDIDL在CHMOS型单片机中,除SMOD位外其它位均为虚设的,SMOD是串行波特率倍增位,当SMOD=1时串行口波特率加倍,系统复位默认

28、为SMOD=0。这里重述一下中断允许寄存器IE对串行口有影响的位ES。ES为串行中断允许控制位,ES=1允许串行中断,ES=0,禁止串行中断。如表2-6所示。表2-6 中断允许寄存器符号EAESET1EX1ETOEX0位地址AFHAEHADHACHABHAAHA8HA8H(3)串行口工作方式串行口具有4种工作方式,我从应用和毕业设计的角度,重点讨论方式1发送。串行口定义为方式1时传送1帧数据为10位,其中1位起始地址、8位数据位(先低位后高位)、1位停止位方式1的波特率可变,波特率=(T1的溢出率)2.2 LCM1601原理LCM1601是一款兼容(jin rn)的液晶显示模块,支持57点阵(

29、din zhn)和16字2行符两种模式,背光亮度和显示对比度可调,是一种功能较简易、价格较便宜的液晶显示器件。它由液晶显示屏和驱动器两部分组成(z chn),单片机通过写控制字方式访问它的驱动器来实现对显示屏的控制。图2-4所示为LCM1601封装图。图2-4 LCM1601封装图器件封装为单列DIP16,引脚定义如表2-7所示。表2-7 LCM1601引脚说明编号标示引脚说明1VSS电源地2VDD电源正极3V0液晶显示偏压4RS指令/数据选择端(H/L)5R/W读/写选择端6E使能信号7D08位数据总线8D19D210D311D412D513D614D715LED+背光源正极16LED-背光

30、源负极2.3 44行列式扫描键盘简易的行列式键盘不需要借助其他的I/O扩展芯片,直接占用P1的8条口线,再利用单片机内部的软件来配合实现4 4扫描键盘,其特点是简单且不增加成本,通常在系统I/O线充裕的情况下采用。2.4 音频功率放大器件LM386LM386的接脚图如图2-8所示。LM386是专为低损耗电源所设计的功率放大器。它的内建增益为20,透过pin 1 和pin8脚位间电容的搭配,增益最高可达200。LM386输入电压范围可由4V12V,无作动时仅消耗4mA电流,且失真低。图2-8 接脚图2.5 RS-232电平转换(zhunhun)器件Max232MAX232芯片(xn pin)是M

31、AXIM 公司(n s)生产的,包含两路接收器和驱动器的IC芯片。MAX232芯片内部有一个电源电压转换器,可以把输入的+5V 电压变换为RS-232输出电平所需的一1O+ 10V 电压。所以采用此芯片接口串行通信系统只需单一的+5V电源就可以了。其价格适中,硬件接口简单,所以被广泛采用。图2-9所示为Max232的封装图。图 2-9 Max232封装图引脚说明如表2-8所示。表2-8 Max232引脚说明VCC供电电压GND地C+、C-外围电容T1IN第一路TTL/CMOS驱动电平输入T1OUT第一路RS-232电平输出R1IN第一路RS-232电平输入R1OUT第一路TTL/CMOS驱动电

32、平输出T2IN第二路TTL/CMOS驱动电平输入T2OUT第二路RS-232电平输出R2IN第二路RS-232电平输入R2OUT第二路TTL/CMOS驱动电平输出3部分(b fen)器件(qjin)的原理(yunl)分析3.1 键盘扫描的工作原理简易的行列式键盘不需要借助其他的I/O扩展芯片,直接占用P1的8条口线,再利用单片机内部的软件来配合实现4行4列的扫描键盘,其特点是简单且不增加成本,通常在系统I/O线充裕的情况下采用。其原理图如图3-1所示。图3-1原理图工作原理:I/O口P2.7P2.1充当列选线,P2.3P2.1充当行选线。在键盘开始扫描的时候,首先向P2口赋行扫描初值7FH,令

33、第一行(P2.3)为0,从第一行开始检测。接下来检测第一行的第一列是否键按下?没有按下,则检测第二列,如果4列扫描完毕,没有键按下,则扫描下一行,如此往复,直至4行4列检测完毕。当有键按下时,相应的列选线电平被拉低,首先扫描行选线,确定按键的行号,然后扫描列选线,确定列号,则按键的编号即可确定。3.2 按键发声原理要产生音频脉冲,只要算出某一音频的周期,然后将此周期除以2,即为半周期的时间,利用定时器计时这个半周期时间,每当计时到后就将输出脉冲的I/O反相,然后重复计时此半周期时间再对I/O反相,就可在I/O引脚上得到此频率的脉冲。计数脉冲值与频率的关系公式如下:N=Fi2FrN:计数值;Fi

34、:内部计时一次为1us,故其频率为1MHZ;Fr:要产生的频率。其计数值的求法如下:T=65536-N=65536-Fi2Fr表3-1是各按键音符的频率与计数值T的对照表。表3-1 各按键音符频率(pnl)与计数值T的对照表键值音符频率(HZ)简谱码(T值)键值音符频率(HZ)简谱码(T值)0低3M330640218中4FA698648201低4FA349641039中5SO784648982低5SO39264260A中6LA880649683低6LA44064400B中7SI988650304低7SI49464524C高1D0946650585中1D052364580D高2RE1175651

35、106中2RE58764684E高3M1318651577中3M65964777F高4FA1397651784单片机软件设计程序流程图是编写软件的重要前提,它是在图表上直观(zhgun)的体现拟设计的目的及过程。也是编译的重要依据,按照流程图一步一步编写程序,单片机软件(run jin)主程序流程图如图4-1所示。是否否是开始LCD初始化设置串口初始化收到数据?检测按键输入读入键值转换成键码串口发送键码LCD显示并发声接收数据送LCD显示图4-1主程序流程图4.1 CM1601软件(run jin)子程序设计(chn x sh j)LCD1601是通用(tngyng)的点阵型液晶模块,分4位和

36、8位数据传输方式。提供5X7点阵光标和5X10点阵光标的显示模式。除带有驱动IC外,还自带液晶显示控制IC,其本身就是一个能够接受指令,自动控制液晶显示的单片微机子系统。因此,通过软件编程,就可以实现对LCM1601的操作。编程时要求CPU每一次访问都要先对忙标志BF进行识别,当BF=0时,即LDC允许CPU访问时,再进行下一步的操作。操作程序如下:4.2.1写指令 ENABLE: MOVP1,#0FFH;令P1=FFHCLRRS;RS=0,R/W=1,读BUSY FLAG地址计数器SETBRWCLRENOPSETBEJBP1.7,ENABLE;BUSY FLAG=0?CLRRS;RS=0,R

37、/W=0写入指令(zhlng)组CLRRWCLRECALLDELAYSETBERET4.2.2写数据(shj)WRITE1:MOVR1,#00H;显示(xinsh)TABLE表的值 A3:MOVA,R1;至TABLE取码MOVCA,A+DPTRCALLWRITE2;显示至LCDINCR1CJNEA,#00H,A3;是否取到“00H”结束码?RETWRITE2:MOVP1,A;显示数据送至P1SETBRS;RS=1,R/W=0写入数据寄存器显示CLRRWCLRECALLDELAYSETBERET4.2.3 LCD1601初始化MOVP1,#01H;清除屏幕CALLENABLEMOVP1,#38H

38、;功能设定(8位,2行,57点矩阵)CALLENABLEMOVP1,#08H;显示器ON,光标ON,闪烁ONCALLENABLEMOVP1,#06H;光标右移CALLENABLEMOVP1,#80H ;令光标回到第一行第一个字位置CALLENABLE4.2串口通信子程序设计AT89C51的串行口是全双工的UART,它可同时发送和接收数据,是使用特殊寄存器内的SBUF寄存器及SCON串行控制寄存器,如表4-1所示。表4-1 SCON串行控制寄存器RI:接收中断标志位。在模式0下,当第8位结束时,硬件会将其设为1;在其他模式下,在停止位的开始时有硬件设定,次位必须由软件(run jin)清除。TI

39、:发送中断标志位。在模式0下,当第8位结束时,硬件会将其设为1;在其他模式下,在停止(tngzh)位的开始时由硬件设定,次位必由软件清除。RB8:在模式2或3时,发送的第9位放入次位。在模式1时,若SM2=0,则RB8为接收(jishu)到的停止位。模式0时,RB8没作用。TB8:在模式2或3时,发送时的第9位数据位由软件控制。REN:由软件设定或清除,以决定是否接收串行输入数据,REN=1,接收;REN=0,发送。SM2:当串行口为模式2或3时,使能多处理器通信的功能。在模式2或3时,如果SM2=1,则当接收到第9位数据为0时,RI不动作。在模式1时,若SM2=1,当接收到的停止位不正确时,

40、RI也不动作。在模式0时,SM2必须为0。SM1:串行口模式选择。SM0:串行口模式选择。UART共有四种工作方式,MODE0可发送或接收8位的数据;MODE1可发送或接收10的数据;MODE2K可发送或接收11的数据;MODE3与 MODE2的功能几乎完全一样,不同的是MODE2的发送速率固定,而MODE3是可变的。现在就本文中用到的MODE1作一重点介绍。MODE1其设定如下:MOVSCON,#00000000B;发送数据工作方式JBCTI,LOOP;发送是否完毕?是则跳至LOOP,并清除TI=0MOVSCON,#00010000B;接收数据工作方式JBCRI,LOOP;接收是否完毕?是则

41、跳至LOOP,并清除RI=0MODE0KE可发送或接收11位的数据,此10个位分别是1个起始位、8个数据位和1个停止位。MODE1发送数据的速度(称为波特率)是可变的,由TIMER1或TIMER2控制且最好工作在MODE2(自动载入模式),这样只要设定TH1一次即可。当UART接收(RXD引脚)到一个字节的数据后,会使SCON寄存器内的RI位设定为1,CPU只要检查RI=1就可知道UART已接收到数据。若数据通过UART输出时(TXD引脚),在8个位输出完毕后,SCON寄存器内的TI位会被设为1,CPU只要检查到TI=1就可知道可以再发送下一个字节。控制波特率的寄存器为PCON,如表4-2所示

42、。说明如下:PCON:电源控制寄存器(POWER CONTROL REGISTER)。表 4-2 电源控制寄存器SOMD:双倍波特率位。当串行工作于模式(msh)1、2或3时,如使用TIMER1做波特率发生器,且SMOD=1则波特率为双倍。:保留(boli)位。GF1:一般用途,对于AT89系列,GF1为通用(tngyng)标志位。GF0:一般用途,对于AT89系列,GF0为通用标志位。PD:电源下降位,对于AT89系列,PD为1时进入掉电状态。IDL:IDLE模式位,对于AT89系列,IDL为1是进入空闲工作方式。注意:PD和IDLE同时为1时,PD较优先。其设定方式如下:设定波特率:MOV

43、TMOD,#00100000B;设定TIMER1的MODE2ANLPCON,#01111110B;设SMOD=0或ORLPCON,#10000000B;设SMOD=1MOVTH1,#0FDH;设定TIMER1的计数值SETBTR1;启动TIMER1(2)设定UART工作方式MOVSCON,#01010000B;MODE1做接收,REN=1JBCRI,LOOP2或MOVSCON,#0100000B;MODE做发送,REN=0JBCTI,LOOP2波特率的计算:MODE0的波特率=振荡器频率12振荡频率=12MHZ波特率=1MHZMODE2的波特率=(2/64)振荡频率振荡频率=12MHZSMOD

44、=0BAUD=187.5KHZSMOD=1BAUD=375KHZMODE1和MODE3:利用TIMER工作在MODE2模式(自动载入)产生的波特率为(2/32)振荡频率/(12(256-TH1)常用的各种波特率如表4-2-3所示。表4-3 常用(chn yn)的各种波特率波特率(bit/s)Fosc(MHZ)SMODTimer1C/T模式自动载入480012102F3H240012002F3H120012102F6H1920011.059102FDH960011.059002FDH480011.059002FAH240011.059002F4H120011.059002F8HUART的中断(z

45、hngdun)要求:其中断要求有两种方式:(1)当UART的接收器(RXD)接收到一个字节的数据且将其存入(cn r)SBUF寄存器后,就会将RI设定为1,而对AT89C51提出中断要求。(2)当UART的发送器将SBUF寄存器的8个位数据发送出去后,会将TI设定为1。UART中断要求设定的步骤:1.设定UART中断起始地址。ORG23HJMPUART2.设定TIMER1工作在MODE2MOVTMOD,#00100000B3.设定波特率为2400ANLPCON,#01111111BMOVTH1,#0F3H4.启动计时器SETBTRX5.设定UART工作方式MOVSCON,#010000B3.设

46、定UART中断功能MOVIE,#10010000B4.3 键盘(jinpn)扫描子程序设计键盘扫描(somio)的步骤:(1)设置(shzh)P1口初始值07FH;(2)P1口右移,检测行;(3)P1口左移,检测列;流程图如图4-2所示。键盘接口程序如下: MOVR3,#0F7H;扫描初值(P2.3=0)MOVR1,#00H;取码指针初值D3:MOVA,R3;载入扫描指针MOVP2,A;输出至P2,开始扫描行MOVA,P2;读入P2CLRCCPLC;令C=1MOVR5,#04H;检测列D4:RLCA;左移一位(P2.7P2.4)JNCKEYIN;检测行C=0,表示被按INCR1;没按则取码指针

47、加1DJNZR5,D4;4列检测完毕了?MOVA,R3CLRCCPLC;C=1RRCA;扫描下一行,即下一行为0MOVR3,A;存回R3扫描指针寄存器 图4-2 读键输入子程序框图JCD3;C=0表示扫描完毕RETKEYIN:MOV22H,R1;取码指针(zhzhn)存入22H地址MOVR7,#10;消除(xioch)抖动D5:MOVR6,#248DJNZR6,$DJNZR7,D5D6:MOVA,P2;按钮放开(fn ki)否?XRLA,R4 4.4 按键发声子程序的设计按键发声子程序框图如图4-3所示。 图4-3按键发声子程序框图程序如下:ORG00H;主程序其始地址JMPSTART;跳至主

48、程序 ORG0BH;TIMER0中断其始地址JMPTIM0;跳至TIMER0中断子程序START:MOVTMOD,#00000001B;设定TIMER0工作在MODE1MOVIE,#10000010B;中断使能SETBTR0;启动TIMER0D1:CALLKEY;调用KEY,判断是否有按下?CLREA;中断屏蔽 JBF0,D1;没按则F0=1,没按则F0=0MOVA,22H;有按则将取码指针暂存地址的值载入ARLA;乘2MOVDPTR,#TABLE;至TABLE取码,取T的值MOVCA,A+DPTR;MOVTH0,A;取到的高位字节存入TH0MOV21H,A;取到的高位字节存入(21H)MOV

49、A,22H;再载入取码指针RLA;乘2INCA;加1MOVCA,A+DPTR;至TABLE取相对的低位字节计数值 MOVTL0,A;取到的高位字节存入TL0MOV20H,A;取到的高位字节(z ji)存入(20H)D2:CALLKEY;调用(dioyng)KEY,判断是否有键按下SETBEA;中断(zhngdun)使能JBF0,D1;有按否?JMPD2;;有则跳至D2KEY:SETBF0;设F0=1MOVR3,#0F7H;扫描初值(P2.3=0)MOVR1,#00H;取码指针初值D3:MOVA,R3;载入扫描指针MOVP2,A;输出至P2,开始扫描行MOVA,P2;读入P2CLRCCPLC;令

50、C=1MOVR5,#04H;检测列D4:RLCA;左移一位(P2.7P2.4)JNCKEYIN;检测行C=0,表示被按INCR1;没按则取码指针加1DJNZR5,D4;4列检测完毕了?MOVA,R3CLRCCPLC;C=1RRCA;扫描下一行,即下一行为0MOVR3,A;存回R3扫描指针寄存器JCD3;C=0表示扫描完毕RETKEYIN:MOV22H,R1;取码指针存入22H地址CLRF0;令F0=0RETTIM0:PUSHACC;将A的值暂存于堆栈PUSHPSW;将PSW的值暂存于堆栈MOVTL0,20H;重设计数值MOVTH0,21HCPLP3.4;将P3.4反相POPPSW;至堆栈(duzhn)取回PSW的值POPACC;至堆栈(duzhn)取回A的值RETITABLE:DW64021,64103,64260,64400DW64524,64580,64684,64777DW64820,64898,64968,65030DW65

温馨提示

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

评论

0/150

提交评论