SPI协议详解(Standard SPI、Dual SPI和Queued SPI)

这篇具有很好参考价值的文章主要介绍了SPI协议详解(Standard SPI、Dual SPI和Queued SPI)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、标准SPI

1.1、SPI接口的引脚

queued spi,嵌入式驱动开发,单片机,嵌入式硬件,SPI协议

(1)SCLK:时钟线;
(2)MOSI(master output slave input):主设备输出,从设备输入,单向传输;
(3)MISO(master input slave output):主设备输入,从设备输出,单向传输;
(4)CS(chip select):片选信号,用于主片选中从片;

1.2、SPI通信协议

queued spi,嵌入式驱动开发,单片机,嵌入式硬件,SPI协议

(1)SPI(serial peripheral interface)是串行外设接口的缩写;
(2)SPI是一种高速的、全双工、同步的串行通信总线; 全双工体现在主从设备间通信时发送数据和接收数据是单独的数据线,能够同时接收和发送数据;同步体现在主从设备间有时钟线,主设备提供时钟信号;
(3)SPI可以实现采用主从方式工作,实现一对多,其中主设备通过多个CS片选引脚来控制和从设备的通信;
(4)SPI总线在传输数据时,先传送高位,后传送地位;数据线为高电平表示逻辑1,低电平表示逻辑0;一个字节传送完成后,无须应答即可开始下一个字节的传送;
(5)主设备/从设备在时钟线的上升沿或者下降沿往数据线上发送数据,在下降沿或者上升沿从数据线上读取数据;

1.3、SPI的四种模式:相位和极性

CPOL=0 CPOL=1
CPHA=0 时钟线在空闲时为低电平;在每个周期的第一个时钟沿采样 时钟线在空闲时为高电平;在每个周期的第一个时钟沿采样
CPHA=1 时钟线在空闲时为低电平;在每个周期的第二个时钟沿采样 时钟线在空闲时为高电平;在每个周期的第二个时钟沿采样

(1)相位(CPOL):表示时钟线空闲时的状态;
(2)极性(CPHA):表示设备从数据线采样的时刻;

1.4、时序分析

queued spi,嵌入式驱动开发,单片机,嵌入式硬件,SPI协议

(1)上面的时序图是CPOL=1 ,CPHA=1的情况;
(2)MSB代表字节数据的高位,LSB代表字节数据的地位,所以SPI协议是先发高位再发低位;
(3)在每个时钟周期发送一个bit的数据,数据在数据线上的发送和接收是在一个时钟周期里完成的,前半个周期A设备往数据线上发数据,后半个周期B设备从数据线上读数据;
(4)分析MOSI线上发送MSB位的时序:空闲时时钟线是高位,在时钟线的下降沿主设备开始往MOSI线发数据,在上升沿时从设备从MOSI线上读数据,这样一个bit就传输完成;
(5)空闲时时钟线是高电平,所以CPOL=1;每个时钟周期都是先有下降沿再有上升沿,设备是在上升沿采样,而上升沿是时钟周期的第二个时钟沿,所以CPHA=1;

1.5、四种模式的选择

(1)实际的电路中,SPI协议中的主设备就是主控,从设备是外设;
(2)主控的SPI控制中,模式是可以配置的,但是从设备的模式是在出厂的时候就定死了;
总结:查阅外设的数据手册,知道外设的SPI模式,主设备去适配从设备的模式;

1.6、SPI协议的优缺点

优点:
(1)没有像I2C这样复杂的从设备寻址系统;
(2)分离的MISO和MOSI信号线,因此可以同时发送和接收数据,支持全双工;
(3)极其灵活的数据传输,不限于8位,它可以是任意大小的字;
(4)数据传输速率比I2C更高(几乎快两倍);
缺点:
(1)使用四根信号线(I2C和UART使用两根信号线);
(2)虽然没有负责的从设备寻址系统,但是要为每个从设备预留一根CS片选线;
(3)没有应答机制,无法确认是否已成功接收数据;
(4)与RS-232和CAN总线相比,只能支持非常短的距离;

2、Dual SPI和QSPI

2.1、使用场景介绍

(1)通常我们说的SPI就是Standard SPI,有4根信号线,分别为CLK、CS、MOSI和MISO,也就是上面介绍的SPI协议;
(2)Dual SPI:只是针对SPI Flash而言,不是针对所有SPI外设。对于SPI Flash,全双工并不常用,因此扩展了mosi和miso的用法,让它们工作在半双工,用以加倍数据传输。也就是对于Dual SPI Flash,可以发送一个命令字节进入dual mode,这样MOSI变成SIO0(serial io 0),MISO变成SIO1(serial io 1),这样一个时钟周期内就能传输2个bit数据,加倍了数据传输;
(3)Queued SPI Flash:在Dual SPI的基础上增加了两根I/O线(SIO2,SIO3),目的是一个时钟内传输4个bit,而QSPI就是Queued SPI的简写;
总结:Dual SPI和Queued SPI是针对flash的接口,根据flash工作的特性,将全双工改为半双工,提高通信的速率;

2.2、QSPI接口分析

queued spi,嵌入式驱动开发,单片机,嵌入式硬件,SPI协议
queued spi,嵌入式驱动开发,单片机,嵌入式硬件,SPI协议>(1)CS:片选线;
(2)WP(IO2):复用引脚,WP(write protect):当做写保护引脚;IO2就是当做数据传输引脚;
(3)HOLD(IO3):复用引脚,做HOLD功能时是暂停QSPI Flash的操作,IO3就是当做数据传输引脚;
总结:QSPI的引脚是功能复用的,具体时序不去分析,最终要达到的效果是能时序同时4根数据线去传输数据;

