ImageVerifierCode 换一换
格式:PDF , 页数:44 ,大小:817.08KB ,
资源ID:3209372      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/3209372.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(SPI总线协议及SPI时序图详解含实例.pdf)为本站会员(b****1)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

SPI总线协议及SPI时序图详解含实例.pdf

1、SPI总线协议及总线协议及SPI时序图详解时序图详解 SPI,是英语 Serial Peripheral Interface 的缩写,顾名思义就是串行外围设备接口。SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为 PCB 的布局上节省空间,提供方便,正是出于这种简单易用的特性,现在越来越多的芯片集成了这种通信协议。SPI 是一个环形总线结构,由 ss(cs)、sck、sdi、sdo 构成,其时序其实很简单,主要是在 sck 的控制下,两个双向移位寄存器进行数据交换。上升沿发送、下降沿接收、高位先发送。上升沿到来的时候,sdo 上的电平将被发

2、送到从设备的寄存器中。下降沿到来的时候,sdi 上的电平将被接收到主设备的寄存器中。假设主机和从机初始化就绪:并且主机的 sbuff=0 xaa(10101010),从机的 sbuff=0 x55(01010101),下面将分步对 spi 的 8 个时钟周期的数据情况演示一遍(假设上升沿发送数据)。-脉冲 主机 sbuff 从机 sbuff sdi sdo-0 00-0 10101010 01010101 0 0-1 0-1 0101010 x 10101011 0 1 1 1-0 01010100 10101011 0 1-2 0-1 1010100 x 01010110 1 0 2 1-0

3、 10101001 01010110 1 0-3 0-1 0101001x 10101101 0 1 3 1-0 01010010 10101101 0 1-4 0-1 1010010 x 01011010 1 0 4 1-0 10100101 01011010 1 0-5 0-1 0100101x 10110101 0 1 5 1-0 01001010 10110101 0 1-6 0-1 1001010 x 01101010 1 0 6 1-0 10010101 01101010 1 0-7 0-1 0010101x 11010101 0 1 7 1-0 00101010 11010101

4、 0 1-8 0-1 0101010 x 10101010 1 0 8 1-0 01010101 10101010 1 0-这样就完成了两个寄存器 8 位的交换,上面的 0-1 表示上升沿、1-0 表示下降沿,sdi、sdo 相对于主机而言的。根据以上分析,一个完整的传送周期是 16 位,即两个字节,因为,首先主机要发送命令过去,然后从机根据主机的名准备数据,主机在下一个 8 位时钟周期才把数据读回来。SPI 总线是 Motorola 公司推出的三线同步接口,同步串行 3 线方式进行通信:一条时钟线 SCK,一条数据输入线 MOSI,一条数据输出线 MISO;用于 CPU 与各种外围器件进行全

5、双工、同步串行通讯。SPI 主要特点有:可以同时发出和接收串行数据;可以当作主机或从机工作;提供频率可编程时钟;发送结束中断标志;写冲突保护;总线竞争保护等。SPI 总线有四种工作方式(SP0,SP1,SP2,SP3),其中使用的最为广泛的是 SPI0 和SPI3 方式。SPI 模块为了和外设进行数据交换,根据外设工作要求,其输出串行同步时钟极性和相位可以进行配置,时钟极性(CPOL)对传输协议没有重大的影响。如果 CPOL=0,串行同步时钟的空闲状态为低电平;如果 CPOL=1,串行同步时钟的空闲状态为高电平。时钟相位(CPHA)能够配置用于选择两种不同的传输协议之一进行数据传输。如果 CP

6、HA=0,在串行同步时钟的第一个跳变沿(上升或下降)数据被采样;如果 CPHA=1,在串行同步时钟的第二个跳变沿(上升或下降)数据被采样。SPI 主模块和与之通信的外设音时钟相位和极性应该一致。SPI 时序图详解-SPI 接口在模式 0 下输出第一位数据的时刻 SPI 接口在模式 0 下输出第一位数据的时刻 SPI 接口有四种不同的数据传输时序,取决于 CPOL 和 CPHL 这两位的组合。图 1 中表现了这四种时序,时序与 CPOL、CPHL 的关系也可以从图中看出。图 1 CPOL 是用来决定 SCK 时钟信号空闲时的电平,CPOL0,空闲电平为低电平,CPOL1 时,空闲电平为高电平。C

7、PHA 是用来决定采样时刻的,CPHA=0,在每个周期的第一个时钟沿采样,CPHA1,在每个周期的第二个时钟沿采样。由于我使用的器件工作在模式 0 这种时序(CPOL0,CPHA0),所以将图 1 简化为图 2,只关注模式 0 的时序。图 2 我们来关注 SCK 的第一个时钟周期,在时钟的前沿采样数据(上升沿,第一个时钟沿),在时钟的后沿输出数据(下降沿,第二个时钟沿)。首先来看主器件,主器件的输出口(MOSI)输出的数据 bit1,在时钟的前沿被从器件采样,那主器件是在何时刻输出 bit1 的呢?bit1 的输出时刻实际上在 SCK 信号有效以前,比 SCK 的上升沿还要早半个时钟周期。bi

