欢迎来到学术参考网

大连海事大学毕业设计(一)

发布时间:2015-07-04 20:31

  1引言

  1.1 设计的目及意义

  一般的pc与单片机之间的串行通信,需要单片机采集数据,然后用异步串行通讯方式传给pc机。相对而言比较的烦琐,而本文着重用vb具有面向对象的设计方法,友好的用户来探讨在vb环境下来实现pc机与51单片机之间串行通讯的方法。实现起来要简捷方便。

  随着计算机系统的应用和微机网络的发展,各种控制设备之间的通信功能越来越显得重要。尤其是伴随着单片微型机技术的发展,人们已越来越多地采用单片机来对一些工业控制系统中如温度、流量和压力等参数进行检测和控制。在本系统中,下位机采用一片at89s51单片机,用于对发送的数据实施控制,为了实现对输入数据的接收,上位机采用便携式pc机,上、下位机之间通过max232芯片实现串行数据通信。pc 机具有强大的监控和管理功能,而单片机则具有快速及灵活的控制特点,通过pc 机的rs-232 串行接口与外部设备进行通信,是许多测控系统中常用的一种通信解决方案。

  本文将论述在vb 环境下pc 机与单片机之间实现串行通讯的软硬件方案。实现单片机与 pc 机的相互通信。单片机部分由汇编语言实现,pc 机的通讯程序使用visual basic 编写,vb 是microsoft 公司推出的windows 应用程序开发工具,因其具有界面友好,编程简便等优点而受到广泛的使用,而且visual basic 6.0 版本带有专门实现串行通讯的mscomm 控件。因此如何实现pc 机与单片机之间的通讯具有非常重要的现实意义。

  利用vb6.0 的事件驱动方式可以很方便地开发数据采集与监控系统,用单台pc 机可以测量和监控多路控制信号,整控制系统设计方便,对小型测控系统的设计具有很大的实用性。

  1.2 设计实现的功能

  实现单片机与 pc 机的相互通信。具体要求有以下两点:

  ①单片机发固定编好的代码,在用 vb 编好的界面上接收;

  ②在 vb 编好的界面上发送数字,在单片机板上的数码管上显示出来。

  2 硬件设计方案

  为了实现pc机与单片机之间的串行通信,我们首先要清楚了解整个系统所采用的原理图。原理图就象一根红线贯穿于整个系统设计,通过此图我们就能很清楚的看到系统所涉及的内容,然后鉴于此,我们将在以后的章节中依次对所牵涉的内容作详细的论述。下面对原理图作一点说明:从max232芯片中的两路发送接收中任选一路作为接口,要注意其发送与接收引脚对应,否则可能对器件或计算机串口造成永久性损坏。如选他t1in接单片机的发送端txd,则pc机、的rs—232的接收端rd一定要对应接t1out引脚。同时,r1out接单片机的接受端rxd引脚,则pc机的rs—232的发送端td一定要对应接r1in引脚。

上图为采用max232芯片接口的pc机与51单片机串行通信接口原理图

2.1 at89s51单片机

2.1.1 at89s51单片机简介

at89s51 为 atmel 所生产的可电气烧录清洗的 8051 相容单芯片,是一个低功耗,高性能cmos 8位单片机,片内含4k bytes isp(in-system programmable)的可反复擦写1000次的flash只读程序存储器,器件采用atmel公司的高密度、非易失性存储技术制造,兼容标准mcs-51指令系统及80c51引脚结构,芯片内集成了通用8位中央处理器和isp flash存储单元,功能强大的微型计算机的at89s51可为许多嵌入式控制应用系统提供高性价比的解决方案。

  at89s51具有如下特点:40个引脚,4k bytes flash片内程序存储器, 128 bytes的随机存取数据存储器(ram),32个外部双向输入/输出(i/o)口,5个中断优先级2层中断嵌套中断,2个16位可编程定时计数器,2个全双工串行通信口,看门狗(wdt)电路,片内时钟振荡器。

  2.1.2 at89s51单片机的功能

at89s51主要功能列举如下:

1)为一般控制应用的8位单芯片   2)晶片内部具有时钟振荡器

3)内部程式存储器(rom)为 4kb 4)内部数据存储器(ram)为 128b

5)外部程序存储器可扩充至 64kb  6)外部数据存储器可扩充至 64kb

7)32 条双向输入输出线,且每条均可以单独做 i/o 的控制

8)5个中断向量源         9)2组独立的 16 位定时器

10)1个全多工串行通信端口    11)8751 及 8752 单芯片具有数据保密的功能

12)单芯片提供位逻辑运算指令

2.1.3 at89s51各引脚功能介绍:

