SPI同步串行总线原理
SPI总线组成及其工作原理

SPI总线组成及其工作原理SPI(Serial Peripheral Interface)是一种同步串行通信总线,常用于连接微控制器与外部设备,如传感器、存储器、外设等。
SPI总线由四条信号线组成,包括SCLK(串行时钟线),MOSI(主设备输出从设备输入线),MISO(主设备输入从设备输出线)和SS(片选信号线)。
以下将详细介绍SPI总线的工作原理和其组成部分。
SPI总线采用主从架构,由一个主设备(如微控制器)和一个或多个从设备(如传感器、存储器等)组成。
主设备通过SCLK产生时钟信号来驱动整个通信过程。
主设备通过MOSI线发送数据到从设备,从设备通过MISO线传输数据给主设备。
每个从设备都有一个片选信号线(SS),用于使能该从设备。
当主设备需要与一些从设备通信时,将对应的片选信号线拉低,使该从设备处于选中状态。
1.SCLK(串行时钟线):SCLK是SPI通信中的时钟信号,由主设备通过该线产生并驱动。
SCLK信号的频率可以由主设备控制,通常可以在MHz级别。
SCLK的上升沿和下降沿都用于同步数据传输。
数据在SCLK的上升沿或下降沿的边沿进行读写操作。
2.MOSI(主设备输出从设备输入线):MOSI是主设备输出从设备输入的数据线。
主设备通过MOSI将数据传输给从设备。
数据在每个SCLK周期的上升沿或下降沿被写入。
3.MISO(主设备输入从设备输出线):MISO是主设备输入从设备输出的数据线。
从设备通过MISO将数据传输给主设备。
数据在每个SCLK周期的上升沿或下降沿被读取。
4.SS(片选信号线):每个从设备都有一个对应的SS信号线。
当主设备需要与一些从设备通信时,将该从设备的SS信号线拉低,使该从设备处于选中状态。
当通信结束后,SS信号线会被拉高,表示该从设备不再被选中。
1.主设备通过控制SS信号线,选中一些从设备开始通信。
2.主设备通过SCLK产生时钟信号,并通过MOSI线发送数据给从设备。
3.从设备在SCLK的上升沿或下降沿将数据写入MISO线,传输给主设备。
SPI、I2C、UART三种串行总线的原理、区别及应用

简朴描述:SPI 和I2C这两种通信方式都是短距离旳,芯片和芯片之间或者其他元器件如传感器和芯片之间旳通信。
SPI和IIC是板上通信,IIC有时也会做板间通信,但是距离甚短,但是超过一米,例如某些触摸屏,手机液晶屏那些很薄膜排线诸多用IIC,I2C能用于替代原则旳并行总线,能连接旳多种集成电路和功能模块。
I2C是多主控总线,因此任何一种设备都能像主控器同样工作,并控制总线。
总线上每一种设备均有一种独一无二旳地址,根据设备它们自己旳能力,它们可以作为发射器或接受器工作。
多路微控制器能在同一种I2C总线上共存这两种线属于低速传播;ﻫ而UART是应用于两个设备之间旳通信,如用单片机做好旳设备和计算机旳通信。
这样旳通信可以做长距离旳。
UART和,UART就是我们指旳串口,速度比上面三者快,最高达100K左右,用与计算机与设备或者计算机和计算之间通信,但有效范畴不会很长,约10米左右,UART长处是支持面广,程序设计构造很简朴,随着USB旳发展,UART也逐渐走向下坡;SmBus有点类似于USB设备跟计算机那样旳短距离通信。
ﻫ简朴旳狭义旳说SPI和I2C是做在电路板上旳。
而UART和SMBUS是在机器外面连接两个机器旳。
具体描述:1、UART(TX,RX)就是两线,一根发送一根接受,可以全双工通信,线数也比较少。
数据是异步传播旳,对双方旳时序规定比较严格,通信速度也不是不久。
在多机通信上面用旳最多。
2、SPI(CLK,I/O,O,CS)接口和上面UART相比,多了一条同步时钟线,上面UART旳缺陷也就是它旳长处了,对通信双方旳时序规定不严格不同设备之间可以很容易结合,并且通信速度非常快。
一般用在产品内部元件之间旳高速数据通信上面,如大容量存储器等。
3、I2C(SCL,SDA)接口也是两线接口,它是两根线之间通过复杂旳逻辑关系传播数据旳,通信速度不高,程序写起来也比较复杂。
一般单片机系统里重要用来和24C02等小容易存储器连接。
spi原理