2.3、QSPI的电路原理图

queued spi,嵌入式驱动开发,单片机,嵌入式硬件,SPI协议

(1)上面是SPI flash的电路原理图;
(2)连接的线:时钟线、复位线、片选线、4根数据传输线;

3、三种SPI协议的总结

(1)标准SPI是通用的,Dual SPI和QSPI只适用于flash;
(2)标准SPI:标准4线连接,全双工,同时收和发;
(3)Dual SPI:标准4线连接,半双工,2根数据线,并线发和收,双方向切换;
(4)QSPI:标准4线连接,半双工,4根数据线,并线发和收,双方向切换;文章来源地址https://www.toymoban.com/news/detail-812067.html

到了这里,关于SPI协议详解(Standard SPI、Dual SPI和Queued SPI)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 嵌入式学习笔记——SPI通信

    之前已经介绍了STM32的ADC、DMA、EXTI、TIME、NVIC、USART以及普通IO模式,此系列笔者还打算写最后三个大的内容,分别是SPI通信、IIC通信以及看门狗,后面就看大家的需求了,需要什么可以留在评论区,本文首先来介绍SPI的有关知识。 在通信协议分类的介绍中,提到过SPI,它是一

    2023年04月09日
    浏览(45)
  • 嵌入式Linux驱动开发——解决/sys/bus/spi/devices下没有对应的spi设备文件

    最近在学习Linux驱动开发中SPI总线的驱动框架,但在修改完设备树添加完对应的spi设备节点后,理应在/sys/bus/spi下会有对应的spi设备,我的目录下面没有。 无spi设备 然后我查看了/proc/device-tree,发现有对应的spi设备节点,我就先没有过多理会这个问题。 /proc/device-tree下有对应

    2024年02月16日
    浏览(43)
  • SPI通信协议&SPI通信外设

    目录 SPI 介绍 硬件电路 移位示意图  软件SPI SPI时序基本单元  SPI时序​编辑 W25Q64  硬件电路 W25Q64框图 Flash操作注意事项 指令集  硬件SPI SPI框图  主模式全双工连续传输 非连续传输  推挽输出 ,高低电平都有很强的驱动能力,使得上升沿和下降沿都很迅速。   当ss为高电

    2024年02月10日
    浏览(48)
  • 嵌入式Linux裸机开发(七)UART串口、IIC、SPI通信

    大概学完这三种通信后,之后就先去学系统移植,其他的先暂时放下 串口全称叫做串行接口,通常也叫做 COM 接口。 UART:(Universal Asynchronous Receiver/Trasmitter)通用异步串行收发器。 USART:(Universal Synchronous/Asynchronous Receiver/Transmitter)通用同步/异步串行收发器,相比 UART多了

    2024年02月07日
    浏览(74)
  • 【STM32 CubeMX】SPI层次结构SPI协议与SPI控制器结构

    随着嵌入式系统的迅猛发展,STM32系列微控制器在各种应用中得到广泛应用。在嵌入式系统设计中,串行外设接口(SPI)是一种常见且重要的通信协议。为了更便捷地配置和使用SPI,STMicroelectronics提供了一款强大的工具——STM32 CubeMX。本文将着重介绍STM32 CubeMX中SPI的层次结构

    2024年02月20日
    浏览(43)
  • FPGA:三大协议(UART、IIC、SPI)之SPI

    摘要:1、本文介绍SPI物理层面连接(通过哪几条线通信),2、本文介绍SPI时序(通过哪种方式进行器件之间交流)。3、提供主机和从机verilog代码。4、仅供自己参考 一、SPI物理层连接 (1)有四根线连接:CS_N(片选信号--主机发出)、miso(从机发出,主机接收)、mosi(主机发

    2024年02月14日
    浏览(42)
  • 通信协议(二)——SPI协议

    1.1 概念 SPI(Serial Peripheral Interface,串行外围设备接口),是Motorola公司提出的一种同步串行接口技术,是一种高速、全双工、同步通信总线,在芯片中只占用四根管脚用来控制及数据传输,广泛用于EEPROM、Flash、RTC(实时时钟)、ADC(数模转换器)、DSP(数字信号处理器)以

    2023年04月08日
    浏览(36)
  • 全志V3S嵌入式驱动开发(spi-nand驱动)

    【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】         nand flash相信大家并不陌生,现在很多的固态硬盘上面,其实有很多的nand flash。只不过根据存储单元,分成slc、mlc和tlc三种。早在差不多20年前,那个时候大家还都是学习s3c2440,标准的

    2024年02月09日
    浏览(53)
  • SPI通信协议及基于Arduino的SPI通信例程

    一、SPI通信协议介绍 SPI通信协议(Serial Peripheral Interface)是一种同步串行通信协议,由Motorola公司在1980年代初开发。SPI协议常用于单片机、嵌入式系统和外围设备之间的通信。 SPI协议使用四根线进行通信:时钟线(SCLK)、数据输入线(MOSI)、数据输出线(MISO)和从机选择

    2024年02月07日
    浏览(40)
  • SPI协议的verilog实现(spi master slave联合实现)

    spi是serial peripheral interface的缩写,即串行扩展总线。SPI是单主设备通信,总线中只有一个主设备发起通信,能发起通信的设备称为主设备。当SPI主设备想读写从设备时,首先拉低对应从设备的ss线(低电平有效)。然后发送工作麦种到时钟线上,在相应的脉冲时间上,主设备

    2024年02月02日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包