vcc:at89s51 电源正端输入,接+5v。

vss:电源地端。

xtal1:单芯片系统时钟的反相放大器输入端。

xtal2:系统时钟的反相放大器输出端。

reset:at89s51的重置引脚,高电平动作。

ea/vpp:存取外部程序代码,低电平动作。

ale/prog:地址锁存器启用信号。

psen:程序储存启用,通常这支脚是接到eprom的oe脚。

  port0(p0.0~p0.7):端口0是一个8位宽的开路汲极(open drain)双向输出入端口,共有8个位,p0.0表示位0,p0.1表示位1,依此类推。其他三个i/o端口(p1、p2、p3)则不具有此电路组态,而是内部有一提升电路,p0在当作i/o用时可以推动8个ls的ttl负载。如果当ea引脚为低电平时(即取用外部程序代码或数据存储器),p0就以多工方式提供地址总线(a0~a7)及数据总线(d0~d7)。

  port2(p2.0~p2.7):端口2是具有内部提升电路的双向i/o端口,每一个引脚可以推动4个ls的ttl负载,若将端口2的输出设为高电平时,此端口便能当成输入端口来使用。p2除了当作一般i/o端口使用外,若是在at89s51扩充外接程序存储器或数据存储器时,也提供地址总线的高字节a8~a15,这个时候p2便不能当作i/o来使用了。

  port1(p1.0~p1.7):端口1也是具有内部提升电路的双向i/o端口,其输出缓冲器可以推动4个ls ttl负载,同样地若将端口1的输出设为高电平,便是由此端口来输入数据。

  port3(p3.0~p3.7):端口3也具有内部提升电路的双向i/o端口,其输出缓冲器可以推动4个ttl负载,同时还多工具有其他的额外特殊功能,包括串行通信、外部中断控制、计时计数控制及外部数据存储器内容的读取或写入控制等功能。

其引脚分配如下:

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,外部数据存储器的读取信号。

本系统所采用的at89s51芯片如下图所示:

  2.1.4 at89s51 isp

  isp为在线编程接口。isp在线编程接口为89s51单片机提供了方便的在线编程方法,使用时将isp下载线一端与pc并口相连接,一端与isp接口相连,使用isp下载软件即可实现mcu在线编程。

下载线插接说明:两排十针下载口,板图上都有一个小方框,为1号引角;下载线的凸口为正方向,凸口的右侧边的第一个插孔为1号引角,这一点一定要切记,不然的话程序下载不进去。

本系统中所用at89s51 isp原理图如下示:

at89s51 isp

  2.2串行通讯

  2.2.1串行通讯的概念

  串行通讯:一条信息的各位数据被逐位按顺序传送的通讯方式称为串行通讯。

  串行通讯的特点是:数据位传送,传送按位顺序进行,最少只需一根传输线即可完成,成本低但传送速度慢。串行通讯的距离可以从几米到几千米。

  分类:根据信息的传送方向,串行通讯可以进一步分为单工、半双工和全双工三种。

  2.2.2 rs-232c 串口通讯原理

  rs-232c是目前最常用的串行接口标准,用来实现计算机与计算机之间,计算机与外设之间的数据通信。

  rs-232c串行接口总线适用于设备之间的通信距离不大于15米,传输速率最高为19.2kb/s的场合。rs-232c标准规定的数据传输速率为50、75、100、150、300、600、1200、2400、4800、9600、和19200b/s。rs-232c属单端信号传送,存在共地噪声和不能抑制的共模干扰等问题,因此一般用于短距离通信。

  1) rs-232c接口信号

  一个完整的rs-232c接口有22根线,采用标准的25芯连接器。

  2) rs-232c 典型应用

  用rs-232c总线连接系统时,有近程通信方式和远程通信方式之分。近程通信是指传输距离小于15米的通信,这时可以用rs-232c电缆直接连接。15米以上的长距离通信,需要采用调制解调器。

  下图a)是计算机与终端之间利用rs-232c直接通信的最常用的交叉连线图。图中“发送数据”与“接收数据”是交叉相连的,使得两台设备都能正确地发送和接收。“数据终端变绪”与“数据装置就绪”两根线也是交叉相连的,使得两设备都能检测出对方是否已经准备好。

  在最简单的全双工系统中,公用发送数据、接收数据和信号地三根即可。对mcs-51单片机来说,利用rxd(串行数据接收端)线、txd(串行数据发送端)线以及一根地线,就可以构成符合rs-232c接口标准的全双工串行通信口。(见图b)

(a)直接连接

(b)最简单的rs-232c数据通信连接
  3) rs-232c接口电平转换

  rs-232c是早期为促进公用电话网络进行数据通信而制定的标准,其逻辑电平对地是对称的,完全与ttl、cmos逻辑电平不同。

