单片机与PC机串口通信的设计.doc

上传人:精*** 文档编号:840582 上传时间:2023-09-08 格式:DOC 页数:37 大小:502.97KB
下载 相关 举报
单片机与PC机串口通信的设计.doc_第1页
第1页 / 共37页
单片机与PC机串口通信的设计.doc_第2页
第2页 / 共37页
单片机与PC机串口通信的设计.doc_第3页
第3页 / 共37页
单片机与PC机串口通信的设计.doc_第4页
第4页 / 共37页
单片机与PC机串口通信的设计.doc_第5页
第5页 / 共37页
点击查看更多>>
资源描述

1、引言 AT89C51是一款高性能的8位单片微型计算机,它采用了CMOS工艺和ATMEL公司的高密度NVRAMUII(易失性随机存储器)技术,片内带有一个4KB的FLASH FPROM(可擦除、可编程只读存储器),作为INTEL8051的换代产品,其输出引脚和指令系统与MCS一51完全兼容。由于AT89C51 单片机具有集成度高、面向控制、系统结构简单、价格便宜等诸多优点,因而在智能化仪器仪表、数据采集、数据测量等方面有着广泛的应用。但是,实际应用中单片机在数据处理能力、人机交互等方面往往不能满足要求,因而通常用PC来弥补单片机的这些不足。例如,在工程应用中,常常由一台PC机和一台单片机构成主从

2、式计算机测控系统。在这样的系统中,以单片机为核心的智能测控仪表(从机)作为现场测控设备,完成数据的采集、处理和控制各种任务,同时将数据传给PC机(主机),PC机将这些数据加工处理后,进行显示、打印报表等,PC机也可以将各种控制命令传送给单片机,干预单片机系统的运行,从而发挥PC机的优势。随着单片机和微机技术的不断发展,特别是网络技术在测控领域的广泛应用,由PC机和多台单片机构成的多机网络测控系统已成为单片机技术发展的一个方向。它结合了单片机在实时数据采集和微机对图形处理、显示的优点。同时,windows环境下后台微机在数据库管理上具有明显的优势。二者结合,使得单片机的应用已不仅仅局限于传统意义

3、上的自动监测或控制,而形成了向以网络为核心的分布式多点系统发展的趋势。1总体方案设计单片机键盘LCD串行通信电平转换接口PC发声电路硬件由单片机89C51、11.059M晶振,30PF电容、22uf/25V电容、10uf/25V电容10K电阻、LCM1601、44键盘、LM386、蜂鸣器、按键、Max232组成。具体可实现由AT89C51键盘(P1)发送数据(由LCD显示),PC做接收且屏幕显示该值;也可由PC键盘发送数据,由8051接收并显示至LCD。系统结构如图1-1所示。图1-1 系统结构图LCD:系统显示界面采用LCM1601,一行16字符的液晶显示模块,显示AT89C51接收或PC发

4、来的数据。键盘:输入按键采用4行4列非编码矩阵键盘,配合液晶界面用于和PC机通信。发声电路:发声电路采用LM386作为音频放大电路,在有按键按下的时候会发出相应的按键音。串行通信电平转换接口:AT89C51与PC间的串行数据通信采用的是最简单的TxD,RxD,GND三线制连接,从单片机TX和RX端CMOS电平到PC的标准RS-232电平的转换器件选用Maxim的Max232。2硬件电路设计总电路图见附录C。2.1 单片机AT89C51AT89C51是一种带4K字节闪烁可编程可擦除只读存储器(FPEROMFalsh Programmable and Erasable Read Only Memo

5、ry)的低电压,高性能CMOS8位微处理器,俗称单片机。该器件采用ATMEL高密度非易失存储器制造技术制造,与工业标准的MCS-51指令集和输出管脚相兼容。由于将多功能8位CPU和闪烁存储器组合在单个芯片中,ATMEL的AT89C51是一种高效微控制器,为很多嵌入式控制系统提供了一种灵活性高且价廉的方案。AT89C51的管脚图如图2-1所示。 图2-1 AT89C51的管脚图主要特性:第37页,共37页与MCS-51 兼容 4K字节可编程闪烁存储器 寿命:1000写/擦循环数据保留时间:10年全静态工作:0Hz-24Hz三级程序存储器锁定128*8位内部RAM32可编程I/O线两个16位定时器