spi原理SPI原理。
SPI(Serial Peripheral Interface)是一种同步串行数据总线,它是一种用于连接微控制器和外围设备的通信协议。
SPI总线由四根线构成,分别是时钟线(SCLK)、主设备输出从设备输入线(MOSI)、主设备输入从设备输出线(MISO)和片选线(SS)。
SPI总线可以实现全双工通信,同时可以连接多个从设备,因此在嵌入式系统中得到广泛应用。
SPI总线的工作原理如下,首先,主设备通过片选线选中需要通信的从设备,然后通过SCLK线提供时钟信号,将数据按位发送到从设备的MOSI线,同时从设备将数据按位发送到主设备的MISO线。
在数据传输过程中,主设备和从设备的时钟必须同步,这样才能正确地进行数据传输。
在数据传输结束后,主设备通过片选线取消对从设备的选择,从而完成一次通信过程。
SPI总线的工作原理非常简单,但是它具有以下几个特点:1.高速传输,SPI总线可以实现高速的数据传输,因为它是同步传输,时钟信号的频率可以达到几十兆赫,甚至更高。
这使得SPI总线非常适合需要高速数据传输的应用场景,比如存储器接口、显示设备接口等。
2.全双工通信,SPI总线可以实现全双工通信,主设备和从设备可以同时进行数据的发送和接收,这样可以大大提高通信效率。
而且,SPI总线可以连接多个从设备,主设备可以通过片选线选择需要通信的从设备,从而实现多个从设备之间的通信。
3.简单灵活,SPI总线的硬件连接非常简单,只需要四根线就可以实现通信,而且SPI总线的通信协议也非常简单。
这使得SPI总线非常适合在资源有限的嵌入式系统中使用。
在实际的应用中,为了提高SPI总线的稳定性和可靠性,通常会在硬件上添加一些额外的电路,比如加上电平转换器、添加阻抗匹配电路等。
而在软件上,通常会使用专门的SPI驱动程序来控制SPI总线的通信,以便更加方便地使用SPI总线进行数据传输。
总的来说,SPI总线是一种非常简单、灵活、高效的通信协议,它在嵌入式系统中得到了广泛的应用。
SPI工作原理

SPI∙由于SPI(setial peripheralinterface)总线占用的接口线少,通信效率高,并且支持大部分处理器芯片,因而是一种理想的选择。
SPI是利用4根信号线进行通信的串行接口协议,包括主/从两种模式。
4个接口信号为:串行数据输入(MISO,主设备输入、从设备输出)、串行数据输出(MOSI,主设备输出、从设备输入)、移位时钟(SCK)、低电平有效的从设备使能信号(cs)。
SPI最大的特点是由主设备时钟信号的出现与否来确定主/从设备间的通信。
一旦检测到主设备的时钟信号,数据开始传输。
∙目录∙SPI工作方式简介∙SPI的数据传输∙SPI用户逻辑∙SPI基本原理与结构SPI工作方式简介∙SPI是由美国摩托罗拉公司最先推出的一种同步串行传输规范,也是一种单片机外设芯片串行扩展接口。
SPI模式可以允许同时同步发送和接收8位数据,并支持4种工作方式:1. 串行数据输出,对应RC5/SDO引脚;2. 串行数据输入,对应RC4/SDI/SDA引脚;3. 串行时钟,对应RC3/SCK/SCL引脚;4. 从动方式选择,对应RA5/SS/AN4引脚。
SPI模式下与之相关的寄存器有10个,其中4个是与I2C模式共用的。
图1所示是由一个主机对接一个从机进行全双工通信的系统构成的方式。
在该系统中,由于主机和从机的角色是固定不变的,并且只有一个从机,因此,可以将主机的丽端接高电平,将从机的SS 端固定接地。
图1 全双工主机/从机连接方法若干个具备SPI接口的单片机和若干片兼容SPI接口的外围芯片,可以在软件的控制下,构成多种简单或者复杂的应用系统,例如以下3种。
(1)一个主机和多个从器件的通信系统。
如图2所示,各个从器件是单片机的外围扩展芯片,它们的片选端SS分别独占单片机的一条通用I/O引脚,由单片机分时选通它们建立通信。
这样省去了单片机在通信线路上发送地址码的麻烦,但是占用了单片机的引脚资源。
当外设器件只有一个时,可以不必选通而直接将SS端接地即可。
SPII2CUART三种串行总线的原理区别及应用

