EDN首页   博客首页

日志档案

发表于 2007-1-8 14:19:25

15

标签: 无标签

SPI接口介绍

 SPI接口的全称是"Serial Peripheral Interface",意为串行外围接口,是Motorola首先在其MC68HCXX系列处理器上定义的。SPI接口主要应用在EEPROM,FLASH,实时时钟,AD转换器,还有数字信号处理器和数字信号解码器之间。

   SPI接口是在CPU和外围低速器件之间进行同步串行数据传输,在主器件的移位脉冲下,数据按位传输,高位在前,地位在后,为全双工通信,数据传输速度总体来说比I2C总线要快,速度可达到几Mbps。

   SPI接口是以主从方式工作的,这种模式通常有一个主器件和一个或多个从器件,其接口包括以下四种信号:

(1)MOSI – 主器件数据输出,从器件数据输入
(2)MISO – 主器件数据输入,从器件数据输出
(3)SCLK – 时钟信号,由主器件产生
(4)/SS  – 从器件使能信号,由主器件控制

在点对点的通信中,SPI接口不需要进行寻址操作,且为全双工通信,显得简单高效。
      在多个从器件的系统中,每个从器件需要独立的使能信号,硬件上比I2C系统要稍微复杂一些。

  SPI接口在内部硬件实际上是两个简单的移位寄存器,传输的数据为8位,在主器件产生的从器件使能信号和移位脉冲下,按位传输,高位在前,低位在后。如下图所示,在SCLK的下降沿上数据改变,同时一位数据被存入移位寄存器。

点击看大图

SPI接口内部硬件图示:
点击看大图

最后,SPI接口的一个缺点:没有指定的流控制,没有应答机制确认是否接收到数据。

系统分类: 单片机   |   用户分类: 单片机   |   来源: 转贴   |   【推荐给朋友】   |   【添加到收藏夹】

    阅读(2661)    回复(1)  

投一票您将和博主都有获奖机会!

  • ahoo1225

    2008-1-15 10:57:09

    感谢你的资料,很有价值,我也看了其他关于SPI的资料,不过你文中也有两点失误的地方。1.SPI没有确定使用MSB First还是LSB First     2.SPI也没有确定数据输出是在上Rising Edge还是在Falling Edge

    MSB First/LSB First和Rising Edge/Falling Edge在一个通用SPI内核上一般是可以通过内部寄存器设置的。