310 likes | 557 Views
第 10 章 串行通讯和串行接口技术. 串行通信基础 可编程串行通信接口 8251. 10.1 串行通信基础(教材的 10.1-10.5 ). 串行通信的概念. 所谓串行通讯是指外设和计算机间使用一根数据信号线一位一位地传输数据,每一位数据都占据一个固定的时间长度。. “ 串行”是指外设与接口电路之间的信息传送方式, CPU 与接口之间仍按并行方式工作。. 串行通信的概念. 信息传输的检错和纠错. 串行数据在传输过程中,由于干扰可能引起信息的出错 如何发现传输中的错误,叫 检错 。 发现错误后,如何消除错误,叫 纠错
E N D
第10章 串行通讯和串行接口技术 • 串行通信基础 • 可编程串行通信接口8251
10.1 串行通信基础(教材的10.1-10.5) • 串行通信的概念 所谓串行通讯是指外设和计算机间使用一根数据信号线一位一位地传输数据,每一位数据都占据一个固定的时间长度。 “串行”是指外设与接口电路之间的信息传送方式,CPU与接口之间仍按并行方式工作。
信息传输的检错和纠错 • 串行数据在传输过程中,由于干扰可能引起信息的出错 • 如何发现传输中的错误,叫检错。 • 发现错误后,如何消除错误,叫纠错 • 最简单的检错方法是奇偶校验,即在传送字符的各位之外,再传送1位奇/偶校验位。可采用奇校验或偶校验。 • 奇校验:所有传送的数位(含字符的各数位和校验位)中,1的个数为奇数 • 偶校验:所有传送的数位(含字符的各数位和校验位)中,1的个数为偶数
信息传输的检错和纠错 奇偶校验能够检测出1位误码,但是不能纠错。 • 串行数据传输方式 全双工方式 通讯双方能同时进行发送和接收操作
串行数据传输方式 半双工方式 只有1根数据线传送数据信号,要求通讯双方的发送和接收由电子开关切换。 单工方式 只允许数据按照一个固定的方向传送
传输速率 在串行通讯中,用波特率来描述数据的传输速率 波特率,即每秒钟传送的二进制位数,简写为bps 接收时钟/发送时钟是波特率的倍数,称为波特率因子。 例如波特率因子为32,则32个时钟脉冲移位1次。 例:波特率=9600bps,波特率因子=16,则 接收时钟和发送时钟频率=9600×16=153600Hz
信号的调制和解调 采用普通通信线路进行远程数据通信时,需要在发送端用调制器(Modulator)把数字信号转换为模拟信号,模拟信号经通信线路传送到接收方,接收方再以解调器(Demodulator),把模拟信号变为数字信号。 大多数情况下,调制器和解调器合在一个装置中,称为调制解调器——Modem
信号的调制和解调 在通讯中,Modem起着传输信号的作用,是一种数据通讯设备,简称DCE 接收设备和发送设备称为数据终端设备,简称DTE。
串行通信的类型 串行通讯可以分为两种类型:同步通讯、异步通讯 异步通讯 一个字符一个字符地传输,每个字符一位一位地传输,传输一个字符时,以起始位开始,然后传输字符本身的各位,接着传输校验位,最后以停止位结束该字符的传输。一次传输的起始位、字符各位、校验位、停止位构成一组完整的信息,称为帧(Frame) 帧与帧之间可有任意个空闲位
异步通讯 异步通讯的信息格式 起始位 逻辑0 1位 数据位 逻辑0或1 5位、6位、7位、8位 校验位 逻辑0或1 1位或无 停止位 逻辑1 1位、1.5位或2位 空闲位 逻辑1 任意数量
异步通讯 例:传送8位数据45H(0100,0101B),奇校验,1个停止位,则信号线上的波形为
同步通讯 靠同步字符完成收发双方同步 多个字符成组传送,在每组信息的开始,加上同步字符,字符组和同步字符以及需要的其他字符构成一个信息帧 同步字符 字符1 字符2 …… 字符n 校验字符 数据块
串行通信的接口标准 在串行通信中,DTE(数据终端设备)和DCE(数据通讯设备)之间的连接要符合接口标准 计算机通信中使用最普遍的是RS-232C标准 PC机上的COM1、COM2接口,就是RS-232C接口,使用9针和25针连接器
串行通信的接口标准 DTE(数据终端设备)、DCE(数据通讯设备如MODEM) • TXD 发送 • RXD 接收 • SG 信号地 • DSR 数据通信设备(DCE)准备好 • DTR DTE(即微机接口电路,如8250/8251)准备好 • RTS DTE请求DCE发送 • CTS DCE允许DTE发送,该信号是对RTS信号的回答。 • DCD 数据载波检出 • 当本地DCE收到对方的DCE设备送来的载波信号时,使DCD有效,通知DTE准备接收,并且由DCE将接收到的载波信号解调为数字信号,经RXD线送给DTE。 • RI 振铃信号 • 当DCE收到交换机送来的振铃呼叫信号时,使该信号有效,通知DTE已被呼叫。
串行通信的接口标准 采用Modem(DCE)和电话网通信时的信号连接
串行通信的接口标准 采用专用线通讯时的信号连接
串行通信的接口标准 无Modem的标准连接
串行通信的接口标准 无Modem 的最简连接
10.6 可编程串行通信接口8251A 通过编程,可以实现异步通讯协议或面向字符的同步通讯协议,波特率:同步方式下:0-64Kbps;异步方式下:0-19.2Kbps。 同步方式下,每字符为5,6,7,8位,能自动检测同步字符,自动添加奇偶校验。 异步方式下,每字符可为5,6,7,8位,自动增加起始位、停止位和校验位。
8251的结构 模式寄存器:决定工作于同步或异步模式以及接收和发送的字符格式 同步字符寄存器:存放同步模式下的同步字符
8251的引脚信号 C/D#: 该信号一般连至地址线A0,用于选择控制端口/数据端口。数据输入输出寄存器合用一个端口,控制寄存器与状态寄存器合用一个端口。 TxE:通知CPU发送移位寄存器空。此时,在状态寄 存器的TxE位置1。CPU可以查询TxE信号或状态寄存器的TxE位 TxRDY:告诉CPU,8251已准备好发送,CPU可以为其提供需要发送的字符 RxRDY:通知CPU,8251已从外部设备收到一个字符,等待CPU读取。CPU可以查询该信号,或把该信号作为中断请求信号。
8251的引脚信号 SYNDET:同步检测信号,只用于同步方式 TXC、RXC: 8251没有内置的波特率发生器,必须由外部产生建立波特率的时钟信号,TXC、RXC通常与8253连接 /RTS:请求发送,请求modem作好发送准备 /CTS:清除发送(允许发送)信号输入线,当modem作好发送准备时,/CTS有效
8251的命令字与初始化编程 模式寄存器的格式 内同步:由8251自身来检测同步字符。 外同步:则由调制解调器和有关设备完成对同步字符的检测。测得同步字符后,调制解调器会通过SYNDET引脚往8251送一个信号,从而通知8251当前已经实现同步。
8251的命令字与初始化编程 控制寄存器与状态寄存器的格式 为1 时表示溢出错 为1 时表示奇偶校验错
8251的命令字与初始化编程 8251与CPU的数据交换 查询方式/中断方式 采用查询方式,在数据交换前应读取状态寄存器。 状态寄存器D0=1,CPU可以向8251数据端口写入数据,完成串行数据的发送 状态寄存器D1=1,CPU可以从8251数据端口读出数据,完成一帧数据的接收
8251编程示例 例:编写8251异步模式下的接收和发送程序,完成256个字符的发送和接收,设端口地址:208H,209H,波特率因子16,1起始位,1停止位,无奇偶校验,每字符8位。
发送程序 MOV DX,209H MOV AL,40H ;复位命令。 OUT DX,AL MOV AL,01001110B ;模式字 OUT DX,AL MOV AL,00110111B ;控制字 OUT DX,AL MOV CX,256 ;发送256字节 NEXT: MOV DX 209H IN AL,DX;状态字 AND AL,01H;TXRDY? JZ NEXT MOV AL,CL MOV DX,208H OUT DX,AL;发送 LOOP NEXT
接收程序 接收256字节,放在buf中 Data segment buf DB 256 dup(?) Data ends ┆ MOV DX,209H MOV AL,40H;复位 OUT DX,AL MOV AL,01001110B;模式字 OUT DX,AL MOV AL,00110111B;控制字 OUT DX,AL MOV CX,256 ;接收256字节 MOV SI,0 NEXT: MOV DX,209H IN AL,DX;状态字 AND AL,02H; RXRDY? JZ NEXT MOV DX,208H IN AL,DX;接收1字符 MOV buf[SI],AL INC SI LOOP NEXT