微机原理串口通信课程设计概要文档格式.docx
《微机原理串口通信课程设计概要文档格式.docx》由会员分享,可在线阅读,更多相关《微机原理串口通信课程设计概要文档格式.docx(13页珍藏版)》请在冰豆网上搜索。
2.2.1波特率因子寄存器(DLL/DLH)
8250芯片规定当线路控制寄存器写入D7=1时,接着对口地址3F8H、3F9H可分别写入波特率因子的低字节和高字节,即写入除数寄存器(L)和除数寄存器(H)中。
而波特率为1.8432MHZ/(波特率因子╳16),波特率和除数对照表见下表:
十进制
十六进制
波特率
1047
417
110
768
300
100
384
180
192
C0
600
96
60
1200
48
30
2400
24
18
4800
12
C
9600
2.2.2通信线路控制寄存器(LCR)(3FBH)
该寄存器规定了异步串行通信的数据格式。
各位含义如下:
D7
D6
D5
D4
D3
D2
D1
D0
DLAB
SB
SP
EPS
PEN
STB
WLS1
WLS0
其中:
D1~D0是字长。
它们的取值和对应的字长如下表:
00
5位
01
6位
10
7位
11
8位
D2是停止位。
它的取值和对应的停止位如下表:
1位
1
15位(数据位5位)
2位(数据位6、7、8位)
D3说明是否允许奇偶校验。
如果为0无奇偶校验,如果为1允许奇偶校验。
D4说明是奇校验还是偶校验。
如果为0是奇校验,如果为1是偶校验。
这一位起作用的前题是D3为1。
D5说明是否有附加奇偶校验位。
如果为0无附加奇偶校验位,如果为1有附加奇偶校验位。
D6如果为0正常,如果为1发空缺位。
D7如果为0允许访问接收、发送数据寄存器或中断允许寄存器。
如果为0允许访问波特率因子寄存器。
通信线路控制寄存器LCR主要用来指定异步通信数据格式,即字符长度、停止位位数、奇偶校验。
LCR的控制字如下
2.2.3通信线路状态寄存器(3FDH)
该寄存器向CPU提供有关数据传输的状态信息,各位含义如下:
TSRE
THRE
BT
FE
PE
OE
DR
D0:
DR,接收数据就绪D1:
OE,数据重叠错D2:
PE,数据奇偶错
D3:
FE,缺少正确停止位D4:
BI,接收空缺位D5:
THRE,发送保持器空
D6:
TSRE,发送移位寄存器空
读入时各数据位等于1有效,读入操作后各位均复位。
除D6位外,其它位还可被CPU写入,同样可产生中断请求。
2.2.4中断允许寄存器(3F9H)
该寄存器允许8250四种类型中断(相应位置1)并通过IRQ4向8088CPU发中断请求。
EMSI
ELSI
ETBEI
ERBFI
为1允许接收缓冲区满中断
D1:
为1允许发送保持器空中断
D2:
为1允许接收数据出错中断
为1允许Modem状态改变中断
2.2.5中断识别寄存器(3FAH)
为了具体识别时哪种事件引起的中断,直到该中断请求被CPU响应并服务之后,才能接收其他的中断请求。
该寄存器为只读寄存器,内容格式为
ID2
ID1
IP
2.2.6调制解调控制寄存器(3FCH)
MODEM控制寄存器用来设置对MODEM的联络控制信号和芯片自检,寄存器的各位定义
LOOP
OUT2
OUT1
RTS
DTR
DTR=1,数据终端就绪,输出端DTR为低电平
RTS=1,请求发送,输出端RTS为低电平
OUT1=1,用户指令输出,输出端OUT1为低电平
OUT2=1,输出端OUT2为低电平,允许发送IRQ4中断请求
D4:
循环(自诊断用)=1,发送数据立即被接收,可用于自检
2.2.7MODEM状态寄存器(3FEH)
Modem状态寄存器用来检测和记录来自Modem的联络信号及其状态变化。
此寄存器的各位定义为:
RLSD
RI
DSR
CTS
△RLSD
△RI
△DSR
△CTS
2.2.8发送保持寄存器和接收缓冲寄存器(3F8H)
发送时,CPU首先将待发送的字符写到8250的发送保持寄存器THR中,然后进入发送移位寄存器,在发送始终的作用下,从SOUT引脚输出。
一旦THR的内容送到发送移位寄存器TSR后,THR就变空,同时将LSR的THRE位置“1”,产生中断请求,要求CPU发送下一个字符。
CPU向THR写入下一个字符后,THRE位自动清“0”。
如此重复,直到全部数据发送完毕。
接收时,串行数据在接收时钟的作用下,从SIN引脚先输入到移位寄存器RSR,然后由RSR并行输入到接收缓冲寄存器RBR,一旦RBR变满,将LSR的DR位置“1”,产生中断请求,要求CPU读取数据字符。
CPU从RBR读取该字符后,DR位自动清“0”。
如此重复,直到所有的数据接收完毕。
2.38250的各寄存器的地址
寄存器
COM1端口下的地址
COM2端口下的地址
发送保持寄存器(THR)
3F8H
2F8H
接收数据寄存器(RBR)
低字节波特率因子(设置工作方式控制字D7=1)(LSB)
高字节波特率因子(设置工作方式控制字D7=1)(MSB)
3F9H1
2F9H1
中断允许寄存器(IER)
3F9H
2F9H
中断识别寄存器(IIR)
3FAH
2FAH
线路控制寄存器(LCR)
3FBH
2FBH
MODEM控制寄存器(MCR)
3FCH
2FCH
线路状态寄存器(LSR)
3FDH
2FDH
MODEM状态寄存器(MSR)
3FEH
2FEH
3程序设计
3.1程序设计思路
根据设计要求,要实现通过串口进行通信,就必须有一个发送端和一个接收端,因此要编写两个程序,在发送端编写发送程序,在接受端编写接收程序。
发送PC机和接收PC机通过RS-232C的3根信号线(TXD、RXD、GND)进行相连。
我决定采用查询方式编写发送程序和接收程序。
编写发送程序的时候,首先要初始化段寄存器,设置发送缓冲区指针。
然后初始化8250,通过初始化8250来设置串口的参数。
再根据线路状态寄存器的内容,测试发送保持寄存器是否为空,如果不为空,继续读线状态寄存器的内容,判断发送保持寄存器是否为空,如果为空的话,读取按键字符并显示和发送它。
我事先规定当输入某一个字符的时候发送结束,这时候我就要判断按键是否为该字符,是该字符的时候结束程序。
编写接收程序的时候首先要设置接收缓冲区,设置接收错信息,初始段寄存器,设置接收缓冲寄存器地址指针然后初始化8250,初始设置和接收端的保持一置。
以上完成后开始接收,在屏幕上显示接收开始。
然后读线状态寄存器,判断是否接收错,在屏幕上显示接收错误,继续读线状态寄存器,如果接收无误,则测试接收数据是否准备好了,为准备好则循环测试,准备好了则接收字符。
判断接收的字符是否为规定的结束字符,如果是结束程序,如果不是显示字符。
两台机器的连接图如下。
3.2程序流程图
3.2.1发送端程序流程图
3.2.2接收端的程序流程图
3.3具体的程序
3.3.1发送端的程序代码
STACKSEGMENTPARASTACK'
STACK'
DB200DUP(0)
STACKENDS
DATASEGMENT
DISPDB'
TRANSMISSIONSTART:
'
0AH,0DH,'
$'
DATAENDS
CODESEGMENT
ASSUMECS:
CODE,DS:
DATA,SS:
STACK
START:
MOVAX,DATA
MOVDS,AX
MOVAX,STACK
MOVSS,AX
MOVDX,3FBH;
置DLAB=1
MOVAL,80H
OUTDX,AL
MOVDX,3F8H;
置波特率因子寄存器
MOVAL,0CH;
波特率因子低字节
OUTDX,AL
MOVDX,3F9H
MOVAL,0;
波特率因子高字节
置线路控制寄存器
MOVAL,03H;
数据位8位,停止位1位、无校验
MOVDX,3FCH;
置MODEM控制寄存器
MOVAL,02H;
禁止中断
MOVDX,3F9H;
置中断允许寄存器
屏蔽所有中断
MOVDX,OFFSETDISP;
显示发送提示信息
MOVAH,9
INT21H
LO0P:
MOVDX,3FDH;
读线路状态寄存器
INAL,DX
TESTAL,20H;
测试发送保持寄存器
JZL0OP;
不空,则循环测试
MOVAH,1;
读取按键字符并显示
发送该字符
CMPAL,’P’;
判断按下的字符是否为P
JZOVER;
是,则结束
JMPLOP;
不是继续循环
OVER:
MOVAH,4CH;
返回DOS
CODEENDS
END