SPI原理

目录

什么是SPI

SPI主从模式

SPI信号线

SPI设备选择 

SPI数据传输

 SPI传输数据量

SPI数据传输顺序

SPI数据CRC

SPI通信的四种模式

 SPI的通信协议

SPI的三种模式

运行模式(Run Mode)

等待模式(Wait Mode)

停止模式(Stop Mode)

优缺点

SPI通讯的优势

SPI的缺点


什么是SPI


        SPI 是英语Serial Peripheral interface的缩写,顾名思义就是串行外围设备接口。是Motorola(摩托罗拉)首先在其MC68HCXX系列处理器上定义的。

SPI,是一种单主机高速的全双工同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为PCB的布局上节省空间,提供方便,主要应用在 EEPROM,FLASH,实时时钟,AD转换器,还有数字信号处理器和数字信号解码器之间。

SPI主从模式


        SPI分为主、从两种模式,一个SPI通讯系统需要包含一个(且只能是一个)主设备,一个或多个从设备。提供时钟的为主设备(Master),接收时钟的设备为从设备(Slave),SPI接口的读写操作,都是由主设备发起。当存在多个从设备时,通过各自的片选信号进行管理。

        SPI是全双工且SPI没有定义速度限制,一般的实现通常能达到甚至超过10 Mbps

SPI信号线

SPI接口一般使用四条信号线通信:
        SDI(数据输入),SDO(数据输出),SCK(时钟),CS(片选)

  • MISO: Master In/Slave Out;主设备输入/从设备输出引脚。该引脚在从模式下发送数据,在主模式下接收数据。
  • MOSI: Master Out/Slave In;主设备输出/从设备输入引脚。该引脚在主模式下发送数据,在从模式下接收数据。
  • SCLK:串行时钟信号,由主设备产生。
  • CS/SS:Slave Select;从设备片选信号,由主设备控制。它的功能是用来作为“片选引脚”,也就是选择指定的从设备,让主设备可以单独地与特定从设备通讯,避免数据线上的冲突。

硬件上为4根线。
SPI一对一

在这里插入图片描述

SPI一对多

在这里插入图片描述

SPI设备选择 

        SPI是[单主设备( single-master )]通信协议,这意味着总线中的只有一支中心设备能发起通信。

        当SPI主设备想读/写[从设备]时,它首先拉低[从设备]对应的SS线(SS是低电平有效),接着开始发送工作脉冲到时钟线上,在相应的脉冲时间上,[主设备]把信号发到MOSI实现“写”,同时可对MISO采样而实现“读”,如下图:在这里插入图片描述

SPI数据传输


        SPI主机和从机都有一个串行移位寄存器,主机通过向它的SPI串行寄存器写入一个WORD来发起一次传输。

  • 首先拉低对应SS信号线,表示与该设备进行通信
  • 主机通过发送SCLK时钟信号,来告诉从机写数据或者读数据;这里要注意,SCLK时钟信号可能是低电平有效,也可能是高电平有效,因为SPI有四种模式,这个我们在下面会介绍
  • 主机(Master)将要发送的数据写到发送数据缓存区(Menory),缓存区经过移位寄存器(0~7),串行移位寄存器通过MOSI信号线将字节一位一位的移出去传送给从机,,同时MISO接口接收到的数据经过移位寄存器一位一位的移到接收缓存区。
  • 从机(Slave)也将自己的串行移位寄存器(0~7)中的内容通过MISO信号线返回给主机。同时通过MOSI信号线接收主机发送的数据,这样,两个移位寄存器中的内容就被交换。

在这里插入图片描述

        SPI只有主模式和从模式之分,没有读和写的说法,外设的写操作和读操作是同步完成的。如果只进行写操作,主机只需忽略接收到的字节;反之,若主机要读取从机的一个字节,就必须发送一个空字节来引发从机的传输。也就是说,你发一个数据必然会收到一个数据;你要收一个数据必须也要先发一个数据。 

 SPI传输数据量

        SPI传输的数据量需要提前规定好,即进行SPI传输前,主机、从机都知道每次传输的数据量是多少;以STM32-031为例,SPI通过寄存器配置,可选传输数据量为4/5/6...../14/15/16bit;

        如果需要传输5bit数据,则主机拉低SS后,会发送5个有效时钟(不含CRC情况;总时钟可能是5个,可能是6个,与时钟极性、相位配置有关);

        5个有效时钟后,主机、从机均认为本次传输完成;此时主机的TX发送完成(发送到从机的RX寄存器);从机的TX数据发送到主机的RX寄存器;

        如果主机还需要继续传输数据,可以不拉高SS信号,待数据准备完成后,继续输出有效时钟,继续重复进行数据传输;

SPI数据传输顺序

        SPI发送、接受数据的顺序(LSB、MSB)可配置,但是主机和从机必须使用相同的配置。

SPI数据CRC

        SPI传输的数据支持CRC,即数据发送完成后,继续发送对应的CRC数据;

        是否使能CRC可配置;

        CRC数据长度可配,支持8/16bit;

SPI通信的四种模式

SPI的四种模式,简单地讲就是设置SCLK时钟信号线的那种信号为有效信号

        SPI通信有4种不同的操作模式,不同的从设备可能在出厂是就是配置为某种模式,这是不能改变的;但我们的通信双方必须是工作在同一模式下,所以我们可以对我们的主设备的SPI模式进行配置,通过CPOL(时钟极性)和CPHA(时钟相位)来