8、t1 的输出时刻与 SSEL 信号没有关系。再来看从器件,主器件的输入口 MISO 同样是在时钟的前沿采样从器件输出的 bit1 的,那从器件又是在何时刻输出 bit1 的呢。从器件是在 SSEL 信号有效后,立即输出 bit1,尽管此时 SCK 信号还没有起效。关于上面的主器件 和从器件输出 bit1 位的时刻,可以从图 3、4 中得到验证。图 3 注意图 3 中,CS 信号有效后(低电平有效,注意 CS 下降沿后发生的情况),故意用延时程序 延时了一段时间,之后再向数据寄存器写入了要发送的数据,来观察主器件输出 bit1的情况(MOSI)。可以看出,bit1(值为 1)是在 SCK 信号有

9、效之前的半个时钟周期的时刻开始输出的(与 CS 信号无关),到了 SCK 的第一个时钟周期的上升沿正好被从器件采样。图 4 图 4 中,注意看 CS 和 MISO 信号。我们可以看出,CS 信号有效后,从器件立刻输出了 bit1(值为 1)。通常我们进行的 spi 操作都是 16 位的。图 5 记录了第一个字节和第二个字节间的相互衔接的过程。第一个字节的最后一位在 SCK 的上升沿被采样,随后的 SCK 下降沿,从器件就输出了第二个字节的第一位。SPI 总线协议介绍(接口定义,传输时序)一、技术性能 SPI 接口是 Motorola 首先提出的全双工三线同步串行外围接口,采用主从模式(Mast

10、er Slave)架构;支持多 slave 模式应用,一般仅支持单 Master。时钟由 Master 控制,在时钟移位脉冲下,数据按位传输,高位在前,低位在后(MSB first);SPI 接口有 2 根单向数据线,为全双工通信,目前应用中的数据速率可达几 Mbps的水平。-二、接口定义 SPI 接口共有 4 根信号线,分别是:设备选择线、时钟线、串行输出数据线、串行输入数据线。(1)MOSI:主器件数据输出,从器件数据输入(2)MISO:主器件数据输入,从器件数据输出(3)SCLK:时钟信号,由主器件产生(4)/SS:从器件使能信号,由主器件控制-三、内部结构 -四、传输时序 SPI 接口

11、在内部硬件实际上是两个简单的移位寄存器,传输的数据为 8 位,在主器件产生的从器件使能信号和移位脉冲下,按位传输,高位在前,低位在后。如下图所示,在 SCLK的下降沿上数据改变,上升沿一位数据被存入移位寄存器。SPI 接口没有指定的流控制,没有应答机制确认是否接收到数据。SPI 接口时钟配置:在主设备这边配置 SPI 接口时钟的时候一定要弄清楚从设备的时钟要求,因为主设备这边的时钟极性和相位都是以从设备为基准的。因此在时钟极性的配置上一定要搞清楚从设备是在时钟的上升沿还是下降沿接收数据,是在时钟的下降沿还是上升沿输出数据。但要注意的是,由于主设备的 SDO 连接从设备的 SDI,从设备的 SD

12、O 连接主设备的 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 o

13、utput 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 在时钟的上升沿接收数据,而且是按照从高位到低

14、位的顺序接收数据的。因此主设备的 SPI 时钟极性同样应该配置为下降沿有效。时钟极性和相位配置正确后,数据才能够被准确的发送和接收。因此应该对照从时钟极性和相位配置正确后,数据才能够被准确的发送和接收。因此应该对照从设备的设备的 SPI 接口时序或者接口时序或者 Spec 文档说明来正确配置主设备的时钟。文档说明来正确配置主设备的时钟。SPI,是英语 Serial Peripheral interface 的缩写,顾名思义就是串行外围设备接口。SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片 的管脚,同时为 PCB 的布局上节省空间,提供方便,正是出于这

15、种简单易用的特性,现在越来越多的芯片集成了这种通信协议,比如 P89LPC900.SPI,是一种高速的,全双工,同步的通信总线,其工作模式有两种:主模式和从模式,无论那种模式,都支持 3Mbit/s 的速率,并且还具有传输完成标志和写冲突保护标志。到目前为止,我使用过的具有 SPI 总线的器件,就是存储芯片 Eprom:at25128,在使用过程中,发现的确是有这种总线的优点。下面以 P89LPC900 单片机的 SPI 总线来解释 SPI 总线的通用使用规 则。LPC900单片机的SPI接口主要由4个引脚构成:SPICLK、MOSI、MISO及/SS,其中SPICLK是整个 SPI 总线的公

16、用时 钟,MOSI、MISO 作为主机,从机的输入输出的标志,MOSI 是主机的输出,从机的输入,MISO 是主机的输入,从机的输出。/SS 是从机的标志管脚,在互相通信的两个 SPI 总线的器件,/SS 管脚的电平低的是从机,相反/SS 管脚的电平高的是主机。在一个 SPI 通信系统中,必须有主机。SPI 总线可以配置成单主单从,单主多从,互为主从。今以互为主从模式作为讲解:要进行 SPI 互为主从操作,必须遵照以下步骤:1 对 A、B 进行初始化,均设为主机(需要进行以下操作)。a)SPI 端口初始化为准双向。b)SPCTL 配置为 0 x50,SSIG=0,SPEN=1,MSTR=1。c)清除 SPSTAT 中的 SPIF 及 WCOL 标志位为 0。d)如果需要使用 SPI 中断,可使能相应中断位。2 将 A 上一个引脚连接到 B 的/SS 引脚上,然后拉低/SS,可将 B 强行置为从机模式,同时B 机会发生以下变化:a)B 机的 MSTR 位自动清 0。b)B 机的 MOSI 及 SPICLK 强行变为输入模式,MISO 则变为输出模式。c)B 机 SPIF 位置位。d)如果

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1