SPII2CUART三种串行总线的原理区别及应用SPI(Serial Peripheral Interface),I2C(Inter-Integrated Circuit)和UART(Universal Asynchronous Receiver/Transmitter)是常见的串行总线通信协议,它们在嵌入式系统中被广泛使用。
以下是对这三种串行总线的原理、区别及应用的详细介绍。
1. SPI(Serial Peripheral Interface)SPI是一种同步的、全双工的串行总线协议,通常由一个主设备和一个或多个从设备组成。
SPI总线上通信是基于时钟信号进行同步的,主设备产生时钟信号,从设备在时钟的边沿上发送和接收数据。
在SPI总线上,主设备控制通信的起始和结束,并通过片选信号选择与之通信的从设备。
SPI总线上的数据传输是基于多线制的,其中包括主设备的时钟线(SCLK)、数据输出线(MOSI)、数据输入线(MISO)和片选线(SS)。
SPI总线具有以下特点:-速度较快,可以达到十几MHz甚至上百MHz的传输速率。
-支持多主设备,但每个时刻只能有一个主设备处于活动状态。
-适用于短距离通信,通常在PCB上的芯片之间进行通信。
-数据传输可靠性较高。
SPI总线广泛应用于各种设备之间的数据传输,例如存储器、传感器、显示模块等。
2. I2C(Inter-Integrated Circuit)I2C也是一种同步的、双向的串行总线协议,由一个主设备和一个或多个从设备组成。
I2C总线上的通信也是基于时钟信号进行同步的,主设备产生时钟信号和开始/停止条件,从设备在时钟边沿上发送和接收数据。
I2C总线上的数据传输是基于两根线—串行数据线(SDA)和串行时钟线(SCL)。
I2C总线具有以下特点:- 通信速度较慢,大多数设备的传输速率为100kbps,但也支持高达3.4Mbps的快速模式。
-支持多主设备,可以同时连接多个主设备。
spi通信原理