控制我们主设备的通信模式,具体如下:

时钟极性(CPOL)定义了时钟空闲状态电平

  • CPOL=0,表示当SCLK=0时处于空闲态,即时钟高电平有效
  • CPOL=1,表示当SCLK=1时处于空闲态,既始终低电平有效

时钟相位(CPHA)定义数据的采集时间

  • CPHA=0,在时钟的第一个跳变沿(上升沿或下降沿)进行数据采样。,在第2个边沿发送数据
  • CPHA=1,在时钟的第二个跳变沿(上升沿或下降沿)进行数据采样。,在第1个边沿发送数据

例如:

  • Mode0:CPOL=0,CPHA=0:此时空闲态时,SCLK处于低电平,数据采样是在第1个边沿,也就是SCLK由低电平到高电平的跳变,所以数据采样是在上升沿(准备数据),(发送数据)数据发送是在下降沿。
  • Mode1:CPOL=0,CPHA=1:此时空闲态时,SCLK处于低电平,数据发送是在第1个边沿,也就是SCLK由低电平到高电平的跳变,所以数据采样是在下降沿,数据发送是在上升沿。
  • Mode2:CPOL=1,CPHA=0:此时空闲态时,SCLK处于高电平,数据采集是在第1个边沿,也就是SCLK由高电平到低电平的跳变,所以数据采集是在下降沿,数据发送是在上升沿。
  • Mode3:CPOL=1,CPHA=1:此时空闲态时,SCLK处于高电平,数据发送是在第1个边沿,也就是SCLK由高电平到低电平的跳变,所以数据采集是在上升沿,数据发送是在下降沿。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

 SPI的通信协议

在这里插入图片描述

        主从设备必须使用相同的工作模式——SCLK、CPOL 和 CPHA,才能正常工作。如果有多个从设备,并且它们使用了不同的工作模式,那么主设备必须在读写不同从设备时需要重新修改对应从设备的模式。以上SPI总线协议的主要内容。
        这也是SPI接口的一个缺点:没有指定的流控制,没有应答机制确认是否接收到数据

SPI的三种模式


SPI工作在3中模式下,分别是运行、等待和停止。

运行模式(Run Mode)


        这是基本的操作模式

等待模式(Wait Mode)


        SPI工作在等待模式是一种可配置的低功耗模式,可以通过SPICR2寄存器的SPISWAI位进行控制。在等待模式下,如果SPISWAI位清0,SPI操作类似于运行模式。如果SPISWAI位置1,SPI进入低功耗状态,并且SPI时钟将关闭。如果SPI配置为主机,所有的传输将停止,但是会在CPU进入运行模式后重新开始。如果SPI配置为从机,会继续接收和传输一个字节,这样就保证从机与主机同步。

停止模式(Stop Mode)

       
        为了降低功耗,SPI在停止模式是不活跃的。如果SPI配置为主机,正在进行的传输会停止,但是在CPU进入运行模式后会重新开始。如果SPI配置为从机,会继续接受和发送一个字节,这样就保证了从机与主机同步

优缺点


SPI通讯的优势

  • 全双工串行通信;
  • 高速数据传输速率。
  • 简单的软件配置;
  • 极其灵活的数据传输,不限于8位,它可以是任意大小的字;
  • 非常简单的硬件结构。从站不需要唯一地址(与I2C不同)。从机使用主机时钟,不需要精密时钟振荡器/晶振(与UART不同)。不需要收发器(与CAN不同)。

SPI的缺点

  • 没有硬件从机应答信号(主机可能在不知情的情况下无处发送);
  • 通常仅支持一个主设备;
  • 需要更多的引脚(与I2C不同);
  • 没有定义硬件级别的错误检查协议;
  • 与RS-232和CAN总线相比,只能支持非常短的距离;
  • 6
    点赞
  • 63
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Lan9252是一款集成了以太网PHY、ARM处理器和SPI接口的芯片,用于实现通过SPI总线与主控器连接以太网的功能。下面是Lan9252 SPI原理图的详细说明。 Lan9252 SPI原理图主要包含以下几个关键部分: 1. SPI接口:Lan9252通过SPI总线与主控器进行通信。SPI包括四个信号线:时钟线(SCK)、主设备输出、从设备输出和数据线(SDO与SDI)。主控器通过SCK来控制时序,通过SDI发送数据给Lan9252,通过SDO接收Lan9252返回的数据。 2. ARM处理器:Lan9252内置了ARM处理器,用于运行以太网协议栈和处理网络数据包。ARM处理器可以通过SPI接口与主控器进行通信。在Lan9252原理图中,ARM处理器与SPI接口相连,通过CS(片选)信号进行使能和禁用。 3. 以太网PHY:Lan9252内部集成了以太网物理层(PHY),用于实现以太网信号的调制和解调。以太网PHY与ARM处理器之间通过内部总线进行连接,以传输网络数据包。 4. 功率和时钟源:Lan9252原理图中还包含用于供电的部分,例如稳压电源和滤波电容。此外,还有外部晶体或振荡器提供系统时钟。 5. 外部接口:Lan9252原理图还可能包含与其它外设或外部器件连接的接口,例如LED指示灯、电压和温度传感器等。 通过以上这些关键部分的组合和连接,Lan9252 SPI原理图实现了Lan9252芯片与主控器之间的通信,并能够将主控器数据包转换为以太网信号进行网络通信。这样的设计使得Lan9252可以广泛应用于物联网、工业自动化等领域。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值