6、/计数器5个中断源可编程串行通道低功耗的闲置和掉电模式片内振荡器和时钟电路 管脚说明:VCC:供电电压。 GND:接地。P0口:P0口为一个8位漏级开路双向I/O口,每脚可吸收8TTL门电流。当P1口的管脚第一次写1时,被定义为高阻输入。P0能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。在FIASH编程时,P0 口作为原码输入口,当FIASH进行校验时,P0输出原码,此时P0外部必须被拉高。P1口:P1口是一个内部提供上拉电阻的8位双向I/O口,P1口缓冲器能接收输出4TTL门电流。P1口管脚写入1后,被内部上拉为高,可用作输入,P1口被外部下拉为低电平时,将输出电流,这是由于

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

8、的双向I/O口,可接收输出4个TTL门电流。当P3口写入“1”后,它们被内部上拉为高电平,并用作输入。作为输入,由于外部下拉为低电平,P3口将输出电流(ILL)这是由于上拉的缘故。 P3口也可作为AT89C51的一些特殊功能口,如表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口同时为闪烁编程和编程校验接收一些

9、控制信号。RST:复位输入。当振荡器复位器件时,要保持RST脚两个机器周期的高电平时间。ALE/PROG:当访问外部存储器时,地址锁存允许的输出电平用于锁存地址的地位字节。在FLASH编程期间,此引脚用于输入编程脉冲。在平时,ALE端以不变的频率周期输出正脉冲信号,此频率为振荡器频率的1/6。因此它可用作对外部输出的脉冲或用于定时目的。然而要注意的是:每当用作外部数据存储器时,将跳过一个ALE脉冲。如想禁止ALE的输出可在SFR8EH地址上置0。此时, ALE只有在执行MOVX,MOVC指令是ALE才起作用。另外,该引脚被略微拉高。如果微处理器在外部执行状态ALE禁止,置位无效。/PSEN:外

10、部程序存储器的选通信号。在由外部程序存储器取指期间,每个机器周期两次/PSEN有效。但在访问外部数据存储器时,这两次有效的/PSEN信号将不出现。/EA/VPP:当/EA保持低电平时,则在此期间外部程序存储器(0000H-FFFFH),不管是否有内部程序存储器。注意加密方式1时,/EA将内部锁定为RESET;当/EA端保持高电平时,此间内部程序存储器。在FLASH编程期间,此引脚也用于施加12V编程电源(VPP)。XTAL1:反向振荡放大器的输入及内部时钟工作电路的输入。XTAL2:来自反向振荡器的输出。AT89C51的时序:AT89C51的振荡器输入分别有引脚19(XTAL1)和引脚18(X

11、TAL2)来完成。只要将这两个引脚接石英晶体和陶瓷电容,如图图2-2所示,就可以与CPU内部组成完整的振荡电路。AT89C51的一个机器周期含有6个状态周期,而每个状态周期为2个振荡周期,因此一个机器周期共有12个振荡周期,如振荡器的频率为12MHZ,一个振荡器周期为1/12微秒,而一个机器周期为1微秒。CXTAL11918石英晶体XTAL2AT89C51C图2-2 AT89C51的振荡电路在本设计中石英晶体的频率为11.0592MHZ,陶瓷电容的取值为30PF。AT89C51的复位:单片机微处理器的复位都是以外部电路来执行的,在CLOCK工作后,只要在RESET引脚上接上10MS以上的高电平

12、,单片机微处理器便执行状态复位。一、 寄存器的复位单片机在RESET为高电平控制下,程序计数器(PC)和特殊功能寄存器的复位如表2-2所示。单片机的复位并不影响芯片内部RAM状态,只要RESET引脚保持高电平,单片机将循环复位。在复位有效期内,ALE,PSEN将输出高电平。表2-2寄存器复位后的状态寄存器复位状态寄存器复位状态PC0000HTMOD00HACC00HTCON00HB00HTH000HPSW00HTL000HSP07HTH100HDPTR0000HTL100HP0P3FFHSCON00HIP(00000)SBUF()IE(000000)PCON(00000)二、复位电路简单复位电

