当前位置首页 > 百科资料> 正文

SCON控制寄存器

2022-06-25 05:04:17 百科资料

SCON(Serial Control Register)串行口控制寄存器,用于控制串行通信的方式选择、接收和发送,指示串口的状态。SCON既可以字节寻址,也可以位寻址,其字节地址为98H,地址位为98H~9FH。

  • 中文名称 SCON控制寄存器
  • 外文名称 Serial Control Register
  • 字节地址 98H
  • 地址位为 98H~9FH

寄存器简介

  结构

  SCON寄存器各位定义

  D7

  D6

  D5

  D4

  D3

  D2

  D1

  D0

  SM0

  SM1

  SM2

  REN

  TB8

  RB8

  TI

  RI

  9FH

  9EH

  9DH

  9CH

  9BH

  9AH

  99H

  98H

  工作方式(SM0 SM1)

  (1)方式0( SM0 SM1 :0 0):串行口的工作方式0为移位寄存器I/O方式,可外接移位寄存器,一扩展I/O口,也可外接同步I/O设备。 发送操作:当执行一条"MOVSBUF,A"指令时,启动发送操作,由TXD输出移位脉冲,由RXD串行SBUF中的数据。发送完8位数据后自动置TI=1.请求中断。要继续发送时,TI必须有指令清零。 接收操作:REN是串行口接收允许控制位。REN=0时禁止接收;REN=1时允许接收。当软件将REN置"1"时,即开始从RXD端口以fosc/12波特率输入数据,当接收到8位数据时,将中断标志RI置"1"。再次接收数据之前,必须用软件将RI清0。

  (2)方式1 ( SM0 SM1 :0 1) :串行口为10位通用异步接口。发送或接收一帧数据信息为10位,包括1位起始位"0"、8位数据位、1位停止位"1"。发送数据:数据从TXD端口输出,当数据写入发送缓冲器SBUF时,就启动发送器发送。发送完一帧数据后,置中断标志TI=1,申请中断,通知CPU可以发送下一个数据了。接收数据:首先使REN=1(允许接收数据),串行口从RXD接收数据,当采样到1至0跳变时,确认是起始位"0",就开始接收一帧数据,当接收完一帧数据时,置中断标志RI=1,申请中断,通知CPU从SBUF取走接收到的数据 。

  (3)方式2 ( SM0 SM1 :1 0) :串行口为11位异步通信接口。发送或接收一帧信息包括1位起始位"0"、8位数据位、1位可编程位、1位停止位"1"。发送数据:发送前,先根据通信协议由软件设置TB8为"奇偶校验位"或"数据标识位",然后将要发送的数据写入SBUF,即能启动发送器。发送过程是由执行任何一条以SBUF为目的寄存器的指令而启动的,把8位数据装入SBUF,同时还把TB8装到发送移位寄存器的第9位上,然后从TXD(P3.1)端口输出一帧数据。接收数据:先置REN=1,使串行口为允许接收状态,同时还要将RI清"0"。然后再根据SM2的状态和所接收到的RB8的状态决定此串行口在信息到来后是否置RI=1,并申请中断,通知CPU接收数据。当SM2=0时,不管RB8为"0"还是为"1",都置RI=1,此串行口将接收发送来的信息。当SM2=1时,且RB8=1,表示在多机通信情况下,接收的信息为"地址帧", 此时置RI=1,串行口将接收发来的地址。当SM2=1时,且RB8=0,表示在多机通信情况下,接收的信息为"数据帧", 但不是发给本从机的,此时RI不置为"1",因而SBUF中接收的数据帧将丢失。

  (4)方式3 ( SM0 SM1 :1 1) :为波特率可变的11位异步通信方式,除了波特率有所区别之外,其余方式都与方式2相同。

各控制位

  SM0、SM1

  --串行口工作方式控制位

  SM0

  SM1

  工作方式

  功能

  波特率

  0

  0

  方式0

  8位同步移位寄存器

  晶振频率/12

  0

  1

  方式1

  10位UART

  可变

  1

  0

  方式2

  11位UART

  晶振频率/64或晶振频率/32

  1

  1

  方式3

  11位UART

  可变

  SM2

  --多机通信控制位

  多机通信是工作于方式2和方式3,SM2位主要用于方式2和方式3。接收状态,当串行口工作于方式2或3,以及SM2=1时,只有当接收到第9位数据(RB8)为1时,才把接收到的前8位数据送入SBUF,且置位RI发出中断申请,否则会将接收到的数据放弃。当SM2=0时,就不管第9位数据是0还是1,都会将数据送入SBUF,并发出中断申请。

  工作于方式0时,SM2必须为0。

  REN

  --允许接收位

  REN用于控制数据接收的允许和禁止,REN=1时,允许接收,REN=0时,禁止接收。

  TB8

  --发送数据位8

  在方式2和方式3中,TB8是要发送的--即第9位数据位。在多机通信中同样亦要传输这一位,并且它代表传输的地址还是数据,TB8=0为数据,TB8=1时为地址。

  RB8

  --接收数据位8

  在方式2和方式3中,RB8存放接收到的第9位数据,用以识别接收到的数据特征。

  TI

  --发送中断标志位

  可寻址标志位。方式0时,发送完第8位数据后,由硬件置位,其它方式下,在发送或停止位之前由硬件置位,因此,TI=1表示帧发送结束,TI可由软件清"0"。

  RI

  --接收中断标志位

  可寻址标志位。接收完第8位数据后,该位由硬件置位,在其他工作方式下,该位由硬件置位,RI=1表示帧接收完成。

  在串口中断处理时,TI,RI都需要软件清"0",硬件置位后不可能自动清0,此外,在进行缓冲区操作时,需要ES=0,以防止中断出现。

声明:此文信息来源于网络,登载此文只为提供信息参考,并不用于任何商业目的。如有侵权,请及时联系我们:baisebaisebaise@yeah.net