【总线】SPI 通信协议

article/2025/9/21 13:58:26

目录

SPI总线协议概述

串行与并行通信

SPI通信介绍

SPI的工作原理

时钟

从属选择

多个从机

常规方法

菊花链方法

MOSI 和 MISO

SPI 数据传输的步骤

SPI 的优缺点

优点

缺点

 文章参考


SPI总线协议概述

SPI是许多不同设备使用的通用通信协议。例如,SD卡读卡器模块、RFID卡读卡器模块和 2.4GHz无线发射器/接收器都使用 SPI 与微控制器进行通信。

电子设备之间的通信就像人与人之间的通信。双方都需要说同一种语言。在电子学中,这些语言被称为通信协议。常见的通信协议有SPI、UART、I2C等。

首先,我们将从一些关于电子通信的基本概念开始,然后详细解释SPI的工作原理。

SPI,I2C和UART比USB,以太网,蓝牙和WiFi等协议慢得多,但它们更简单,使用更少的硬件和系统资源。SPI、I2C 和 UART 非常适合微控制器之间以及不需要传输大量高速数据的微控制器和传感器之间的通信。

串行与并行通信

电子设备通过设备之间物理连接的电线发送数据位来相互通信。设备之间通过传递位来进行通信,位是二进制的,只能是1或0。通过电压的快速变化,位从一个设备传输到另一个设备。在5 V工作系统中,0V的电压值为0,而5V的电压值为1。

数据位可以并行或串行形式传输。在并行通信中,数据位同时发送,每个数据位都通过单独的导线发送。下图显示了字母“C”在二进制(01000011)中的并行传输:

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBATGluZXN0LTU=,size_20,color_FFFFFF,t_70,g_se,x_16

在串行通信中,位通过单根线逐个发送。下图显示了字母“C”在二进制(01000011)中的串行传输:

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBATGluZXN0LTU=,size_20,color_FFFFFF,t_70,g_se,x_16

SPI通信介绍

SPI的一个独特优势是数据可以不间断地传输。可以在连续流中发送或接收任意数量的位。使用I2C和UART,数据以数据包形式发送,限制为特定数量的位。开始和停止条件定义了每个数据包的开始和结束,因此数据在传输过程中会中断。

通过SPI进行通信的设备处于主从关系中。主机是控制设备(通常是微控制器),而从机(通常是传感器、显示器或存储芯片)从主机获取指令。SPI最简单的配置是单个主机,单从系统,但一个主机可以控制多个从机(下面将详细介绍)。

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBATGluZXN0LTU=,size_20,color_FFFFFF,t_70,g_se,x_16

MOSI(主输出/从输入):主机将数据发送到从机的线路。

MISO(主输入/从输出):从机将数据发送到主机的线路。

SCLK(时钟):时钟信号的线。

SS/CS(从机选择/芯片选择):主机选择线,用于选择要将数据发送到哪个从机。

所需的线

2

最大速率

高达10Mbps

同步或异步

同步

串行或并行

串行

主机的最大个数

1

从机的最大个数

理论上没有限制

在实践中,从机的数量受到系统负载电容的限制,这降低了主机精确切换电压电平的能力。

SPI的工作原理

时钟

时钟信号将主机的数据位输出与从器件的位采样同步。每个时钟周期传输一位数据,因此数据传输的速度由时钟信号的频率决定。SPI通信始终由主站启动,因为主机配置并生成时钟信号。

设备共享时钟信号的任何通信协议都称为同步。SPI 是一种同步通信协议。还有一些不使用时钟信号的异步方法。例如,在UART通信中,双方都设置为预配置的波特率,该波特率决定了数据传输的速度和时间。

SPI中的时钟信号可以使用时钟极性和时钟相位属性进行修改。这两个属性协同工作,以定义何时输出位以及何时对位进行采样。时钟极性可由主器件设置,以允许在时钟周期的上升沿或下降沿输出和采样位。时钟相位可以设置为在时钟周期的第一边沿或第二边沿上进行输出和采样,无论它是上升还是下降。

在SPI中,主机可以选择时钟极性和时钟相位。CPOL 位设置空闲状态期间时钟信号的极性。空闲状态定义为 CS 为高并在传输开始时转换为低电平的周期,以及当 CS 处于低电平并在传输结束时转换为高电平的周期。CPHA 位选择时钟相位。根据CPHA位,上升或下降时钟沿用于采样和/或移位数据。主机必须根据从机的要求选择时钟极性和时钟相位。根据 CPOL 和 CPHA 位选择,提供四种 SPI 模式。表中显示了四种SPI模式。

