单片机课程设计实验单片机间串行通信.doc
单片机原理及应用课程设计报告 课程设计题目:单片机间串行通信原理专业班级 :2012级电子信息科学及技术学生姓名 : 罗滨志 学 号 :成 绩 : 2014 年12 月 27日目 录摘 要11 设计任务11.1 功能要求21.2 总体方案及工作原理22 系统硬件设计221 器件选择222.1.2 AT89C5132.1.3键盘输入电路52.1.4晶振电路方案62.1.5数码管显示62.1.6复位电路方案62.2 硬件原理图73 系统软件设计83.1基本原理83.2系统软件设计流程图83.3 按键程序设计9串口通信程序设计:103.3.2 显示程序设计:103.4软件清单101发送端程序103.42接收端程序134实验步骤144.1实验程序调试144.1.1发送端程序调试144.1.2接收端程序调试154.2实验仿真165设计总结176参考文献:17第 19 页摘 要单片机自20世纪70年代问世以来,以其极高性能价格比,受到人们重视与关注,应用很广、发展很快。而AT89C51单片机是各单片机中最为典型与最有代表性一种,本设计是基于MCS51系列单片机中AT89C51所设计一种具有一个全双工串行通信口,可以实现单片机及单片机之间点对点串行通信,主从通信以及上,下位机互相通信等。本设计基于单片机技术原理,以单片机芯片AT89C51作为核心控制器,由单片机及键盘控制数码管显示,修改设置LED显示由按键开关控制,通过硬件电路制作以及软件程序编制,设计制作一个简单单片机间串行通信。关键词:单片机 AT89C51 串行通信 1 设计任务单片机间串行通信,是工业自动化、智能终端、通信管理等领域传统且重要通讯手段。此次设计单片机串行通信,就是为了了解单片机工作原理,从而学会制作数字钟。本次课程设计通过理论设计与实物制作解决相应实际问题,巩固与运用在单片机原理及应用及C51程序设计中所学理论知识与实验技能,掌握单片机应用系统一般设计方法,提高设计能力与实践动手能力,为以后从事电子电路设计、研发电子产品打下良好基础。1.1 功能要求设计一个单片机及单片机之间点对点串行通信应用电路,要求按下发送端单片机键盘上按钮,该键键号通过串行异步通信传送到接收端单片机中,并在LED上显示出来,其晶振频率为6MHZ。1.2 总体方案及工作原理本设计2个相同单片机之间通过串口进行通信,通过按键输入要发送数据,该数据为数字,并可在数码管上显示出来,设置完后通过串口通信发送给另一个单片机,另一个单片机接收到后在数码管上显示出来,2个单片机可以互相发送数据,通过2个单片机系统数码管显示数字可以判断串口通信发送数据正确性。系统设计框图如图2-1所示。本设计主要由按键输入电路、单片机控制电路与数码管显示电路组成,2个单片机电路图完全相同,实现功能也相同,所以本文只介绍其中一块单片机电路设计方法与串口通信原理。整个串行通信工作原理是:在正常供电状态下,首先利用发送端单片机读入键盘输入数据,在将读入数据传送到接收端,由单片机将所需要显示数据送到LED显示器输入口,当有键按下时则进入相应按键调整状态,进行按键调整。2 系统硬件设计21 器件选择元件名称数量AT89C51芯片27SEG-MPX2-CA数码管16MHZ晶振(CRYSTAL)110uF电解电容(CAP-ELEC)130pF普通电容(CAP)274LS06六驱动器2200R电阻(RES)210K电阻(RES)15.1K电阻(RES)4按钮(BUTTON)16BUS2.2 AT89C51AT89C51是一种带4K字节闪烁可编程可擦除只读存储器(FPEROM-FALSH PROGRAMMABLE AND ERASABLE READ ONLY MEORY)低电压,高性能CMOS8位微处理器,俗称单片机。AT89C51是一种带4K字节闪烁可编程可擦除只读存储器单片机,单片机可擦除只读存储器可以反复擦除100次。该器件采用ATMEL高密度非易失存储器制造技术制造,及工业标准MCS-51指令集与输出管脚相兼容,AT89C51单片机包含中央处理器、程序存储器(ROM)、数据存储器(RAM)、定时/计数器、串行接口与中断系统等几大单元及数据总线、地址总线与控制总线等三大总线。其基本结构如图1 图 1 AT89C51单片机基本结构AT89C51 是一个低电压,高性能CMOS 8 位单片机,片内含8kB 可反复擦写Flash 只读程序存储器与256B 随机存取数据存储器(RAM),器件采用ATMEL公司高密度、非易失性存储技术生产,及标准MCS-51 指令系统及8052 产品引脚兼容,片内置有通用8 位中央处理器(CPU)与Flash 存储单元。 图2 AT 89C51单片机引脚VCC/GND:供电电源。 P0口:可以被定义为数据/地址低八位,能够用于外部程序/数据存储器。在FIASH编程时,P0 口作为原码输入口,当FIASH进行校验时,P0输出原码,此时P0外部必须被拉高。 P1口:标准输入输出I/O口,P1口管脚写入1后,被内部上拉为高,可用作输入。在FLASH编程与校验时,P1口作为第八位地址接收。P2口:既可用于标准输入输出I/O,也可用于外部程序存储器或数据存储器访问时高八位地址。P2口在FLASH编程与校验时接收高八位地址信号与控制信号。P3口:既可以作标准输入输出I/O,也可作为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(外部数据存储器读选通) RST:复位输入。当振荡器复位器件时,要保持RST脚两个机器周期高电平时间。 ALE/PROG:当访问外部存储器时,地址锁存允许输出电平用于锁存地址地位字节。在FLASH编程期间,此引脚用于输入编程脉冲。在平时,ALE端以不变频率周期输出正脉冲信号,此频率为振荡器频率1/6。PSEN:外部程序存储器选通信号。在由外部程序存储器取指期间,每个机器周期两次/PSEN有效。但在访问外部数据存储器时,这两次有效/PSEN信号将不出现。EA / VPP:当/EA保持低电平时,则在此期间外部程序存储器(0000H-FFFFH),不管是否有内部程序存储器。注意加密方式1时,/EA将内部锁定为RESET;当/EA端保持高电平时,此间内部程序存储器。在FLASH编程期间,此引脚也用于施加12V编程电源(VPP)。XTAL1:反向振荡放大器输入及内部时钟工作电路输入。 XTAL2:来自反向振荡器输出。.3键盘输入电路键盘输入电路由发送端单片机接口“ 按键组串联”构成,按下S1按键,LED显示器显示相应键盘值,同理其余15个按键如此。图3 键盘输入原理图.4晶振电路方案 晶振电路功能在于给单片机提供振荡时钟信号,使单片机正常工作。本设计中采用了常用晶振电路组成方案,具体如下图所示。图4晶振电路.5数码管显示引脚接口ABCDEFGDP1R82R9.6复位电路方案 复位电路功能在于对单片机进行复位从而达到对整个电路复位功能。要达到目则要求在复位按键按下后在RST引脚上要出现一个维持2个机器周期高电平4。考虑到可以利用电容电压不能突变(需要一定充放电时间),于是采用如下复位电路。图5复位电路 硬件原理图3 系统软件设计 它是利用单片机全双工串行通信口,实现单片机及单片机之间点对点串行通信,主从通信以及上,下位互相通信。然后数码管把他们内容在相应位置显示出来。在具体设计时按键采用中断方式工作,对LED显示在中断程序中实现,在发送端程序只是对键盘输入数据定义初始化,调用显示程序与控制程序初始化。本设计软件程序包括发送端程序、接收端程序、中断子程序、时钟显示子程序等等。另外电路中有按键控制程序。 本系统软件设计分为发送机与接收机,发送机程序设计流程图如图6所示,接收机程序设计流程图如图7所示。数据发送完成?结束开始初始化读取数据送数码管显示数据发送至串口扫描按键NY 图6 发送端流程图数据接收完成?结束开始初始化读取数据送数码管显示NY触发串口中断?NY图7 接收端流程图3.3 按键程序设计单片机读取按键值方法有两种:查询方式与中断方式。查询方式是利用键盘程序不断查询是否有按键按下,有按下则进入相应按键子程序进行数据处理,没有则一直循环查询;中断方式是将按键动作及单片机中断系统联系起来,有按键按下时,就引起单片机中断,使系统进入中断处理程序。本设计中有16个按键,且主要程序就是按键处理,所以采用查询方式来处理读取按键值程序。设计按键程序时,首先应注意是按键机械触点效应,原理上,按键按下时,单片机端口为低电平,但是由于按键机械触点效应,按键在断开与闭合瞬间会有抖动过程,这个过程会出现一系列负脉冲,这样会让单片机引起误判,因次,必须采取措施去掉按键抖动影响。去按键抖动常用有两种方法:硬件方法与软件方法。硬件方法一般是并接电容,或者加R-S触发器;软件去抖动一般采用延时方法,按键抖动过程一般持续5-10ms时间,在判断按键状态时,只要加一个5-10ms延时程序,再次判断按键是否状态不变,即可实现去抖动作用。本设计中选用软件延时方法去按键抖动。3串口通信程序设计:AT89C51串行口是一个全双工异步串行通信口,可以同时进行接收数据与发送数据,因为口内接受缓冲器与发送缓冲器在物理上是隔离,即是完全独立。可以通过访问特殊功能寄存器SBUF,来访问接收缓冲器与发送缓冲器。接收缓冲器还具有双缓冲功能,即它在接收第一个数据字节后,能接受第二个数据字节,但是,在它完成接收第二个数据字节之后,若第一个字节仍未取走,那么该字节数据将丢失。对串行口控制主要包括对状态控制寄存器SCON、控制寄存器PCON、与串行数据寄存器SBUF设置。3显示程序设计:根据数码管驱动方式不同,数码管送显方式有两种:静态送显与动态送显。静态显示驱动:静态驱动也称直流驱动,在静态显示驱动方式下,数码管共阴极或共阳极共同接地或接电源,每个数码管段选线及8位单片机并口连接。静态显示驱动方式占用单片机I/O端口比较多,一般在实用中不采用。动态显示驱动:数码管动态显示方式是将所有段选线并联在一起,由一个8位I/O口来控制,再利用单片机其他I/O口来作为数码管位选线。当单片机输出显示数字译码时,哪个数码管显示由单片机对位选通电路控制来选择,所以将欲显示数码管位选通端选通,该数码管就会显示,其它数码管均不会亮。通过轮流控制各个数码管选通端使数码管轮流显示。在显示过程中,每个数码管显示时间为1-2ms,由于人们视觉暂留现象及发光二极管余晖效应,只要扫描速度够快,给人印象就是同时点亮,而且不会有闪烁感。软件清单ORG 0000H AJMP STARTORG 0030HSTART: MOV SP,#50H 设置堆栈区为:50H-7FHCLR EA 关中断 MOV TMOD,#20H T1方式2 MOV TH1,#0E7H 波特率设置为:625bps MOV TL1,#0E7H MOV PCON,#0 SETB TR1 MOV SCON,#40H 设串口为方式1LOOP: NOPACALL KEYSCAN 调用键盘扫描程序KEYSCANMOV A,R7CJNE A,#0FFH,EXIT1 有按键按下,转EXIT1 执行 SJMP LOOP 主程序循环EXIT1: MOV SBUF,A 发送键号JNB TI,$CLR TISJMP LOOP 主程序循环NOPKEYSCAN: MOV P0,#0F0H 键盘扫描程序KEYSCAN,返回值存R7中MOV A,P0 有键按下返回相应键号,无键按下返回FFH,应键号CPL A ANL A,#0F0HJZ NOKEY 无按键按下,转NOKEY执行ACALL DEL10MS 调用延时10ms程序,软件去抖动MOV A,P0CPL AANL A,#0F0HJZ NOKEYMOV R3,A 闭合键列线状态送R3MOV R4,#11111110B 从P0.0=0开始扫描MOV R0,#4 循环扫描4次KLOOP1: MOV P0,R4ACALL DEL1MSMOV A,P0CPL AANL A,#0F0HJNZ KEYNUM MOV A,R4 RL A MOV R4,A 闭合键行线状态送R4 DJNZ R0,KLOOP1 SJMP NOKEYKEYNUM: MOV A,R3 计算列号,结果存在R3中 SWAP A MOV R3,#0 MOV R0,#4KLOOP2: RRC A JC COL INC R3 DJNZ R0,KLOOP2 SJMP NOKEYCOL: MOV A,R4 计算列号,结果存在R4中 MOV R4,#0 MOV R0,#4KLOOP3: RRC A JNC ADDKEY INC R4 DJNZ R0,KLOOP3 SJMP NOKEYADDKEY: MOV A,R4 计算键号,键号=行号*4+列号 RL A RL A ADD A,R3 MOV R7,A 键号存R7中KLOOP4: MOV P0,#0F0H 等待按键释放 MOV A,P0 CPL A ANL A,#0F0H JNZ KLOOP4 RETNOKEY: MOV R7,#0FFH 无键按下,FFH存R7中 RET 返回 NOPDEL1MS: MOV R6,#125 延时1ms子程序DEL: NOP NOP DJNZ R6,DEL RETDEL10MS: MOV R6,#5 延时10ms子程序DEL2: MOV R5,#125DEL1: NOP NOP DJNZ R5,DEL1 DJNZ R6,DEL2 RET ENDORG 0000H AJMP START ORG 0023H AJMP SIO 调转到串行口中断执行 ORG 0030HSTART: MOV SP,#50H 设置堆栈区为:50H-7FH MOV A,#10 设置显示初始字符为P MOV 30H,A INC A MOV 31H,A MOV TMOD,#20H T1工作方式2 MOV TH1,#0E7H 波特率设置625bps MOV TL1,#0E7H MOV PCON,#0 SETB TR1 MOV IP,#10H 设置串行口中断为高优先级 MOV IE,#90H 开串行口中断 MOV SCON,#50H 设串口为方式1LOOP: NOP ACALL DISP 调用显示子程序DISP SJMP LOOP 主程序循环DISP: MOV DPTR,#DISPTAB 显示子程序DISP MOV A,30H MOVC A,A+DPTR MOV P1,A ACALL DEL1MS MOV A,#0FFH MOV P1,A MOV A,31H MOVC A,A+DPTR MOV P1,A ACALL DEL1MS MOV A,#0FFH MOV P1,A RETSIO: PUSH PSW 串行口中断服务程序SIO PUSH ACC JNB RI,EXIT CLR RI MOV A,SBUF 接收发送端传送来数据 MOV B,#10 将键号分解成两位存于31H与30H中 DIV AB JNZ EXIT2 MOV A,#11EXIT2: MOV 31H,A MOV A,B MOV 30H,AEXIT: NOP CLR TI POP ACC POP PSW RETI 中断返回DEL1MS: MOV R6,#125 延时1ms子程序DEL: NOP NOP DJNZ R6,DEL RETDISPTAB: DB 0C0H,0F9H,0A4H 显示段码表,0,1,2 DB 0B0H,99H,92H 3,4,5 DB 82H,0F8H,80H 6,7,8 DB 90H,8CH,0FFH 9,P,熄灭 END4 实验步骤在Keil软件中输入实验发送端参考程序,调试如图8所示:图8发送端程序调试图如图8发送端程序调试图可以看出程序调试无错误,所以将调试无错误发送端程序转换为HEX文件;在Keil软件中输入实验接收端参考程序,调试如图9所示:图9接收端程序调试图如图9接收端程序调试图可以看出程序调试无错误,所以将调试无错误接收端程序转换为HEX文件;按照单片机间串行通信实验原理图在Proteus软件中连接相应源器件如图10图10实验原理图将首先转换好发送端及接收端HEX文件下载到相应芯片中,在Proteus中仿真图形如图11图11电路仿真图5 设计总结本设计介绍了一种单片机及单片机之间串行通信设计方法,论文首先介绍了单片机及单片机之间串行通信工作原理、软件及硬件实现、研究现状、串行通信概念以及键盘输入。主要是单片机及单片机之间串行通信方式与重要数据位说明,接着提出了可行设计方案,并从硬件电路设计及软件程序设计两个方面详细介绍了整个设计工作原理及设计过程,同时验证了方案可行性。通过本次单片机间串行通信实验设计,使我对单片机有更加深刻了解,明白了软件及硬件配合使用,懂得怎样去分析电路及调试程序,虽然在设计过程中遇到很多困难,但是经过进一步查阅相关资料,问题才得以解决,尽管最后设计不是那么完美,不是那么理想,但总体上来说实现了单片机间串行通信,基本上完成了实验原理所需要求,通过本次设计也使得自己明白软件及硬件相结合重要性,二者缺一不可,所以在实现硬件连接同时也要读懂软件所实现功能。6参考文献:13刘万松、曹晓龙.微型计算机原理及应用实验教程.6朱清慧,Proteus教程:电子线路设计、制版及仿真,清华大学出版社,2008.97郭文川,单片机原理及接口技术,中国农业出版社,2007.18 杨加国. 单片机原理及应用及C51程序设计. 清华大学出版社,2009(2)9