DSP课件 串行外设接口SPI.ppt

  1. 1、本文档共26页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
SPI通过对寄存器SPIBRR的配置,可以实现125种不同的波特率,计算公式如下: 当SPIBRR=0,1,2时: 当SPIBRR=3~127时: SPI是Serial Peripheral Interface的缩写,翻译成中文就是串行外围设备接口。 SPI是一种高速的同步串行输入输出接口,允许1~16位的数据流在设备与设备之间进行交换,通常用于DSP与外围设备或者DSP与其他控制器之间进行通信。 SCI 串行通信接口 低速异步串行通信 SPI 串行外设接口 高速同步串行通信 同步通信时,通信双方的设备必须拥有相同的时钟脉冲,以相同的步调进行数据传输,就像国庆阅兵时,队伍中的官兵在统一的口令下齐步前进,整齐划一。 异步通信时,通信双方的设备可以拥有各自独立的时钟脉冲,可以独自进行数据传输,就像是两个人在散步,可以各走各的。 SPI的总线系统可以直接与各个厂家生产的多标准外围器件直接接口,SPI接口一般使用四条线。当然,并不是所有的SPI接口都是采用四线制的,有的SPI接口带有中断信号线INT,而有的SPI接口没有主机输出/从机输入线MOSI。在X281X中SPI接口采用的是四线制。 线路名称 线路作用 SCK 串行时钟线 MISO 主机输入/从机输出线 MOSI 主机输出/从机输入线 低电平有效的从机选择线 SPI是一个环形总线结构,其时序其实比较简单,主要是在时钟脉冲SCK的控制下,两个双向移位寄存器SPIDAT进行数据交换。 具有4个外部引脚 。 有两种工作模式可以选择:主工作模式和从工作模式。 波特率:具有125种可编程的波特率。能够使用的最大波特率受到I/O缓冲器最大缓存速度的限制,这些缓冲器是使用在SPI引脚上的I/O缓冲器,而最高的波特率不能超过LSPCLK/4。 单次发送的数据字的长度为1~16位,可以通过寄存器设定。 可选择的四种脉冲时钟配置方案 。 接收和发送可以同步操作,也就是说可以实现全双工通信。 和SCI相同,发送和接收都能通过查询或者中断方式来实现。 具有6个控制寄存器、3个数据寄存器和3个FIFO寄存器。值得注意的是,SPI所有的控制寄存器都是8位的,当寄存器被访问时,数据位于低8位,而高8位为0,因此把数据写入SPI这6个控制寄存器的高8位是无效的。 X281X的SPI也具有2个16级的FIFO,一个用于发送数据,一个用于接收数据。 在标准的SPI模式(非FIFO模式)下,发送中断和接收中断都使用SPIINT/RXINT。在FIFO模式中,接收中断使用SPIINT/RXINT,而发送中断使用的是SPITXINT。 信号名称 功能描述 外部引脚 SPISOMI SPI从模式输出/主模式输入引脚 SPISIMO SPI从模式输入/主模式输出引脚 SPICLK SPI串行时钟引脚 SPI从模式发送使能引脚 控制信号 SPI时钟速率 LSPCLK 中断信号 SPIINT/RXINT 发送中断/接收中断(不使用FIFO情况下) SPITXINT 发送中断(使用FIFO情况下) 问: 如何设置SPI成为主机,就像图15-6中的处理器1? 答:通过设置SPI工作控制寄存器SPICTL的MASTER/SLAVE位为1来使得SPI工作于主机模式。编程的语句为: SpiaRegs.SPICTL.bit.MASTER_SLAVE=1 。 问:整个SPI的通信网络中的时钟和波特率是由主机来提供的吗? 答:是的。从字面上理解,主机就是在系统中占主导地位的设备,关乎到整个系统的运行。主机通过SPICLK引脚为整个通信网络提供时钟脉冲信号。由于每经过一个时钟脉冲,SPI就完成一位数据的发送,因此时钟脉冲的频率就是通常所说的波特率,其值由主机的SPIBBR寄存器来决定。通过对SPIBBR寄存器的编程,SPI能够实现125种不同的波特率,最大波特率为LSPCLK/4。 问:主机的数据是如何发送和接收的呢? 答:主机通过SPISIMO引脚来发送数据,而通过SPISOMI引脚输入数据。如图15-6所示,当数据写到移位寄存器SPIDAT或者写到串行发送缓冲器SPITXBUF的时候,就会启动SPISIMO引脚开始发送数据,首先发送的是SPIDAT的最高位,接着将剩余的数据左移1位,然后将接收到得数据通过SPISOMI引脚移入SPIDAT的最低有效位。 问:在数据传输过程和传输完成两种状态时,主机的SPISTE引脚有何变化? 答:从前面的学习已经知道,引脚SPISTE是从机使能信号,这是

文档评论(0)

ldj215323 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档