SPI 模式

CPOL

CPHA

空闲状态下的时钟极性

用于采样和/或移位数据的时钟相位

0

0

0

逻辑低电平

数据在上升沿采样,在下降沿切换

1

0

1

逻辑低电平

数据在下降沿采样,在上升沿切换

2

1

0

逻辑高电平

数据在下降沿采样,在上升沿切换

3

1

1

逻辑高电平

数据在上升沿采样,在下降沿切换

下图展示了 SPI 的四种模式下的通信示例,在这些示例中,数据显示在 MOSI 和 MISO 线路上。传输的开始和结束由绿色虚线表示,采样沿以橙色表示,切换沿以蓝色表示。

模式0

在此模式下,时钟极性为 0,表示时钟信号的空闲状态为低电平。此模式下的时钟相位为 0,表示数据在上升沿(由橙色虚线显示)上采样,数据在时钟信号的下降沿(由蓝色虚线显示)上切换。

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBATGluZXN0LTU=,size_20,color_FFFFFF,t_70,g_se,x_16

模式1

在此模式下,时钟极性为 0,表示时钟信号的空闲状态为低电平。此模式下的时钟相位为 1,表示数据在下降沿(由橙色虚线显示)上采样,数据在时钟信号的上升沿(由蓝色虚线显示)上切换。

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBATGluZXN0LTU=,size_20,color_FFFFFF,t_70,g_se,x_16

模式2

在此模式下,时钟极性为 1,表示时钟信号的空闲状态为高电平。此模式下的时钟相位为 0,表示数据在下降沿上采样,数据在时钟信号的上升沿上切换。

模式3

在此模式下,时钟极性为 1,表示时钟信号的空闲状态为高电平。此模式下的时钟相位为 1,表示数据在上升沿上采样,数据在时钟信号的下降沿上切换。

从属选择

主机可以通过将从机的CS/SS线路设置为低电平来选择要与之通信的从机。在空闲、非发射状态下,从机选择线保持在高电平。主机上可能有多个 CS/SS 引脚,允许多个从机并联接线。如果只有一个 CS/SS 引脚,则可以通过菊花链将多个从器件连接到主机。

多个从机

常规方法

SPI可以设置为使用单个主机和单个从机工作,也可以设置由单个主机控制的多个从机。有两种方法可以将多个从机连接到主机。如果主机有多个从机选择引脚,则从机可以并联,如下所示:

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBATGluZXN0LTU=,size_20,color_FFFFFF,t_70,g_se,x_16

在常规模式下,需要从主机为每个从机选择单个芯片。一旦芯片选择信号被主机使能(拉低),MOSI/MISO线路上的时钟和数据就可用于所选子节点。如果启用了多个芯片选择信号,则MISO线路上的数据将损坏,因为主节点无法识别哪个子节点正在传输数据。

从图中可以看出,随着子节点数量的增加,芯片从主节点中选择的线的数量也在增加。这可以迅速增加主机所需的输入和输出数量,并限制可以使用的从机数量。有不同的技术可用于增加常规模式下的从机数量;例如,使用多路复用器生成芯片选择信号。

菊花链方法

如果只有一个从机选择引脚可用,则从器件可以按菊花链形式排列,如下所示:

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBATGluZXN0LTU=,size_20,color_FFFFFF,t_70,g_se,x_16

在菊花链模式下,从机的配置使得所有从机的芯片选择信号绑定在一起,数据从一个从机传播到下一个从机。在此配置中,所有子节点从机接收相同的SPI时钟。来自主机的数据直接连接到第一个从机,该从机向下一个从机提供数据,依此类推。

在这种方法中,当数据从一个从机传播到下一个从机时,传输数据所需的时钟周期数与菊花链中的从机位置成正比。例如,在图中,在8位系统中,需要24个时钟脉冲才能在3上使用数据。而第三个从机在常规SPI模式下只有8个时钟脉冲。图中展示了时钟周期和通过菊花链传播的数据。并非所有SPI器件都支持菊花链模式。

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBATGluZXN0LTU=,size_20,color_FFFFFF,t_70,g_se,x_16

MOSI 和 MISO

