5)SCI串行通信接口
串行通信接口SCI
串行通信分为同步通信和异步通信。
串行通信接口都具有发送引脚TXD和接收引脚RXD,它们是TTL平电。
如果要利用这两个引脚与外界实行异步通信,必须将TTL电平转化为RS-232电平。
SCI是一种全双工异步串行通信接口,主要用于MCU与其他计算机或设备之间的通信,几个独立的MCU也能通过SCI实现串行通信,形成网络。
从编程角度看,先设定好波特率,通信格式,是否校验,是否允许中断等。
接着发送数据时,先检查相应的标志位是否允许发送数据,如果可以,则把数据放入SCI数据寄存器即可,剩下的工作芯片自动完成:将数据从SCI数据寄存器送到发送移位寄存器,硬件驱动将发送移位寄存器里的数据按规定发送到发送引脚TXD,供对方接收。
接收时,数据逐位从接收引脚RXD进入到接收移位寄存器,当收到一个完整字节时,芯片会自动将数据送到SCI数据寄存器,并置相应的标志位,我们就可以根据标志位的情况来读取数据了。
SCIBDH:TNP[1:0]:发送窄脉冲位。
此位的设定与SCI传送的脉冲对应关系如下表:SCIBDL:SBR[12:0]:波特率设定位当IREN=0时,SCI波特率=SCI总线时钟/(16*SBR[12:0])当IREN=1时,SCI波特率=SCI总线时钟/(32*SBR[12:1])SCICR1:控制寄存器1(当AMAP=0时有效)LOOPS:循环模式选择位。
LOOPS=0时,为正常模式。
LOOPS=1时,为自发自收模式,在此模式下,RXD引脚与SCI内部断开,内部发送数据直接作为接收的输入,用于测试。
接收器的输入由RSRC位决定。
SCISWAI:当SCISWAI=0时,SCI可以在等待模式下工作。
当SCISWAI=1时,SCI 不可以在等待模式下工作。
RSRC:当LOOPS=1时,RSRC位决定接收移位寄存器接收数据的来源。
RSRC=1,RXD引脚与SCI模块断开,SCI用TXD引脚来发送及接收。
RSRC=0时,发送器的输出作为接收器的输入。
第五章2_串行通信接口
PIE 模块
图6-1-1 SCI与CPU接口图
第5.2节 串行通信接口(SCI)
一、概述
√四个错误检测标志位:奇偶性、溢出、帧和间断检测。 √两种唤醒多处理器模式:空闲线唤醒和地址位唤醒。 √半双工或全双工通信。 √双缓冲接收和发送功能。 √发送器和接收器可通过带有状态标志的中断驱动或polled算法完成操作。 √独立的发送和接收中断使能位(BRKDT除外)。 √ NRZ格式。 √ 13个SCI模块控制寄存器,起始地址为7050H。 √自动波特率检测硬件逻辑(比F240x多出的功能)。 √ 16级发送/接收FIFO(比F240x多出的功能)。
第5.2节 串行通信接口(SCI)
二、SCI 结构特点
SCI 可编程数据格式
▲ SCI接收和发送的数据都采用NRZ格式: √ 1个起始位; √ 1~8位数据; √ 1个奇、偶或无校验位(可选); √ 1~2位停止位; √ 1个区分数据与地址的附加位(仅用于地址位模式)。 ▲字符 —— 数据的基本单元称为,其长度为1~8位。每一个字符包含1个
▲ 对接收到的数据进行间断、奇偶性、溢出和帧错误检测 ▲ 通过使用16位的波特率选择寄存器能设置不同的位速率
第5.2节 串行通信接口(SCI)
一、概述
▲ SCI与CPU之间的接口图如P149 所示 ▲ SCI模块主要特点如下 √两个多功能复用引脚,如果不用于SCI通信,可以作为通用I/O口。
SCITXD:数据发送引脚; SCIRXD:数据接收引脚。
第5.2节 串行通信接口(SCI)
二、SCI 结构特点
空闲线多处理器模式
空闲线多处理器模式(ADDR/IDLE MODE=0)中,块 , 与块之间的空闲时间大于块中各帧之间的空闲时间。如果一 帧之后有10个或更多的高电平位的空闲时间,就表明了下一 个新数据块的开始。每位的时间可以由波特率值(位每秒) 计算出来。空闲线多处理器模式(ADDR/IDLE MODE位是 SCICCR.3)通信格式P255所示。
sci串口通信原理
sci串口通信原理SCI(Serial Communication Interface,串行通信接口)是一种广泛应用于嵌入式系统和电子设备中的串行通信协议。
SCI通常指的是UART(Universal Asynchronous Receiver/Transmitter,通用异步收发传输器)的一种实现方式。
在SCI通信原理中,数据以串行的方式通过一根或多根信号线进行发送和接收。
基本的通信参数包括波特率(bits per second, bps)、数据位数、停止位数和校验类型等。
1. 波特率:指每秒钟传输的比特数,是通信双方必须同步的一个重要参数。
2. 数据格式:1)数据位数(Data Bits):通常为5、6、7或8位。
2)停止位(Stop Bits):通常为1或2位,用于表示一个字符数据包的结束。
3)校验位(Parity Bit):奇偶校验,可选无校验、奇校验或偶校验,用于检测数据传输过程中可能出现的错误。
3. 通信过程:1)发送端将并行数据转换为串行数据,并按照设定的波特率和格式输出。
2)接收端则按照相同的参数设置解码接收到的串行数据,还原成并行数据。
4. 控制信号:1)RTS (Request to Send) 和CTS (Clear to Send) 用于硬件握手,确保双方都准备好进行通信。
2)DTR (Data Terminal Ready) 和DSR (Data Set Ready) 另一对硬件握手信号,用于设备之间表明就绪状态。
3)TXD (Transmit Data) 是发送数据的信号线,RXD (Receive Data) 是接收数据的信号线。
4)其他可能还包括中断请求线(如IRQ)等。
在嵌入式系统中,例如使用TMS320F28xx系列DSP芯片时,SCI模块负责处理这些串行通信任务,通过配置相应的寄存器来设定上述参数,然后利用中断机制实现在数据发送和接收过程中的实时响应与处理。
DSP课件-SCI串行通信接口
8255A
打印机插座
CPU
PA0~7
PC7 PC2
地
DATA0~7
STB BUSY 地
8255A并行打印机接口电路框图
3
串行通信概述
串行通信:通信线上既传输数据信息,也传输联络信息,因 此收发双方就必须要有通信协议。特点是串行传输成本低, 适用于远距离通信,但传输速度低。 串行通信分类:1)同步通信;2)异步通信。
同步通信:发送器和接收器通常使用同一时钟源来同步。方法是在发送器 发送数据时同时包含了时钟信号,接收器利用该时钟信号进行接收。 异步通信:收发双方的时钟不是同一个时钟,是由双方各自的时钟实现数 据的发送和接收。但要求双方使用同一标称频率,允许有一定偏差。 同步方法:要正确传输字符,准确读取每一位是必须用各自的时钟同步的, 为克服不同时钟的偏差,每个字符都有一个起始位进行同步。
发送过程:在FIFO功能使能的情况下,缓冲寄存器SCITXBUF从TX FIFO中获 取要发送的数据,然后将数据传输给发送移位寄存器TXSHF,若SCI的发送功 能使能,将接收到的数据逐位的移到SCITXD引脚上。
8
SCI的数据格式
SCI的数据格式包括: 一个开始位 1~8个数据位(通常为8位) 一个奇/偶校验位或无奇偶校验位 1~2个停止位 区分地址和数据的附加位(仅地址位模式时存在)
CPU SCIRXBUF
每个字符6个数据位
RXSHF
SCIRXD
地址位模式
12
通信过程中的发送器信号 3个数据位
地址位模式
1)TXENA=1(SCICTL1.D1),使能发送器发送数据; 2)程序写数据到SCITXBUF寄存器,此时发送器不为空,TXRDY变低; 3)SCI发送数据到移位寄存器TXSHF后,产生中断请求,同时TXRDY变高; 4)TXRDY变高后,程序写第二个字符到SCITXBUF,随后TXRDY又变低; 5)发送完第一个字符,开始将第二个字符移位到寄存器TXSHF;
SCI
SCI(serial communication interface)串行通信接口SCI 是一个双线的异步接口,即具有接受和发送两根信号线的异步接口,一般可以看着UART(通用异步接收/发送装置),SCI可以工作在查询和中断的方式实例:设计时使用MAX3232芯片将SCI 设计成串口RS232,那么X2812就可以和其他使用RS232接口的设备进行通信,当然也可设计成其他电平形式的串口,如RS485。
2812具有2个相同的SCI 模块,SCIA,SCIB 。
每个模块都有一个接收器和发送器,发送器和接收器都具有一个16级深度的FIFO 队列。
它们都自己独立的使能位和中断位。
工作模式:一.SCI 模块的特点1. 有两个引脚,发送SCITXD 和接收SCIRXD ,分别对应FPIOF 模块的第4位和第5位。
在编程初始化时,需要将GPIOFMUX 寄存器的第4位和第5位置1,否则这两个引脚就是通用数字I/O 口。
2. 外部晶振通过PLL 模块倍频之后产生了CPU 的系统时钟SYSCLKOUT ,经低速时钟预定标器之后输出低速外设时钟LSPCLK 提供给SCI 模块,要保证SCI 正常运行,系统控制模块必须使能SCI 时钟,只有使能了,LSPCLK 才能供给SCI 。
也就是在系统初始化函数中需要将外设时钟控制寄存器PCLKCR 的SCIAENCLK 位置1.3. SCI 具有4种错误检测标志:极性错误,超时错误,帧错误,间断检测A A ABB B单工,A 只发,B 只接半双工,A,B 都可发,同一时刻只能接收或发送全双工,任何时刻,都可发4.具有双缓冲接收和发送功能,接收缓冲寄存器位SCIRXBUF,发送缓冲寄存器为SCITXBUF。
独立的发送器和接收器使得SCI可以工作于半双工或全双工5.可以产生两个中断:SCIRXINT和SCITXINT,即接收中断和发送中断,SCI模块具有独立的发送中断使能位和接收中断使能位,发送和接收可以通过中断方式实现,也可以查询中断方式是实现6.在多处理器模式下,SCI模块具有两种唤醒方式:空闲线方式和地址位方式。
SCI串行通信
实验五SCI串行通信一.实验目的1.了解串行通讯的基本原理;2. 掌握SCI接口通信的工作原理和典型编程方法。
二.实验设备1.PC机一台,操作系统为WindowsXP (或Windows98、Windows2000),安装了ccs3.1;2.TI 2000系列的TMS320F2812 eZdsp开发板一块;3.扩展实验箱一台。
三.实验原理1.串行通信接口(SCI)是采用双线制通信的异步串行通信接口(UART)。
SCI模块采用标准非归零(NRZ)数据格式,能够实现多CPU之间或同其他具有兼容数据格式SCI端口的外设进行数据通信。
SCI的接收器和发送器都支持16级接受和发送FIFO,有着各自独立的中断和使能位,可以独立地操作实现半双工通信,或者同时操作实现全双工通信。
为保证数据完整,SCI模块对接受的数据进行间断、极性、超限和帧错误的检测。
为减少软件的负担,SCI采用硬件对通信数据进行极性和数据格式检测。
通过对16位的波特率控制寄存器进行编程,配置不同的SCI通信速率。
SCI与CPU的的接口结构如图5.1。
图5.1 SCI与CPU接口结构图2.SCI接口特点:2个外部引脚:SCITXD为SCI数据发送引脚;SCIRXD为SCI数据接收引脚。
两个引脚为多功能复用引脚,如果不使用可以作为通用数字量I/O。
●可编程通信速率,可以设置64K种通信速率。
●数据格式:1个启动位;1-8个可编程数据字长度;可选择奇校验、偶校验或无校验位模式;1或2位的停止位。
●4种错误检测标志位:奇偶错误、超时错误、帧错误和间断错误。
●2种唤醒多处理器方式:空闲线唤醒(Idle-line)和地址位唤醒(Address Bit)。
●全双工或半双工通信模式。
●双缓冲接收和发送功能。
●发送和接收可以采用中断和状态查询2种方式。
图5.2 SCI通信模块接口框图●独立的发送和接收中断使能控制。
●NRZ(非归零)通信格式。
●13个SCI模块控制寄存器,起始地址为7050H。
sci串口通信原理 -回复
sci串口通信原理-回复SCI(串行通信接口)是一种常见的串口通信协议,被广泛应用于各种电子设备中。
在本文中,我们将一步一步回答关于SCI串口通信原理的问题,包括它的工作原理、常见的应用场景以及一些技术细节。
首先,让我们来了解SCI串口通信的工作原理。
SCI是一种串行通信接口,它通过使用单一的线路来传输数据。
这条线路被分为两个方向,一个用于传输数据(TX),一个用于接收数据(RX)。
通过在这两个方向上的电位变化,可以实现数据的传输。
SCI串口通信一般使用异步传输模式,即数据按照一个位一个位地传输,每个位之间使用起始位和停止位进行分隔。
在SCI串口通信中,每个数据位通常是8位或9位。
其中,8个数据位中的7个用于传输数据的真正内容,而最高位为校验位。
校验位有助于检测数据传输错误,提高数据传输的可靠性。
在接收端,接收器会比对接收到的校验位和传输过程中计算得到的校验位,以检测并纠正任何可能的错误。
除了数据位外,SCI串口通信还使用两个控制信号:RTS(请求发送)和CTS(清除发送)。
RTS信号由发送端控制,用于请求发送数据。
而CTS 信号由接收端控制,用于指示接收端是否准备好接收数据。
这两个控制信号的使用可以有效地控制数据的传输速率,避免数据传输丢失或溢出的情况发生。
SCI串口通信可以应用于多种场景中。
例如,它常用于个人电脑与其他外部设备之间的通信,如打印机、调制解调器、数码相机等。
此外,它还可以用于嵌入式系统中,如工业自动化、机器人控制、仪器仪表等。
由于SCI串口通信具有简单、可靠、成本低廉等特点,因此在各种场景下都有广泛的应用。
在SCI串口通信中,还有一些技术细节需要考虑。
首先是波特率的选择,波特率表示数据传输速度,常用的波特率有9600、19200、38400等。
选择合适的波特率能够平衡数据传输速度和系统资源的利用率。
其次是数据格式的设置,包括数据位数、校验位和停止位。
不同的应用场景可能需要不同的数据格式设置,需要根据具体需求进行调整。
6.5_串行通信接口SCI模块080408
接收缓冲器/间断中断使 能
0
TX INT ENA
发送缓冲器中断使能控 制TXRDY标志引起的 中断
0-禁止TXRDY中断; 1-使能TXRDY中断
南京航空航天大学自动化学院DSP技术应用实验室
(4)SCI优先级控制寄存器SCIPRI 规定SCI发送和接收中断的优先级以及 SCI模块在仿真挂起时的操作.
2. SCI接收操作 ⑤接收器继续接收下一帧数据,检测起始位, 重复上述操作。 ⑥若第二帧数据尚未接收完毕(时刻6), RXENA=0,则将这一帧数据全部接收完毕后再 停止,但RXSHF中的数据并不传送到SCIRXBUF 中。
南京航空航天大学自动化学院DSP技术应用实验室
四、 SCI操作控制
3. SCI错误处理操作
7052h
SCIHBAUD
SCI波特率选择寄存器高8位
7053h
7054h
SCILBAUD
SCICTL2
SCI波特率选择寄存器低8位
SCI控制寄存器2
保存波特率控制数据低8位
发送中断使能,接收缓冲器/ 间断中断使能,发送准备好 标志和发送空标志。 存放7个接收状态标志
7055h
SCIRXST
SCI接收状态寄存器
四种错误:间断错误、奇偶性错误、溢出错误和帧错 误 ① 数据帧错误(Framing error):若超过一段时间 后仍收不到期待的停止位。 发生数据帧错误时,FE(SCIRXST.4)置位。 ②奇/偶校验错误(Parity error):检测接收到的数 据中1的个数是否正确,用于有限差错检测。 发生奇偶校验错误时,PE(SCIRXST.2)置位。
南京航空航天大学自动化学院DSP技术应用实验室
2. SCI模块的主要部件
SCI,SPI,UART三种串行总线协议的区别
SCI,SPI,UART三种串行总线协议的区别SCI (串行通讯接口)模块对其进行控制。
(注:SCI 首先由Motorola 微串口微控制器而得名,SCI 另一种说法是UART 控制器)常用的许多芯片中都包含了SCI ,例如ARM 的S3C2410X 芯片内嵌了3 个串行接口控制器,而Nios等软核芯片则可以用选用UART(RS232) 的IP 对UART 进行控制。
PC 机则常用16650 UART,16750 UART 等控制串口。
--这样说来SCI 只不过属于UART里面比较特殊的一种串行通讯方式了。
确实也只是在飞思卡尔芯片上遇见过。
第一个区别当然是名字:SCI(Serial Communicate Interface:串行通信接口)SPI(Serial Peripheral Interface:串行外设接口)另外曾在一官方datasheet 里面看见这种说法:Serial Parallel Interface:串并行接口UART(Universal Asynchronous Receiver Transmitter:通用异步收发器)第二,区别在电气信号线上:SPI 总线由三条信号线组成:串行时钟(SCLK)、串行数据输出(SDO)、串行数据输入(SDI)。
SPI 总线可以实现多个SPI 设备互相连接。
提供SPI 串行时钟的SPI 设备为SPI 主机或主设备(Master),其他设备为SPI 从机或从设备(Slave)。
主从设备间可以实现全双工通信,当有多个从设备时,还可以增加一条从设备选择线。
如果用通用IO 口模拟SPI 总线,必须要有一个输出口(SDO),一个输入口(SDI),另一个口则视实现的设备类型而定,如果要实现主从设备,则需输入输出口,若只实现主设备,则需输出口即可,若只实现从设备,则只需输入口即可。
UART 总线是异步串口,因此一般比前两种同步串口的结构要复杂很多,一般由波特率产生器(产生的波特率等于传输波特率的16 倍)、UART 接收器、UART 发送器组成,硬件上由两根线,一根用于发送,一根用于接收。
串行通信接口模块(SCI).
Electrical Engineering Institute of NEDU
3. 4.
5.
2018年7月31日星期二
12.1串行通信接口概述 全双工模式下SCI的主要部件
1.
2. 3. 4.
一个发送器(TX)及和它相关的主要寄存器; 一个接收器(RX)及和它相关的主要寄存器; 一个可编程的波特率发生器; 控制和状态寄存器。
电气工程学院
Electrical Engineering Institute of NEDU
2018年7月31日星期二
12.2.2 SCI的多处理器通信
地址字节的识别 空闲线模式在地址字节前留有一定长度的 空闲空间, 这种模式对于大数据块传输更有效。 地址位模式在每帧中加入额外地址/数据位, 这种模式对于小数据块传输更有效。
第十二章 串行通信接口模块(SCI) Serial Communication Interface
电气工程学院
Electrical Engineering Institute of NEDU
2018年7月31日星期二
12.1串行通信接口概述
SCI模块支持异步通信; SCI接收器和发送器是双缓冲的,各自有独立 的使能位和中断标志位。可以独立工作,或全 双工方式工作; SCI对接收到的数据进行间断检测,奇偶校验, 越限和帧出错的检查; 数据传输速度可编程为65535种方式;
电气工程学院
Electrical Engineering Institute of NEDU
2018年7月31日星期二
12.2.2 SCI的多处理器通信
空闲线模式下有两种方法可传送块的开始信号
1.
在前一块的最后一帧的数据传送与新块的地址 帧传送之间留出10位或更多位的空闲时间。 首 先 将 发 送 唤 醒 位 TXWAKE 置 1 , 然 后 再 向 SCITXBUF 写入任意一个数据,这样可以在数 据线上产生11位的空闲时间。
第7章 串行通信接口SCI By Wang
//发送就绪标志状态查询函数 int SciaTx_Ready(void) { unsigned int i; if(SciaRegs.SCICTL2.bit.TXRDY == 1) { i = 1; //返回1说明发送器已经准备就绪, 可以接收新的数据进行发送 } Else { i = 0; } return(i); }
18
除了查询方式之外,SCI的发送和接 收还可以通过中断进行控制。
看hellodsp 资料
19
多处理器通信
20
多处理器通信方式分为: 空闲线模式 地址位模式
21
22
23
RX FIFO_15
RX FIFO_15 6
SCI Device #1
SCI Device #2
7
之所以SCI能工作于全双工模式,是因为它 够同时进行,也能够独立 进行发送和接收的操作。
8
SCI数据格式
进行通信的时候,一般都会涉及到协议,所谓协 议就是通信双方预先约定好的数据格式,以及数 据的具体含义。这就像地下党员做情报工作时一 样,地下工作人员将一份情报交给了上级,上级 可以根据事先约定好的规则进行翻译,获取情报 具体内容。如果情报被敌人截获那也不怕,由于 敌人不知道情报中每个文字所代表的含义,所以, 对于敌人来说,这份情报也是无效的。这种事先 约定好的规则,我们就把它叫做通信协议。
11
通信波特率
所谓的波特率就是指每秒所能发送的位数 双方必须一致 2812的每个SCI都具有两个8位的波特率寄存器, SCIHBAUD和SCILBAUD
其中BRR=波特率选择寄存器中的值,从十进制转换成十 六进制后,高8位赋值给SCIHBAUD,低8位赋值给 SCILBAUD。
SPI 和 SCI的区别
1.SPI串行外围设备接口(serial peripheral interface)总线技术是Motorola公司推出的一种同步串行接口。
Motorola公司生产的绝大多数MCU(微控制器)都配有SPI硬件接口,如68系列MCU。
SPI总线是一种三线同步总线,因其硬件功能很强,所以与SPI有关的软件就相当简单,使CPU有更多的时间处理其他事务。
2.SCI串行通信接口(serial communication interface)也是由Motorola公司推出的。
司推出的。
它是一种通用异步通信接口UART,与MCS‐51的异步通信功能基,本相同。
说白一点一个是同步串行、一个是同步串行、再白一点——同步的需要多出一条时钟线、异步的只需要接收、发送两条线同步的需要多出一条时钟线SCI模块用于串行通讯,如RS422、RS485、RS232;SPI模块用于扩展外设,如AD、DA、FRAM、DSP等。
SCI模块和SPI模块是两个外设的扩展模块!SCI是异步通信SPI是同步通信SCI是异步串行通信接口,spi是同步,spi分主从机,通信速率上spi高于sci。
SPI总线由三条信号线组成:串行时钟(SCLK)、串行数据输出(SDO)、串行数据输入(SDI)。
SPI总线可以实现多个SPI设备互相连接。
sci是单片机的串口通信,spi是单片机的I2C通信一个是同步时钟,一个是同步时钟SCI是异步通信串口,只有两根线就可一完成通信。
SPI是同步通信串口,需要的线比SCI多。
SPI和I2C的区别I2C的数据输入输出用的是一根线,SPI则分为dataIN和dataOUT。
由于这个原因,采用I2C时CPU的端口占用少,SPI多一根。
但是由于I2C的数据线是双向的,所以隔离比较复杂,SPI则比较容易。
所以系统内部通信可用I2C,若要与外部通信则最好用SPI带隔离(可以提高抗干扰能力)。
但是I2C和SPI都不适合长距离传输。
长距离时就要用485了。
异步接收器传输总线(UART)、串行通信接口(SCI)和通用串行总线
异步接收器传输总线(UART)、串行通信接口(SCI)和通用串行总线异步接收器传输总线(UART)、串行通信接口(SCI)和通用串行总线(USB)等,这些总线在速度、物理接口要求和通信方法学上都有所不同。
本文详细介绍了嵌入式系统设计的串行总线、驱动器和物理接口的特性,并为总线最优选择提供性能比较和选择建议。
由于在消费类电子产品、计算机外设、汽车和工业应用中增加了嵌入式功能,对低成本、高速和高可靠通信介质的要求也不断增长以满足这些应用,其结果是越来越多的处理器和控制器用不同类型的总线集成在一起,实现与PC软件、开发系统(如仿真器)或网络中的其它设备进行通信。
目前流行的通信一般采用串行或并行模式,而串行模式应用更广泛。
微处理器中常用的集成串行总线是通用异步接收器传输总线、串行通信接口、同步外设接口(SPI)、内部集成电路(I2C)和通用串行总线,以及车用串行总线,包括控制器区域网(CAN)和本地互连网(LIN)。
这些总线在速度、物理接口要求和通信方法学上都有所不同。
本文将对嵌入式系统设计的串行总线、驱动器和物理接口这些要求提供一个总体介绍,为选择最优总线提供指导并给出一个比较图表(表1)。
为了说明方便起见,本文的阐述是基于微处理器的设计。
串行与并行相比串行相比于并行的主要优点是要求的线数较少。
例如,用在汽车工业中的LIN串行总线只需要一根线来与从属器件进行通信,Dallas公司的1-Wire总线只使用一根线来输送信号和电源。
较少的线意味着所需要的控制器引脚较少。
集成在一个微控制器中的并行总线一般需要8条或更多的线,线数的多少取决于设计中地址和数据的宽度,所以集成一个并行总线的芯片至少需要8个引脚来与外部器件接口,这增加了芯片的总体尺寸。
相反地,使用串行总线可以将同样的芯片集成在一个较小的封装中。
另外,在PCB板设计中并行总线需要更多的线来与其它外设接口,使PCB 板面积更大、更复杂,从而增加了硬件成本。
串行通信接口模块(SCI)概要
电气工程学院
Electrical Engineering Institute of NEDU
2020年1月29日星期三
12.2.2 SCI的多处理器通信
1.空闲线多处理器模式(ADDR/IDLE MODE=0)
数据块被块间的时间间隔分开,该时间间隔 比块中的数据帧之间的时间间隔要长,一帧后的 空闲时间(10个或更多个高电平位)表明了一个 新块的开始。如下页图所示:
Electrical Engineering Institute of NEDU
TXD RXD
从机n
2020年1月29日星期三
12.2.1串行通信接口可编程的数据格式 串行通信接口的NRZ数据格式包括:
一个起始位; 1~8个数据位; 一个奇/偶校验位 或 无奇/偶校验位; 1~2个停止位; 一个用于区分数据和地址的额外位。
BRR=24000000/(9600*8)–1=311.5
取138H 所以波特率选择寄存器设置为 SCIHBUAD=01H,SCILBAUD=38H
电气工程学院
Electrical Engineering Institute of NEDU
2020年1月29日星期三
12.3串行通信接口控制寄存器
第十二章 串行通信接口模块(SCI) Serial Communication Interface
电气工程学院
Electrical Engineering Institute of NEDU
2020年1月29日星期三
12.1串行通信接口概述
SCI模块支持异步通信;
SCI接收器和发送器是双缓冲的,各自有独立 的使能位和中断标志位。可以独立工作,或全 双工方式工作;
串行口SCI
串行通信接口SCI 串行通信接口
SCI同步方式: 同步方式: 同步方式 以数据格式以及发收双方时钟相同设置进行同步。 以数据格式以及发收双方时钟相同设置进行同步。 主从机具有相同时钟周期(波特率) 主从机具有相同时钟周期(波特率)在特定数据格式下收发 数据可以同步(起始位 数据位 校验位+停止位 空闲位) 数据位+校验位 停止位+空闲位 数据可以同步(起始位+数据位 校验位 停止位 空闲位) SCI异步通信可使用半双工或全双工模式通信。在这种 异步通信可使用半双工或全双工模式通信。 异步通信可使用半双工或全双工模式通信 模式下,一个帧包括 个起始位 个起始位、 个数据位 个数据位、 个 模式下,一个帧包括1个起始位、1-8个数据位、1个 可选的奇偶校验位以及1-2个停止位。每个数据占 可选的奇偶校验位以及 个停止位。每个数据占8 个停止位 个SCICLK周期。 周期。 周期
Page 15
识别地址
处理器根据多处理器的模式来识别一个地址字节,例如: 处理器根据多处理器的模式来识别一个地址字节,例如: • 空闲线模式在地址字节前留有一段静空间。数据块之间 空闲线模式在地址字节前留有一段静空间。 个或10个以上连续空闲位 是10个或 个以上连续空闲位,同一帧数据字符间空闲 个或 个以上连续空闲位, 位应小于10个 该模式没有一个附加的地址/数据位, 位应小于 个。该模式没有一个附加的地址/数据位,在 处理包含多于10个字节的数据块的情况下,其效率比地址 处理包含多于 个字节的数据块的情况下, 个字节的数据块的情况下 位模式更高。 位模式更高。 • 地址位模式为每个字节增加一个附加位 地址位 来 地址位模式为每个字节增加一个附加位(地址位 地址位)来 从数据中识别地址。该模式在处理多个小数据块时 从数据中识别地址。 更有效。 更有效。
第05章串行通信接口SCI
地址链接文件
M CU 映 像 寄 存 器 名 定 义 头 文 件
嵌入式系统--使用HCS12微控制器的设计与应用
工程说明文件
20
5.5 串行通信通用函数与测试实例 5.5.2 查询方式收发测试工程
4.中断方式测试工程辅助工具
嵌入式系统--使用HCS12微控制器的设计与应用
21
5.5 串行通信通用函数与测试实例 5.5.2 查询方式收发测试工程
13
5.3 DG128 SCI模块寄存器
5.3.6 SCI数据寄存器
1. 缩写:SCI0DRH、SCI0DRL、SCI1DRH、SCI1DRL 2. 位定义:
数据位 D7 D6 T8 0 D7 R7 T7 0 D6 R6 T6 0 D5 R5 T5 0 D4 R4 T4 0 D3 R3 T3 0 D2 R2 T2 0 D1 R1 T1 0 D0 R0 T0 D5 D4 D3 D2 D1 D0
15 H X 0 8 7
M CU 的
内
部
总
线
(In te rn a l B u s )
7 SCI 控 制 寄 存 器
0
S C I状 态 寄 存 器
S C I波 特 率 寄 存 器
7
嵌入式系统--使用HCS12微控制器的设计与应用 7
5.3 DG128 SCI模块寄存器
5.3.1 SCI波特率寄存器
嵌入式系统--使用HCS12微控制器的设计与应用 17
5.5 串行通信通用函数与测试实例 5.5.2 查询方式收发测试工程
1.查询方式收发测试工程主函数文件main.c 1.禁止总中断 2.芯片初始化 3.SCI模块初始化
等待从PC机接收一个数据
向PC机发送一个数据
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
一个开始位 1~8个数据位(通常为8位) 一个奇/偶校验位或无奇偶校验位 1~2个停止位
区分地址和数据的附加位(仅地址位模式时存在)
与RS232 格式兼容
8
SCI数据格式的配置
SCIA的通信控制寄存器
STOP BITS:指定发送时停止位个数,0-1个停止位,1-2个停止位; EVEN/ODD PARITY:奇偶校验选择, 0-奇校验, 1-偶校验; PARITY ENALBE:校验使能, 0-禁止奇偶校验,1-允许奇偶校验; LOOPBACK ENA:环路测试模式使能,1-TX数据内部送Rx,0-禁止 ADDR/IDLE MODE:多处理器模式选择,0-空闲线模式,1-地址位模式 SCICHAR2~0:数据长度选择,1~8位数据(000-111)。
第四讲 内容回顾
1、DSP开发系统组成 1)硬件开发工具;2)软件开发工具;3)DSP应用板。 2、DSP最小系统 1)DSP芯片;2)时钟电路;3)电源与复位电路; 4)JTAG仿真接口。 3、人机接口 1)输入:键盘、开关、按钮等; 2)输出:LED、LCD等
1
DSP原理及其应用技术
串行通信接口(SCI)
1)臵RXENA=1(SCICTL1.D0),使能接收器接收器数据; 2)数据到达SCIRXD引脚后,检测起始位(SCI自动实现); 3)数据从RXSHF寄存器移位到接收缓冲寄存器(SCIRXBUF), 产生一个中断请求,同时接收器数据准备好标志RXRDY=1;
4)用户程序读取SCIRXBUF寄存器,标志位RXRDY自动清零;
1)首先置位TXWAKE(SCICTL1.3),控制数据发送特征;
2)写一个数据字节(内容不重要)到SCITXBUF,发送一个块 开始信号( 11位的空闲时间);
3)写一个新的地址到SCITXBUF,当TXSHF再次空闲后, SCITXBUF内容送TXSHF,TXWAKE被清零;
4)随后依次发送各个数据帧。
14
SCI的波特率计算
波特率:串行通信过程每秒钟传送的二进制脉冲数目,单位: bit/s (位/秒) 串行时钟 SCICLK 由低速外设时钟 LSPCLK和波特率选择寄存器确定; 注意:如果 BRR= 0,则波特率=LSPCLK/16. BRR--Baud-Select Register
同步通信:发送器和接收器通常使用同一时钟源来同步。方法是在发送器 发送数据时同时包含了时钟信号,接收器利用该时钟信号进行接收。 异步通信:收发双方的时钟不是同一个时钟,是由双方各自的时钟实现数 据的发送和接收。但要求双方使用同一标称频率,允许有一定偏差。 同步方法:要正确传输字符,准确读取每一位是必须用各自的时钟同步的, 为克服不同时钟的偏差,每个字符都有一个起始位进行同步。
5)数据的下一个字节到达SCIRXD引脚,检测到起始位;
6)RXENA=0,禁止接受数据。继续向RXSHF装载数据,但不送入SCIRXBUF。
CPU SCIRXBUF
RXSHF SCIRXD 地址位模式
11
每个字符6个数据位
通信过程中的发送器信号
1)TXENA=1(SCICTL1.D1),使能发送器发送数据;
13
SCI的中断(续)
2、接收器/间断中断: 如果臵位RX/BK INT ENA (SCICTL2.1), 则下列条件之一产生接收器中断: 1)SCI接收到一个完整的帧,并将RXSHF中的数据送SCIRXBUF,就会产生 接收器中断,同时将RXRDY臵位(SCICTL2.6); 2)间断检测条件发生(在一个缺少的停止位后,SCIRX保持10周期的低电 平)。该操作将BRKDT臵位,并产生中断。 3、 在接收器错误中断服务子程序中,可以检测错误条件:
16
SCI多处理器通信
多处理器模式下,接受步骤如下:
接受地址块时,SCI端口被唤醒并申请中断,读取地址块 的第一帧,该帧包含目的处理器的地址;
比较接受的地址字节与内存中存放的器件地址;
如果二者一致,则编程使CPU清除SLEEP位,并读取数据 块中各个数据帧;否则,退出接受子程序并保持SLEEP臵位, 直到下一个地址块的开始才接受中断。 如何识别地址字节? SCI的两种模式均支持多处理器通信。
PC机1
RXD 2 TXD 3 GND 5 DCD 1 DTR 4 DSR 6 RTS 7 CTS 8ຫໍສະໝຸດ PC机2 双绞线:小于50英尺
1)FE:当检测不到一个期望的停止位时,帧错误标志臵位;
2)OE:在前一个字符被CPU读取前,有新的字符送到SCIRXBUF中时,臵 位超时错误标志,此时前一个字符被覆盖; 3)PE:当接受字符中1的个数和它的奇偶校验位之间不匹配时(含地址位), 且校验模式被使能时,奇偶校验错误标志臵位。
错误标志位不能被直接清除,只能通过软件复位或系统复位来清除。
SCI使用16位波特率选择寄存器,可以设定为64K种波特率;
SCI波特率= LSPCLK/ (BRR+1)×8
SYSCLKOUT/4
15
SCI多处理器通信
在同一条串行连线上,多处理器通信模式允许一个处理器 (主机)向串行线上其它处理器(从机)发送数据。
一条串行线上每刻只能有一个节点发送数据(发送使能控 制),但可以多个节点同时接受数据。
规定为逻辑 “1” 规定为逻辑 “0”
25
RS-232接口的硬件连接
RS232的信号定义:
TXD/RXD : 是一对数据线,TXD称发送数据输出,RXD称接收数据输入,当 两台计算机以全双工方式直接通信时,双方的这两根线应交叉连接。
GND: 所有的信号都要通过信号地线构成回路。
其余为联络(握手信号)信号线.
3个数据位 地址位模式
2)程序写数据到SCITXBUF寄存器,此时发送器不为空,TXRDY变低; 3)SCI发送数据到移位寄存器TXSHF后,产生中断请求,同时TXRDY变高; 4)TXRDY变高后,程序写第二个字符到SCITXBUF,随后TXRDY又变低; 5)发送完第一个字符,开始将第二个字符移位到寄存器TXSHF; 6)TXENA=0,禁止发送数据,SCI继续完成当前字符的发送; 7)第二个字符发送完成后,发送器变空,TXEMPTY=1,与TXSHF相对
典型的异步串行通信接口:RS-232、RS-422/485、USB等
4
计算机通信接口
5
6.2 SCI模块
主要特点:
串行通信接口(SCI-Serial Communication Interface)
F2812包含两个SCI接口,记做SCIA和SCIB
SCI是一种异步串行通信接口,即通常所说的UART SCI支持16级接收和发送FIFO,有助于减少CPU的开销 如果不使用FIFO时,SCI接收器和发送器采用两级缓冲方式 SCI可工作于半双工或全双工模式(RS485/422)
两种多处理器通信模式:空闲线与地址位多处理器模式
为保证数据的完整性,SCI模块对接收到的数据可以进行间 断、奇偶、超限和帧错误检测。
6
SCI与CPU间的接口
CPU
两个外 部引脚
SCI模块
13个控制 寄存器
只能以 16位方 式访问
3.3V TTL 电平
7
SCI的数据格式
SCI的数据格式包括:
19
地址位多处理器协议中,每帧的最后一个数据位后有一个附加的地址位; 数据块的第一帧的地址位设臵为1,其余帧的地址位为0; 数据传输与数据块间的空闲周期无关。
地址位多处理器模式
ADDR/IDLE MODE=1
20
地址位多处理器模式
ADDR/IDLE MODE=1
地址位多处理器协议中,每帧的最后一个数据位后有一个附加的地址位; 数据块的第一帧的地址位设臵为1,其余帧的地址位为0; 数据传输与数据块间的空闲周期无关。
1、地址字节
发送节点发送信息的第一个字节是地址字节(各个从机的地址预先定义 好),所有接受节点都读取该地址字节。只有地址字节与接受节点的地址 字相符,才能接受数据,否则等待下一个地址字节。
2、Sleep位 (接收器休眠位)
连接到串行总线上的所有处理器都将SCI Sleep位臵1,这样只有检测到 地址字节后才会中断。当数据块地址与用户软件设臵的处理器地址相符时, 用户必须清除Sleep位,以便SCI能够在接受每个数据字节时产生中断。
发送器有一个SCITXBUF空标志(TXRDY=1),接收器有3个中断标志:
1)接收器数据准备好(RXRDY=1);
2)接收器错误标志位(RX ERROR=1);
3)如果SCIRXD引脚连续保持至少10个低电平,则产生一个间断条件 ( BRKDT =1)。 1、发送器中断: 1)臵位TX INT ENA(SCICTL2.0); 2)只要SCITXBUF中数据传送到TXSHF中,就会产生发送器中断; 3)该操作将TXRDY臵位(SCICTL2.7),表示CPU可以继续写数据。
9
SCI通信格式
1) 4个SCICLK周期的连续低电平表示有效的起始位; 2) 接收器收到1个起始位后开始接受数据; 3) 每个串行数据位占用8个SCICLK时钟周期; 4) 在随后的各位中进行三次采样(4、5、6)确定该位电平;
5)串口两端的接收/发送器分别使用各自的时钟(异步方式)。
10
通信过程中的接收器信号
自动波特率检测
自动检测SCI通信的波特率,并刷新BRR寄存器。
24
6.3 标准串行总线接口
1、 RS-232C标准(Recommended Standard)
计算机远程通信
DTE(Data Terminal Equipment)数据终端 DCE(Data Communications Equipment)数据通信装臵 机械连接:25针,9针 电气方面:采用负逻辑电平:-5V~-15V +5V~+15V