rs-232c采用负逻辑,即:

逻辑1:-5v~-15v。 逻辑0:+5v~+15v。

  由于mcs-51采用ttl电平,若用rs-232c标准接口通信必须进行电平转换。目前rs-232c与ttl电平转换最常用的集成电路芯片是传输线驱动器mc1488传输线接收器mc1489。其内部结构和引脚如下图(c)所示。

  mc1488可完成ttl电平到rs-232c的电平转换,输入为ttl电平,输出为rs-232c电平。其内部有3个与非门和1个反相器。采用±12v或±15v电源供电。

  mc1489可完成由rs-232c到ttl电平转换,输入为rs-232c电平,输出为ttl电平。其内部有4个反相器,采用+5v电源供电。mc1489中每个反相器都有一个控制端,高电平有效,可作为rs-232c操作的控制端。图(d)给出了rs-232c接口电路原理图。


(c)rs-232c电平转换芯片mc1488和mc1489

(d) rs-232c接口电路

max232芯片

  max232芯片是美信公司专门为电脑的rs-232标准串口设计的接口电路,使用+5v单电源供电。它的内部结构基本可分三个部分;

  第一部分是电荷泵电路。由1、2、3、4、5、6脚和4只电容构成。功能是产生+12v和-12v两个电源,提供给rs-232串口电平的需要。

  第二部分是数据转换通道。由7、8、9、10、11、12、13、14脚构成两个数据通道。其中13脚(r1in)、12脚(r1out)、11脚(t1in)、14脚(t1out)为第一数据通道。8脚(r2in)、9脚(r2out)、10脚(t2in)、7脚(t2out)为第二数据通道。ttl/cmos数据从t1in、t2in输入转换成rs-232数据从t1out、t2out送到电脑dp9插头;dp9插头的rs-232数据从r1in、r2in输入转换成ttl/cmos数据后从r1out、r2out输出。

  第三部分就是供电。15脚dng、16脚vcc(+5v)。

  2.2.3 串行接口

  控制串行接口的寄存器有两个,即特殊功能寄存器pcon和scon。

  1)pcon中的波特率选择位

  pcon是一个特殊功能寄存器(如下图所示),没有位寻址功能,字节地址为87h。其中d7位(smod)为波特率选择位。其他位均无意义。复位时的smod值为0。可用mov pcon。#80h或mov 87h,#80h指令使该位置1。当smod=1时,在串行接口方式1、2或3情况下,波特率提高一倍。

d7 d0

pcon

smod

波特率选择位 | 无定义位 |


2)串行接口控制寄存器 scon

特殊功能寄存器scon用于定义串行接口的操作方式和控制它的某些功能。其字节地址为98h。寄存器中各位内容如下:

scon


位 d7 d6 d5 d4 d3 d2  d1 d0

位地址

9f

9e

9d

9c

9b

9a

99

98

sm0

sm1

sm2

ren

tb8

rb8

ti

ri

sm0,sm1 串行接口操作方式选择位。两个选择位对应于四种状态,所以串行接口能以四种方式工作。

sm2 允许方式2和3的多机通信使能位。

ren 允许串行接收位。由软件置位或清0,使允许接收或禁止接收。

tb8 是在方式2和3中要发送的第9位数据可按需要由软件置位或复位

rb8 是方式2和3中已接收到的第9位数据。

ti 发送中断标志。

ri 接收中断标志。

串行接口工作方式

串行接口的操作方式由sm0、sm1定义,编码和功能如下表所示

串行接口方式选择

sm0 sm0

方式

功能说明

波特率

0 0

0

移位寄存器方式

fosc/12

0 1

1

8位uart

可变

1 0

2

9位uart

fosc/64或fosc/32

1 1

3

9位uart

可变

2.2.4 tmod介绍

定时器/计数器t0、t1 的方式寄存器tmod

字节地址为89h。tmod的格式如下:低4位用来定义t0,高4位用来定义t1d7

  d7 d6 d5 d4 d3 d2 d1 d0

gate

c/t

m1

m0

gate

c/t

m1

m0

|

t1 | t0 |

各位的意义如下:

1、 gate——门控位。

gate=1时,由外部中断引脚、和tr0、tr1共同来启动定时器。当引脚为高电平时,tr0置位启动定时器t0;当引脚为高电平时,tr1置位,启动定时t1。

gate=0时,仅由tr0和tr1置位来启动定时器t0和t1。

上一篇:地铁列车自动运行系统的分析与设计

下一篇:劈裂注浆技术在软流塑地层加固中的应用