13、路中,干扰易串入复位端,在大多数情况下不会造成单片机的错误复位,但会引起内部某些寄存器的错误复位,可以在RESET引脚上接上一个去耦电容。为了保证复位电路的可靠性,常将RC电路接斯密特电路后再接入单片机和外围IC的RESET引脚,如图2-3所示。图2-3 AT89C51的复位电路AT89C51的串行口:(1)基本概念数据通信的传输方式:常用于数据通信的传输方式有单工、半双工、全双工和多工方式。A单工方式:数据仅按一个固定的方向传送。因为这种传输方式的用途有限,常用于串行口的打印数据传输与简单系统间的数据采集。B双工方式:数据可以实现双向传送,但不能同时进行,实际的应用采用某种协议实现收发开关转

14、换。C全双工方式:允许双方同时进行数据双向传送,但一般全双工电路的线路和设备比较复杂。D多工方式:以上三种传输方式都是同一线路传输一种频率信号,为了充分的利用线路资源,可通过使用多路复用器或多路集线器,采用频分、时分、或码分复用技术,即可实现在同一线路上资源共享功能,我们称之为多工传输方式。串行通信的两种通信形式A. 异步通信 在这种通信方式中,接收器和发射器有各自的时钟,他们的工作是非同步的,异步通信用一帧来表示一个字符,其内容如下:一个起始位,紧接着是若干个数据位,图 是传输45H的数据格式。B.同步通信 同步通信格式中,发送器和接收器由同一个时钟源控制,为了克服在异步传输中,每传输一帧字

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

16、行通信控制寄存器(SCON),它是一个可寻址的专用寄存器,用于串行数据通信的控制,单元地址是98H,其结构格式如表2-3所示。表2-3 SCON寄存器结构SCOND7D6D5D4D3D2D1D0SM0SM1SM2RENTB8RB8TIRI位地址9FH9EH8DH9CH9BH9AH99H98H下面我们对SCON控制位功能介绍如表2-4所示。1)SM0、SM1:串行口工作方式控制位表2-4 SCON控制位功能介绍SM0SM1工作方式功能说明00方式0移位寄存器方式(用于I/O扩展)01方式18位UART,波特率可变(T1溢出率/n)10方式29位UART,波特率为fosc/64或fosc/3211

17、方式39位UART,波特率可变(T1溢出率/ n)2)SM2:多机通信控制位多机通信是工作方式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和方

18、式3中是接收到的第9位数据。在方式1时,如SM2=0,RB8接收到的停止位。在方式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是串行

19、波特率倍增位,当SMOD=1时串行口波特率加倍,系统复位默认为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 LCM1601LCM1601

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

21、D-背光源负极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电平转换器件Max232MAX232芯片是MAXIM 公司生产的,包含

22、两路接收器和驱动器的IC芯片。MAX232芯片内部有一个电源电压转换器,可以把输入的+5V 电压变换为RS-232输出电平所需的一1O+ 10V 电压。所以采用此芯片接口串行通信系统只需单一的+5V电源就可以了。对于没有一12+12V 的场合,其适应性更强。加之其价格适中,硬件接口简单,所以被广泛采用。图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/

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

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

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

26、3M1318651577中3M65964777F高4FA1397651784单片机软件设计软件的设计是我毕业设计的另一个重要方面。它的好坏直接关系毕业设计的成功与否。我等软件是用汇编完成的,需要能熟练的掌握汇编语言,还要熟悉AT89C51单片机。程序流程图是编写软件的重要前提,它是在图表上直观的体现拟设计的目的及过程。也是编译的重要依据,按照流程图一步一步编写程序,单片机软件主程序流程图如图4-1所示。是否否是开始LCD初始化设置串口初始化收到数据?检测按键输入读入键值转换成键码串口发送键码LCD显示并发声接收数据送LCD显示图4-1主程序流程图4.1 CM1601软件子程序设计LCD1601

27、是通用的点阵型液晶模块,分4位和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 FLA