spi通信原理SPI(串行外围接口,Serial Peripheral Interface)是一种常见的半双工、同步串行通信总线接口(bus interface)。
它由一个正极性信号线(CS,Chip Select),一个时钟信号线(SCK,Serial Clock),一个向下发出数据线(MOSI,Master Out-Slave In)和一个向上接收数据线(MISO,Master In-Slave Out)构成,可用于微分模式或模拟模式通信,且具有较高的数据传输率和节点连线数,是一种主从(Master-Slave)式的串行数据传输标准。
一、SPI通信原理1、工作模式SPI接口通信模式有三种,分别是主模式(Master Mode)、从模式(Slave Mode)和双向模式(Bi-directional Mode),根据两个彼此连接的电路是主端还是从端,其工作模式就可以分别确定。
(1)主模式主模式有总线的控制权,它是总线的主导者,其发送时钟信号控制总线,由它读取从模式器件入端口的字节数据或者写入数据到从模式器件出端口,它一般兼顾发送和接收两种操作,并且在发送和接收都有数据缓存能力;(2)从模式从模式段缺少时钟和控制信号,从模式由主模式发送的时钟信号控制总线,从模式只能够等待主模式的唤醒,接收到主模式发来的时钟脉冲,才能工作;数据传输中,从模式由主模式发来的数据控制信号中控制自身的行为,从模式接收到数据,可能直接或间接地存储在从模式自身的缓冲位;(3)双向模式双向模式下,两电路当守护者和执行者双重角色,类似主模式,双向模式的总线可以实现双向同时收发数据功能,这也是SPI最重要的一个特点之一;2、信号线(1)CS: Chip Select,片选信号,由主机向从机发送,表示仪器的开始和结束信号;(2)SCK: Serial Clock,系统时钟信号,由主机向从机发送,控制数据的传输;(3)MOSI: Master Out Slave In,主机输出从机输入,由主机向从机发送;(4)MISO: Master In Slave Out,主机输入从机输出,由从机向主机发送;3、总线收发:1)主机向外设发送起始信号CS并向外设发出一个脉冲,外设将收到控制信号,从而开始读写操作;2)主机向外设发送时钟信号SCK,外设收到时钟信号后,可以进行一般主机传入和传出操作;3)主机发出信号来控制从机发出数据,从机受到数据标识,可以开始向主机发送数据,主机则接收从机发出的数据;4)当数据传送完毕后,起始信号CS将放低,SCK亦会放低,外设再将已写完信息的SS连接信号拉高;5)最后,外设会结束数据的读取和写入,同时将SS。
SPI接口的优缺点及通信原理
SPI接口的优缺点及通信原理SPI是串行外设接口(Serial Peripheral Interface)的缩写。
是一种同步串行接口技术,是高速的,全双工,同步的通信总线。
下面就有iBeacon、蓝牙模块厂家-云里物里科技来帮大家讲解下SPI接口的优缺点。
1、SPI接口的优点支持全双工操作;操作简单;数据传输速率较高。
同时,它也具有如下缺点:需要占用主机较多的口线(每个从机都需要一根片选线);只支持单个主机;没有指定的流控制,没有应答机制确认是否接收到数据。
2、SPI通信原理SPI的通信原理是以主从方式工作,这种模式通常有一个主设备和一个或多个从设备。
SPI接口经常被称为4线串行总线,分别是SDI(数据输入)、SDO(数据输出)、SCLK(时钟)、CS(片选)。
(a)SDO/MOSI–主设备数据输出,从设备数据输入;(b)SDI/MISO–主设备数据输入,从设备数据输出;(c)SCLK–时钟信号,由主设备产生;(d)CS/SS–从设备使能信号,由主设备控制。
在SPI总线上,某一时刻可以出现多个从设备,但只能存在一个主设备,主设备通过片选线来确定要通信的从设备。
这就要求从设备的MISO口具有三态特性,使得该口线在设备未被选通时表现为高阻抗。
3、数据传输在一个SPI时钟周期内,会完成如下操作:1)主设备通过MOSI线发送1位数据,从设备通过该线读取这1位数据;2)从设备通过MISO线发送1位数据,主设备通过该线读取这1位数据。
这是通过移位寄存器来实现的。
如图所示,主设备和从设备各有一个移位寄存器,且二者连接成环。
随着时钟脉冲,数据按照从高位到低位的方式依次移出主设备寄存器和从机寄存器,并且依次移入从设备寄存器和主设备寄存器。
当寄存器中的内容全部移出时,相当于完成了两个寄存器内容的交换。
4、内部工作机制SSPSR是SPI设备内部的移位寄存器(Shift Register).它的主要作用是根据SPI时钟信号状态,往SSPBUF里移入或者移出数据,每次移动的数据大小由Bus-Width以及Channel-Width所决定。
spi工作原理
spi工作原理SPI(Serial Peripheral Interface)是一种同步串行通信协议,用于连接微控制器、传感器、存储器等外部设备。
其工作原理如下:1. 通信架构:SPI使用主从架构,其中主设备(通常是微控制器或处理器)控制通信的初始化、时钟速率以及数据传输的起始和终止,而从设备(例如传感器或存储器)则被动地响应主设备的指令。
2. 时钟信号:SPI通信需要一个时钟信号作为同步基准,由主设备产生并传输给从设备。
通常情况下,SPI设备具有两个时钟极性(CPOL)和时钟相位(CPHA)设置,主设备和从设备必须使用相同的设置才能正常通信。
3. 数据传输:主设备通过SPI总线发送数据,而从设备则将其接收。
数据以字节为单位传输,可以进行全双工或半双工传输。
数据传输的方式一般为MSB(最高有效位)或LSB(最低有效位)优先。
4. 片选信号:SPI可以支持多个从设备的连接。
通过片选信号(通常称为CS或SS),主设备可以选择与哪个从设备进行通信。
只有选中的从设备会响应主设备发送的指令和数据。
5. 数据帧:SPI通信中的数据传输由一系列的数据帧组成。
每个数据帧包含一个位传输和一个字节传输,并由传输时钟控制。
6. 通信步骤:- 主设备发送片选信号以选中从设备。
- 主设备发送时钟信号作为同步时钟。
- 主设备将数据位推送到MOSI(主输出从输入)线上。
- 从设备在下降沿接收数据位,并将响应数据推送到MISO (主输入从输出)线上。
- 主设备在上升沿采集响应数据。
- 重复以上步骤直到传输完成。
总结:SPI是一种高速串行通信协议,具有灵活性和简单性。
它通过主从架构、时钟信号、数据传输、片选信号以及数据帧来实现设备之间的通信。
主设备控制通信的初始化和时序,从设备被动响应主设备的指令和数据。
通过理解SPI的工作原理,可以更好地设计和应用它。
spi总线工作原理
spi总线工作原理
SPI(Serial Peripheral Interface)总线是一种同步串行通信协议,它主要用于在微控制器或其他数字集成电路之间传输数据。
SPI总线由一个主设备(Master)和一个或多个从设备(Slave)组成。
主设备通过与从设备之间发送和接收数据的方式来与其进行通信。
SPI总线的工作原理如下:
1. 首先,主设备选择要与之通信的从设备。
这是通过在片选引脚上拉低电平来实现的。
其他从设备的片选引脚应保持高电平。
2. 接着,主设备通过时钟引脚(SCK)生成时钟信号,此时数据传输开始。
3. 主设备通过主输出(MOSI)引脚发送数据,从设备通过主输
入(MISO)引脚接收数据。
在每个时钟周期中,主设备和从设
备在SCK上的上升沿或下降沿进行数据交换。
4. 数据传输时,主设备先发送一个起始位(通常是高电平)并将其传输到从设备。
5. 接下来,主设备和从设备同时发送并接收数据,每一个时钟周期传输一个位。
数据传输的顺序是从最高位(MSB)到最
低位(LSB)。
6. 当所有数据位都传输完毕后,主设备通过拉高片选引脚结束
与从设备的通信。
7. 在通信结束后,主设备可以选择与其他从设备进行通信,或者在下一个时钟周期中重新选择与之前的从设备进行通信。
SPI总线的工作原理简单而直观。
它具有高速、可简化电路设计等优点,因此在很多嵌入式系统中得到了广泛应用。
SPI总线简介及原理
SPI总线简介及原理2009-12-29 10:52SPI(Serial Peripheral Interface)是一种串行同步通讯协议,由一个主设备和一个或多个从设备组成,主设备启动一个与从设备的同步通讯,从而完成数据的交换。
SPI 接口由SDI(串行数据输入),SDO(串行数据输出),SCK(串行移位时钟),CS(从使能信号)四种信号构成,CS 决定了唯一的与主设备通信的从设备,如没有CS 信号,则只能存在一个从设备,主设备通过产生移位时钟来发起通讯。
通讯时,数据由SDO 输出,SDI 输入,数据在时钟的上升或下降沿由SDO 输出,在紧接着的下降或上升沿由SDI 读入,这样经过8/16 次时钟的改变,完成8/16 位数据的传输。
SPI通信该总线通信基于主-从配置。
它有以下4个信号:MOSI:主出/从入MISO:主入/从出SCK:串行时钟SS:从属选择芯片上“从属选择”(slave-select)的引脚数决定了可连到总线上的器件数量。
在SPI传输中,数据是同步进行发送和接收的。
数据传输的时钟基于来自主处理器的时钟脉冲,摩托罗拉没有定义任何通用SPI的时钟规范。
然而,最常用的时钟设置基于时钟极性(CPOL)和时钟相位(CPHA)两个参数,CPOL定义SPI串行时钟的活动状态,而CPHA定义相对于SO-数据位的时钟相位。
CPOL和CPHA的设置决定了数据取样的时钟沿。
数据方向和通信速度SPI传输串行数据时首先传输最高位。
波特率可以高达5Mbps,具体速度大小取决于SPI硬件。
例如,Xicor公司的SPI串行器件传输速度能达到5MHz。
SPI总线接口及时序SPI总线包括1根串行同步时钟信号线以及2根数据线。
SPI模块为了和外设进行数据交换,根据外设工作要求,其输出串行同步时钟极性和相位可以进行配置,时钟极性(CPOL)对传输协议没有重大的影响。
如果 CPOL=0,串行同步时钟的空闲状态为低电平;如果CPOL=1,串行同步时钟的空闲状态为高电平。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
三、SPI是英文Serial Peripheral Interface的缩写,中文意思是串行外围设备接口,SPI是Motorola公司推出的一种同步串行通讯方式,是一种三线同步总线,因其硬件功能很强,与SPI有关的软件就相当简单,使CPU有更多的时间处理其他事务。
SPI概述SPI:高速同步串行口。
3~4线接口,收发独立、可同步进行.SPI,是英语Serial Peripheral interface的缩写,顾名思义就是串行外围设备接口。
是Motorola首先在其MC68HCXX系列处理器上定义的。
SPI接口主要应用在EEPROM,FLASH,实时时钟,AD转换器,还有数字信号处理器和数字信号解码器之间。
SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为PCB 的布局上节省空间,提供方便,正是出于这种简单易用的特性,现在越来越多的芯片集成了这种通信协议,比如AT91RM9200.SPI总线系统是一种同步串行外设接口,它可以使MCU与各种外围设备以串行方式进行通信以交换信息。
外围设置FLASHRAM、网络控制器、LCD显示驱动器、A/D转换器和MCU等。
SPI总线系统可直接与各个厂家生产的多种标准外围器件直接接口,该接口一般使用4条线:串行时钟线(SCK)、主机输入/从机输出数据线MISO、主机输出/从机输入数据线MOSI 和低电平有效的从机选择线SS(有的SPI接口芯片带有中断信号线INT或INT、有的SPI接口芯片没有主机输出/从机输入数据线MOSI)。
SPI的通信原理很简单,它以主从方式工作,这种模式通常有一个主设备和一个或多个从设备,需要至少4根线,事实上3根也可以(单向传输时)。
也是所有基于SPI的设备共有的,它们是SDI(数据输入),SDO(数据输出),SCK(时钟),CS(片选)。
(1)SDO –主设备数据输出,从设备数据输入(2)SDI –主设备数据输入,从设备数据输出(3)SCLK –时钟信号,由主设备产生(4)CS –从设备使能信号,由主设备控制其中CS是控制芯片是否被选中的,也就是说只有片选信号为预先规定的使能信号时(高电位或低电位),对此芯片的操作才有效。
这就允许在同一总线上连接多个SPI设备成为可能。
接下来就负责通讯的3根线了。
通讯是通过数据交换完成的,这里先要知道SPI是串行通讯协议,也就是说数据是一位一位的传输的。
这就是SCK时钟线存在的原因,由SCK提供时钟脉冲,SDI,SDO则基于此脉冲完成数据传输。
数据输出通过SDO 线,数据在时钟上升沿或下降沿时改变,在紧接着的下降沿或上升沿被读取。
完成一位数据传输,输入也使用同样原理。
这样,在至少8次时钟信号的改变(上沿和下沿为一次),就可以完成8位数据的传输。
要注意的是,SCK信号线只由主设备控制,从设备不能控制信号线。
同样,在一个基于SPI的设备中,至少有一个主控设备。
这样传输的特点:这样的传输方式有一个优点,与普通的串行通讯不同,普通的串行通讯一次连续传送至少8位数据,而SPI允许数据一位一位的传送,甚至允许暂停,因为SCK时钟线由主控设备控制,当没有时钟跳变时,从设备不采集或传送数据。
也就是说,主设备通过对SCK时钟线的控制可以完成对通讯的控制。
SPI还是一个数据交换协议:因为SPI的数据输入和输出线独立,所以允许同时完成数据的输入和输出。
不同的SPI设备的实现方式不尽相同,主要是数据改变和采集的时间不同,在时钟信号上沿或下沿采集有不同定义,具体请参考相关器件的文档。
在点对点的通信中,SPI接口不需要进行寻址操作,且为全双工通信,显得简单高效。
在多个从设备的系统中,每个从设备需要独立的使能信号,硬件上比I2C系统要稍微复杂一些。
最后,SPI接口的一个缺点:没有指定的流控制,没有应答机制确认是否接收到数据。
AT91RM9200的SPI接口主要由4个引脚构成:SPICLK、MOSI、MISO及/SS,其中SPICLK是整个SPI总线的公用时钟,MOSI、MISO作为主机,从机的输入输出的标志,MOSI是主机的输出,从机的输入,MISO 是主机的输入,从机的输出。
/SS是从机的标志管脚,在互相通信的两个SPI总线的器件,/SS管脚的电平低的是从机,相反/SS管脚的电平高的是主机。
在一个SPI通信系统中,必须有主机。
SPI总线可以配置成单主单从,单主多从,互为主从。
SPI的片选可以扩充选择16个外设,这时PCS输出=NPCS,说NPCS0~3接4-16译码器,这个译码器是需要外接4-16译码器,译码器的输入为NPCS0~3,输出用于16个外设的选择。
[编辑本段]SPI协议举例SPI是一个环形总线结构,由ss(cs)、sck、sdi、sdo构成,其时序其实很简单,主要是在sck的控制下,两个双向移位寄存器进行数据交换。
假设下面的8位寄存器装的是待发送的数据10101010,上升沿发送、下降沿接收、高位先发送。
那么第一个上升沿来的时候数据将会是sdo=1;寄存器中的10101010左移一位,后面补入送来的一位未知数x,成了0101010x。
下降沿到来的时候,sdi上的电平将锁存到寄存器中去,那么这时寄存器=0101010sdi,这样在8个时钟脉冲以后,两个寄存器的内容互相交换一次。
这样就完成里一个spi时序。
举例:假设主机和从机初始化就绪:并且主机的sbuff=0xaa,从机的sbuff=0x55,下面将分步对spi的8个时钟周期的数据情况演示一遍:假设上升沿发送数据这样就完成了两个寄存器8位的交换,上面的上表示上升沿、下表示下降沿,sdi、sdo相对于主机而言的。
其中ss引脚作为主机的时候,从机可以把它拉底被动选为从机,作为从机的是时候,可以作为片选脚用。
根据以上分析,一个完整的传送周期是16位,即两个字节,因为,首先主机要发送命令过去,然后从机根据主机的命令准备数据,主机在下一个8位时钟周期才把数据读回来。
SPI 总线是Motorola公司推出的三线同步接口,同步串行3线方式进行通信:一条时钟线SCK,一条数据输入线MOSI,一条数据输出线MISO;用于CPU与各种外围器件进行全双工、同步串行通讯。
SPI主要特点有:可以同时发出和接收串行数据;可以当作主机或从机工作;提供频率可编程时钟;发送结束中断标志;写冲突保护;总线竞争保护等。
下图示出SPI总线工作的四种方式,其中使用的最为广泛的是SPI0和SPI3方式(实线表示):SPI总线四种工作方式SPI 模块为了和外设进行数据交换,根据外设工作要求,其输出串行同步时钟极性和相位可以进行配置,时钟极性(CPOL)对传输协议没有重大的影响。
如果CPOL=0,串行同步时钟的空闲状态为低电平;如果CPOL=1,串行同步时钟的空闲状态为高电平。
时钟相位(CPHA)能够配置用于选择两种不同的传输协议之一进行数据传输。
如果CPHA=0,在串行同步时钟的第一个跳变沿(上升或下降)数据被采样;如果CPHA=1,在串行同步时钟的第二个跳变沿(上升或下降)数据被采样。
SPI主模块和与之通信的外设备时钟相位和极性应该一致。
SPI总线包括1根串行同步时钟信号线以及2根数据线。
SPI模块为了和外设进行数据交换,根据外设工作要求,其输出串行同步时钟极性和相位可以进行配置,时钟极性(CPOL)对传输协议没有重大的影响。
如果CPOL=0,串行同步时钟的空闲状态为低电平;如果CPOL=1,串行同步时钟的空闲状态为高电平。
时钟相位(CPHA)能够配置用于选择两种不同的传输协议之一进行数据传输。
如果CPHA=0,在串行同步时钟的第一个跳变沿(上升或下降)数据被采样;如果CPHA=1,在串行同步时钟的第二个跳变沿(上升或下降)数据被采样。
SPI主模块和与之通信的外设音时钟相位和极性应该一致。
SPI接口时序如图3、图4所示。
补充:上文中最后一句话:SPI主模块和与之通信的外设备时钟相位和极性应该一致。
个人理解这句话有2层意思:其一,主设备SPI时钟和极性的配置应该由外设来决定;其二,二者的配置应该保持一致,即主设备的SDO同从设备的SDO配置一致,主设备的SDI同从设备的SDI配置一致。
因为主从设备是在SCLK的控制下,同时发送和接收数据,并通过2个双向移位寄存器来交换数据。
工作原理演示如下图:上升沿主机SDO发送数据1,同时从设备SDO发送数据0;紧接着在SCLK的下降沿的时候从设备的SDI接收到了主机发送过来的数据1,同时主机也接收到了从设备发送过来的数据0.[编辑本段]SPI协议心得SPI接口时钟配置心得:在主设备这边配置SPI接口时钟的时候一定要弄清楚从设备的时钟要求,因为主设备这边的时钟极性和相位都是以从设备为基准的。
因此在时钟极性的配置上一定要搞清楚从设备是在时钟的上升沿还是下降沿接收数据,是在时钟的下降沿还是上升沿输出数据。
但要注意的是,由于主设备的SDO连接从设备的SDI,从设备的SDO连接主设备的SDI,从设备SDI接收的数据是主设备的SDO发送过来的,主设备SDI接收的数据是从设备SDO发送过来的,所以主设备这边SPI时钟极性的配置(即SDO的配置)跟从设备的SDI接收数据的极性是相反的,跟从设备SDO发送数据的极性是相同的。
下面这段话是Sychip Wlan8100 Module Spec上说的,充分说明了时钟极性是如何配置的:The 81xx module will always input data bits at the rising edge of the clock, and the host will always output data bits on the falling edge of the clock.意思是:主设备在时钟的下降沿发送数据,从设备在时钟的上升沿接收数据。
因此主设备这边SPI时钟极性应该配置为下降沿有效。
又如,下面这段话是摘自LCD Driver IC SSD1289:SDI is shifted into 8-bit shift register on every rising edge of SCK in the order of data bit 7, data bit 6 …… data bit 0.意思是:从设备SSD1289在时钟的上升沿接收数据,而且是按照从高位到地位的顺序接收数据的。
因此主设备的SPI时钟极性同样应该配置为下降沿有效。
时钟极性和相位配置正确后,数据才能够被准确的发送和接收。
因此应该对照从设备的SPI接口时序或者Spec文档说明来正确配置主设备的时钟。