主机通过MOSI线以串行方式逐位向从机发送数据。从机接收从MOSI引脚的主器件发送的数据。从主机发送到从机的数据通常以最高有效位优先发送。

从机还可以通过MISO线路串行将数据发送回主机。从从机发送回主机的数据通常首先以最低有效位发送。

SPI 数据传输的步骤

1、主机输出时钟信号:

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBATGluZXN0LTU=,size_20,color_FFFFFF,t_70,g_se,x_16

2、主机将 SS/CS 引脚切换到低电平状态,来激活从机:

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBATGluZXN0LTU=,size_20,color_FFFFFF,t_70,g_se,x_16

3、主机沿 MOSI 线路一次一位地将数据发送到从站。从机读取接收到的位:高位先读到

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBATGluZXN0LTU=,size_20,color_FFFFFF,t_70,g_se,x_16

4. 如果需要响应,从机沿MISO线一次一位地将数据返回给主机。主机在接收到位时读取:低位先读到

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBATGluZXN0LTU=,size_20,color_FFFFFF,t_70,g_se,x_16

SPI 的优缺点

使用SPI有优点和缺点,在不同的通信协议之间进行选择,应根据项目的要求知道何时使用SPI:

优点

  • 没有启动和停止位,因此数据可以连续流式传输而不会中断
  • 没有像I2C那样复杂的从地址系统
  • 数据传输速率高于 I2C(几乎是 I2C 的两倍)
  • 独立的MISO和MOSI线,因此可以同时发送和接收数据

缺点

  • 使用四根电线(I2C 和 UART 使用两根电线)
  • 没有校验是否成功接收数据(I2C 具有此值)
  • 没有像UART中的奇偶校验位那样的错误检查形式
  • 仅允许单个主机

 文章参考

https://www.circuitbasics.com/basics-of-the-spi-communication-protocol/

Mixed-signal and digital signal processing ICs | Analog Devices


http://chatgpt.dhexx.cn/article/51IXuBUA.shtml

相关文章

SPI通信协议详解,一篇就够!

一、什么是SPI? SPI 的英文全称为 Serial Peripheral Interface,顾名思义为串行外设接口。SPI 是一种同步串行通信接口规范,主要应用于嵌入式系统中的短距离通信。该接口由摩托罗拉在20世纪80年代中期开发,后发展成了行业规范。 …

2021年游戏项目的十大编程语言:C++、Java、C#均上榜

在这个技术驱动的世界里,游戏行业是全球增长最快的行业之一。在每一款华丽精美的电子游戏背后,都有一种编程语言,为用户提供优质的体验。游戏开发者利用顶级的编程语言来构建游戏。不同的游戏项目使用了不同的编程语言,这取决于游…

2021 编程语言排行榜

点击“终码一生”,关注,置顶公众号 每日技术干货,第一时间送达! IEEE Spectrum 发布了 2021 年编程语言排行榜,官方的标题是:Python 在新技术领域依然是主导地位。 Python 近几年随着大数据、数据挖掘、人…

2020 年最牛逼的 10 门编程语言

先看再点赞,给自己一点思考的时间,微信搜索【沉默王二】关注这个有颜值却假装靠才华苟且的程序员。 本文 GitHub github.com/itwanger 已收录,里面还有我精心为你准备的一线大厂面试题。 对于很多初学编程的人来说,尤其是马上要入…

世界上到底有多少种编程语言?

最近,网站上看到一个很有意思的问题:世界上到底有多少种编程语言? 查遍网络之后,仍然没有找到准确答案,只知道几千的数量是有的,但是我们常用的也就几十来个,其中最常见的便是Java、Python、C、…

世界上最难的5种编程语言

世界上最难的5种编程语言 每个程序员都熟悉许多编程语言。许多编程语言都是高级的,它们的语法是人类可读的。然而,也有一些低级语言,对于一个人来说,读起来很困难,但是可以理解。然而,您是否遇到过一种既不…

2018年最流行的十大编程语言,有你用的吗?

对于编程界的初学者来说,最大的困难是决定从何处入手,或者应掌握哪种语言才能在职场上平步青云。有时,专业程序员也面临学习一门新语言似乎更卓有成效的情形。 无论是什么原因,下面列出了世界上最流行的编程语言,以便了…

5月编程排行榜出炉,最佳编程语言是谁?