28、G=0?CLRRS;RS=0,R/W=0写入指令组CLRRWCLRECALLDELAYSETBERET4.2.2写数据WRITE1:MOVR1,#00H;显示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;功能

29、设定(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;在其他模式下,在停止位的开始时有硬件设定,次位必须由软件清除。TI:发送中断标志位。在模式

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

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

32、收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所示。说明如下:PCON:电源控制寄存器(POWER C

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

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

35、3) MODE1和MODE3:利用TIMER工作在MODE2模式(自动载入)产生的波特率为(2/32)振荡频率/(12(256-TH1)常用的各种波特率如表4-2-3所示。表4-3 常用的各种波特率波特率(bit/s)Fosc(MHZ)SMODTimer1C/T模式自动载入480012102F3H240012002F3H120012102F6H1920011.059102FDH960011.059002FDH480011.059002FAH240011.059002F4H120011.059002F8HUART的中断要求:其中断要求有两种方式:(1)当UART的接收器(RXD)接收到一个字节的

36、数据且将其存入SBUF寄存器后,就会将RI设定为1,而对AT89C51提出中断要求。(2)当UART的发送器将SBUF寄存器的8个位数据发送出去后,会将TI设定为1。UART中断要求设定的步骤:1.设定UART中断起始地址。ORG23HJMPUART2.设定TIMER1工作在MODE2MOVTMOD,#00100000B3.设定波特率为2400ANLPCON,#01111111BMOVTH1,#0F3H4.启动计时器SETBTRX5.设定UART工作方式MOVSCON,#010000B3.设定UART中断功能MOVIE,#10010000B4.3 键盘扫描子程序设计键盘扫描的步骤:(1)设置P

37、1口初始值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;没按则取码指针加1DJNZR5,D4;4列检测完毕了?MOVA,R3CLRCCPLC;C=1RRCA;扫描下一行,即下一行为0MOVR3,A;存回R3扫描指针

38、寄存器 图4-2 读键输入子程序框图JCD3;C=0表示扫描完毕RETKEYIN:MOV22H,R1;取码指针存入22H地址MOVR7,#10;消除抖动D5:MOVR6,#248DJNZR6,$DJNZR7,D5D6:MOVA,P2;按钮放开否?XRLA,R4 4.4 按键发声子程序的设计按键发声子程序框图如图4-3所示。 图4-3按键发声子程序框图程序如下:ORG00H;主程序其始地址JMPSTART;跳至主程序 ORG0BH;TIMER0中断其始地址JMPTIM0;跳至TIMER0中断子程序START:MOVTMOD,#00000001B;设定TIMER0工作在MODE1MOVIE,#10

39、000010B;中断使能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)MOVA,22H;再载入取码指针RLA;乘2INCA;加1MOVCA,A+DPTR;至TABLE取相对的低位字节计数值 MOVTL0,A;取到的高位字节存入TL0MOV20H,A;取到的高位字

40、节存入(20H)D2:CALLKEY;调用KEY,判断是否有键按下SETBEA;中断使能JBF0,D1;有按否?JMPD2;;有则跳至D2KEY:SETBF0;设F0=1MOVR3,#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;没按则取码指针加1DJNZR5,D4;4列检测完毕了?MOVA,R3CLRCCPLC;C=1RRCA;

41、扫描下一行,即下一行为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;至堆栈取回PSW的值POPACC;至堆栈取回A的值RETITABLE:DW64021,64103,64260,64400DW64524,64580,64684,64777DW64820,64898,64968,65030DW65058,65110,65157,651785软硬件调试及结果5.1 软件仿真软件仿真使用的是ISIS 6 Professional,它可以完成单片机的电路仿真。图5-5-1是软件仿真的结果。图5-1-1 软件

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 学术论文 > 毕业设计

版权声明:以上文章中所选用的图片及文字来源于网络以及用户投稿,由于未联系到知识产权人或未发现有关知识产权的登记,如有知识产权人并不愿意我们使用,如有侵权请立即联系:2622162128@qq.com ,我们立即下架或删除。

Copyright© 2022-2024 www.wodocx.com ,All Rights Reserved |陕ICP备19002583号-1 

陕公网安备 61072602000132号     违法和不良信息举报:0916-4228922