单片机课程设计实验单片机间串行通信.doc
《单片机课程设计实验单片机间串行通信.doc》由会员分享,可在线阅读,更多相关《单片机课程设计实验单片机间串行通信.doc(21页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、单片机原理及应用课程设计报告 课程设计题目:单片机间串行通信原理专业班级 :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.
2、42接收端程序134实验步骤144.1实验程序调试144.1.1发送端程序调试144.1.2接收端程序调试154.2实验仿真165设计总结176参考文献:17第 19 页摘 要单片机自20世纪70年代问世以来,以其极高性能价格比,受到人们重视与关注,应用很广、发展很快。而AT89C51单片机是各单片机中最为典型与最有代表性一种,本设计是基于MCS51系列单片机中AT89C51所设计一种具有一个全双工串行通信口,可以实现单片机及单片机之间点对点串行通信,主从通信以及上,下位机互相通信等。本设计基于单片机技术原理,以单片机芯片AT89C51作为核心控制器,由单片机及键盘控制数码管显示,修改设置LE
3、D显示由按键开关控制,通过硬件电路制作以及软件程序编制,设计制作一个简单单片机间串行通信。关键词:单片机 AT89C51 串行通信 1 设计任务单片机间串行通信,是工业自动化、智能终端、通信管理等领域传统且重要通讯手段。此次设计单片机串行通信,就是为了了解单片机工作原理,从而学会制作数字钟。本次课程设计通过理论设计与实物制作解决相应实际问题,巩固与运用在单片机原理及应用及C51程序设计中所学理论知识与实验技能,掌握单片机应用系统一般设计方法,提高设计能力与实践动手能力,为以后从事电子电路设计、研发电子产品打下良好基础。1.1 功能要求设计一个单片机及单片机之间点对点串行通信应用电路,要求按下发
4、送端单片机键盘上按钮,该键键号通过串行异步通信传送到接收端单片机中,并在LED上显示出来,其晶振频率为6MHZ。1.2 总体方案及工作原理本设计2个相同单片机之间通过串口进行通信,通过按键输入要发送数据,该数据为数字,并可在数码管上显示出来,设置完后通过串口通信发送给另一个单片机,另一个单片机接收到后在数码管上显示出来,2个单片机可以互相发送数据,通过2个单片机系统数码管显示数字可以判断串口通信发送数据正确性。系统设计框图如图2-1所示。本设计主要由按键输入电路、单片机控制电路与数码管显示电路组成,2个单片机电路图完全相同,实现功能也相同,所以本文只介绍其中一块单片机电路设计方法与串口通信原理
5、。整个串行通信工作原理是:在正常供电状态下,首先利用发送端单片机读入键盘输入数据,在将读入数据传送到接收端,由单片机将所需要显示数据送到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字节闪烁可编程可擦除只读存储器(
6、FPEROM-FALSH PROGRAMMABLE AND ERASABLE READ ONLY MEORY)低电压,高性能CMOS8位微处理器,俗称单片机。AT89C51是一种带4K字节闪烁可编程可擦除只读存储器单片机,单片机可擦除只读存储器可以反复擦除100次。该器件采用ATMEL高密度非易失存储器制造技术制造,及工业标准MCS-51指令集与输出管脚相兼容,AT89C51单片机包含中央处理器、程序存储器(ROM)、数据存储器(RAM)、定时/计数器、串行接口与中断系统等几大单元及数据总线、地址总线与控制总线等三大总线。其基本结构如图1 图 1 AT89C51单片机基本结构AT89C51 是
7、一个低电压,高性能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后,被内部上拉
8、为高,可用作输入。在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(外部数据存储器读选通)
9、 RST:复位输入。当振荡器复位器件时,要保持RST脚两个机器周期高电平时间。 ALE/PROG:当访问外部存储器时,地址锁存允许输出电平用于锁存地址地位字节。在FLASH编程期间,此引脚用于输入编程脉冲。在平时,ALE端以不变频率周期输出正脉冲信号,此频率为振荡器频率1/6。PSEN:外部程序存储器选通信号。在由外部程序存储器取指期间,每个机器周期两次/PSEN有效。但在访问外部数据存储器时,这两次有效/PSEN信号将不出现。EA / VPP:当/EA保持低电平时,则在此期间外部程序存储器(0000H-FFFFH),不管是否有内部程序存储器。注意加密方式1时,/EA将内部锁定为RESET;当
10、/EA端保持高电平时,此间内部程序存储器。在FLASH编程期间,此引脚也用于施加12V编程电源(VPP)。XTAL1:反向振荡放大器输入及内部时钟工作电路输入。 XTAL2:来自反向振荡器输出。.3键盘输入电路键盘输入电路由发送端单片机接口“ 按键组串联”构成,按下S1按键,LED显示器显示相应键盘值,同理其余15个按键如此。图3 键盘输入原理图.4晶振电路方案 晶振电路功能在于给单片机提供振荡时钟信号,使单片机正常工作。本设计中采用了常用晶振电路组成方案,具体如下图所示。图4晶振电路.5数码管显示引脚接口ABCDEFGDP1R82R9.6复位电路方案 复位电路功能在于对单片机进行复位从而达到
11、对整个电路复位功能。要达到目则要求在复位按键按下后在RST引脚上要出现一个维持2个机器周期高电平4。考虑到可以利用电容电压不能突变(需要一定充放电时间),于是采用如下复位电路。图5复位电路 硬件原理图3 系统软件设计 它是利用单片机全双工串行通信口,实现单片机及单片机之间点对点串行通信,主从通信以及上,下位互相通信。然后数码管把他们内容在相应位置显示出来。在具体设计时按键采用中断方式工作,对LED显示在中断程序中实现,在发送端程序只是对键盘输入数据定义初始化,调用显示程序与控制程序初始化。本设计软件程序包括发送端程序、接收端程序、中断子程序、时钟显示子程序等等。另外电路中有按键控制程序。 本系
12、统软件设计分为发送机与接收机,发送机程序设计流程图如图6所示,接收机程序设计流程图如图7所示。数据发送完成?结束开始初始化读取数据送数码管显示数据发送至串口扫描按键NY 图6 发送端流程图数据接收完成?结束开始初始化读取数据送数码管显示NY触发串口中断?NY图7 接收端流程图3.3 按键程序设计单片机读取按键值方法有两种:查询方式与中断方式。查询方式是利用键盘程序不断查询是否有按键按下,有按下则进入相应按键子程序进行数据处理,没有则一直循环查询;中断方式是将按键动作及单片机中断系统联系起来,有按键按下时,就引起单片机中断,使系统进入中断处理程序。本设计中有16个按键,且主要程序就是按键处理,所
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 单片机 课程设计 实验 串行 通信
限制150内