技术的发展日新月异,作为开发者,应该时刻关注这些变化,不断学习才能跟上时代步伐。 编程语言层出不穷,关于“ 最佳编程语言 ”的争论也从未停止,网友们各抒己见...... 网友A: 人生苦短,我选Pyt…

十大热门编程语言的介绍

小编给大家分享一篇关于现阶段十大热门编程语言的文章:经过流行的搜索引擎,如谷歌,必应,雅虎,维基百科,亚马逊,YouTube和百度,用于计算评级;得出十大热门编程语言排行榜的…

GitHub2022年十大热门编程语言榜单

全球知名代码托管平台 GitHub发布的2022年GitHub Octoverse年度报告公布了全球最流行的十大编程语言,其中JavaScript蝉联第一,Python位列次席。 编程是技术革新的核心,对于所有的编程开发人员来说,对世界范围内编程语言发展和趋势…

2021年十大热门编程语言

几乎可以肯定,每个人都知道,在当今数字先进的世界中,技术是如何快速变化的。经常通过定期更新和改进来观察替代技术之间的相互超越已成为一种正常现象。在这一切之中,一个领域因技术世界的如此多变的性质而受到很大的影响&#xf…

十大编程语言,每一个都不容易学,但每一个又很有用,黑客必备

一定要注意,您选择的编程将在很大程度上取决于您要定位的系统类型和计划使用的漏洞。因此,根据您的策略,任何语言都会很棒。 1. C语言 它被称为“所有编程语言之母”,也是Hacking社区中的关键语言。今天,我们拥有的大…

抖音照片图集怎么制作,如何将图片做成视频上传抖音?

抖音最近被很多人当做茶余饭后不可或缺的娱乐项目,丰富了很多人的业余生活,也成就了很多抖音人,经常在抖音上会看到很多不是直接拍摄的视频,而是通过图片图集的方式展示出来的视频,图片中还可以配上相应的文字&#xf…

手把手教你抖音怎么用图片做视频!

抖音是一款短视频APP,在抖音里人们可以上传视频,录制视频,看到别人的视频,抖音目前很受年轻人的欢迎,使用抖音的人高达几个亿;我们在抖音上看到的照片视频,其实大部分是在电脑制作后上传的一般比…

如何用照片做抖音视频?这样剪辑电子相册

如果只是在抖音中拍摄视频的话,相信这个操作大家都会吧?毕竟现如今的抖音可以说是全民在用了,关于如何拍摄视频发布到抖音,这个操作也几乎是人人都会的。但是拍摄视频你会,你又知道应该如何用照片来制作一个抖音视频吗…

[短视频运营] 抖音最新风口,漫改图文号,变现模式非常简单

这几天抖音出现了一个新的风口,千万不要错过,抖音召开了抖音创作者大会,在大会上有几件事的披露引起了广泛关注,对于每一个在抖音上的创作者来说都是重大的事件。 ​第一、抖音在大会上确定未来一年将会把更多的重点放在图文和中…

抖音开放平台-视频切片-视频分片上传-不合法的参数ID-不合法的对象ID

问题描述 1、最近遇到个问题,做业务需要管理几个抖音账号,用抖音开放平台做分片上传视频,多次返回不合法参数id,提交工单之后给的回复没有任何参考价值。 2、例如视频文件按15M进行切片,调用分片上传初始化接口&#…

抖音上css照片动态旋转怎么做,抖音里单张图片平移视频怎么制作?影音制作实现一张图片从左到右滑动视频效果...

今天的影音制作,是实现视频画面中有一张图片从左往右慢慢滑动的视频效果。一张横屏图片要制作成竖视频的时候,要么就会出现图片显示不全的情况,要么显示全了就会出现上下有黑边的情况,基本很难解决这个问题~但是小编今天通过这款常…

仿抖音上下滑动分页视频

如果要是不想看这么代码的话,我整理了一下项目,下载到本地直接进行运行也可以; 代码下载地址 目录介绍 01.先来看一下需求02.有几种实现方式 2.1 使用ViewPager2.2 使用RecyclerView03.用ViewPager实现 3.1 自定义ViewPager3.2 ViewPager和…

java抖音字符视频_抖音流行的字符视频如何实现

前几天,有个朋友给我分享了一个抖音短视频链接,是以代古拉k跳舞视频为原型的字符视频,朋友问我:“这个你知道怎么做吗?”。 我们都知道视频是由一帧一帧的静态图片组合而成的,所以当我们把原视频的每一帧变…