【总线】SPI 通信协议
目录
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)中的并行传输:
在串行通信中,位通过单根线逐个发送。下图显示了字母“C”在二进制(01000011)中的串行传输:
SPI通信介绍
SPI的一个独特优势是数据可以不间断地传输。可以在连续流中发送或接收任意数量的位。使用I2C和UART,数据以数据包形式发送,限制为特定数量的位。开始和停止条件定义了每个数据包的开始和结束,因此数据在传输过程中会中断。
通过SPI进行通信的设备处于主从关系中。主机是控制设备(通常是微控制器),而从机(通常是传感器、显示器或存储芯片)从主机获取指令。SPI最简单的配置是单个主机,单从系统,但一个主机可以控制多个从机(下面将详细介绍)。
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,表示数据在上升沿(由橙色虚线显示)上采样,数据在时钟信号的下降沿(由蓝色虚线显示)上输出。
模式1
在此模式下,时钟极性为 0,表示时钟信号的空闲状态为低电平。此模式下的时钟相位为 1,表示数据在下降沿(由橙色虚线显示)上采样,数据在时钟信号的上升沿(由蓝色虚线显示)上输出。
模式2
在此模式下,时钟极性为 0,表示时钟信号的空闲状态为高电平。此模式下的时钟相位为 1,表示数据在上升沿(由橙色虚线显示)上采样,数据在时钟信号的下降沿(由蓝色虚线显示)上输出。
模式3
在此模式下,时钟极性为 0,表示时钟信号的空闲状态为高电平。此模式下的时钟相位为 1,表示数据在下降沿(由橙色虚线显示)上采样,数据在时钟信号的上升沿(由蓝色虚线显示)上移动。
从属选择
主机可以通过将从机的CS/SS线路设置为低电平来选择要与之通信的从机。在空闲、非发射状态下,从机选择线保持在高电平。主机上可能有多个 CS/SS 引脚,允许多个从机并联接线。如果只有一个 CS/SS 引脚,则可以通过菊花链将多个从器件连接到主机。
多个从机
常规方法
SPI可以设置为使用单个主机和单个从机工作,也可以设置由单个主机控制的多个从机。有两种方法可以将多个从机连接到主机。如果主机有多个从机选择引脚,则从机可以并联,如下所示:
在常规模式下,需要从主机为每个从机选择单个芯片。一旦芯片选择信号被主机使能(拉低),MOSI/MISO线路上的时钟和数据就可用于所选子节点。如果启用了多个芯片选择信号,则MISO线路上的数据将损坏,因为主节点无法识别哪个子节点正在传输数据。
从图中可以看出,随着子节点数量的增加,芯片从主节点中选择的线的数量也在增加。这可以迅速增加主机所需的输入和输出数量,并限制可以使用的从机数量。有不同的技术可用于增加常规模式下的从机数量;例如,使用多路复用器生成芯片选择信号。
菊花链方法
如果只有一个从机选择引脚可用,则从器件可以按菊花链形式排列,如下所示:
在菊花链模式下,从机的配置使得所有从机的芯片选择信号绑定在一起,数据从一个从机传播到下一个从机。在此配置中,所有子节点从机接收相同的SPI时钟。来自主机的数据直接连接到第一个从机,该从机向下一个从机提供数据,依此类推。
在这种方法中,当数据从一个从机传播到下一个从机时,传输数据所需的时钟周期数与菊花链中的从机位置成正比。例如,在图中,在8位系统中,需要24个时钟脉冲才能在3上使用数据。而第三个从机在常规SPI模式下只有8个时钟脉冲。图中展示了时钟周期和通过菊花链传播的数据。并非所有SPI器件都支持菊花链模式。
MOSI 和 MISO
主机通过MOSI线以串行方式逐位向从机发送数据。从机接收从MOSI引脚的主器件发送的数据。从主机发送到从机的数据通常以最高有效位优先发送。
从机还可以通过MISO线路串行将数据发送回主机。从从机发送回主机的数据通常首先以最低有效位发送。
SPI 数据传输的步骤
1、主机输出时钟信号:
2、主机将 SS/CS 引脚切换到低电平状态,来激活从机:
3、主机沿 MOSI 线路一次一位地将数据发送到从站。从机读取接收到的位:高位先读到
4. 如果需要响应,从机沿MISO线一次一位地将数据返回给主机。主机在接收到位时读取:低位先读到
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
【总线】SPI 通信协议相关推荐
- MPU6050开发 -- 进阶之I2C/SPI通信协议
如需转载请注明出处:https://blog.csdn.net/qq_29350001/article/details/78611309 上一篇基本概念讲了一通,大体上对MPU6050有了一个了解.对 ...
- 【嵌入式】STM32基于SPI通信协议OLED屏显示
STM32基于SPI通信协议OLED屏显示 一.SPI协议和OLED介绍 1.SPI协议介绍 物理层 协议层 2.OLED显示屏介绍 二.显示个人学号姓名实验 1.题目要求 2.代码部分 1.完整代码 ...
- Verilog实现的SPI通信协议(主机模式)
一.前言 最近在使用FPGA调试一个MCP2515CAN芯片的时候,需要用到SPI通信协议,也在网上看了许多不同人写的博客,也学习了很多种不同的写法,从结果来看,网上给出的大部分例子都能实现SPI通信 ...
- 嵌入式开发基础—SPI通信协议解析
嵌入式开发基础-SPI通信协议解析 1 通信方式(主从通信) 1.1 什么是主从通信 1.2 主从通信如何实现 1.2.1 相关控制引脚介绍 1.2.2 如何通过控制引脚实现主从通信 2 通信数据交换 ...
- 收藏 | 电子通信协议之SPI通信协议篇
当你将微控制器连接到传感器,显示器或其他模块时,你是否考虑过这两种设备如何相互通信?他们到底在说什么?他们如何理解对方? 电子设备之间的通信就像人类之间的通信.双方都需要说同样的语言.在电子产品中,这 ...
- SPI通信协议详解(二)
1.SPI简介 SPI,是英语Serial Peripheral interface的缩写,顾名思义就是串行外围设备接口.是Motorola首先在其MC68HCXX系列处理器上定义的.SPI接口主要应 ...
- SPI通信协议:单片机spi通信接口什么意思,spi接口干什么用的?
讲真,以前做开发的时候最怕就是调spi和iic. 因为公司没有逻辑分析仪,调起来全凭经验,一出问题找都找不到,只能仔细看代码盲调,看是不是哪个时序有问题. 说到这里,可能刚初学的小伙伴会问:单片机sp ...
- stm32中spi可以随便接吗_stm32之SPI通信协议实例详解
之前一直对SPI通信一知半解,所以想抽空把它搞得明白一些.考虑到之前是结合Flash芯片来学的,十分不直观,而且主要把时间和精力都花在Flash芯片的datasheet和驱动上了,SPI通信也没学好. ...
- STM-32:SPI通信协议/W25Q64简介—软件SPI读写W25Q64
目录 一.SPI简介 1.1电路模式 1.2通信原理 1.3SPI时序基本单元 1.3.1起始和终止 1.3.2交换字节 二.W25Q64 2.1W25Q64简介 2.2W25Q64硬件电路 2.3W ...
最新文章
- Google colab: 修改系统时间 change system time
- 《排序算法系列一、简单选择排序》
- 现代软件工程 第一章 概论 第9题——邓琨
- 深刻理解Python中的元类(metaclass)以及元类实现单例模式
- C++ GUI Qt4编程(12)-6.1FindFileDialog
- SAP UI5 sap-ui-core.js的加载逻辑
- leetcode 87. 扰乱字符串(dp)
- python用字典统计出现次数_python 字典(dict)列表(list),统计重复出现字典的数量...
- 计算机三级之嵌入式系统学习笔记3
- centos7 安装VNC Server
- 为什么mysql启动不了了_Mysql为什么启动不了
- 【CNMP系列】CentOS7.0下安装Nginx服务
- Linux 管道(pipe)原理及使用
- json-lib javabean转换为首字母大写的json串
- SpringBoot+Thymeleaf+ECharts实现大数据可视化(基础篇)
- Linux 基础——ls 命令
- 3个免费的设计师图库,值得收藏
- js页面打印去掉页眉页脚
- 关于美元中 单位 换算 English
- 数字统计-c语言-求特殊自然数
热门文章
- [道兰][NHK纪录片]世界游戏革命 几点观后
- 【Ubuntu】Ubuntu编译安装Nginx
- python实现静态变量
- 【uniapp】真机调试
- 彻彻底底删除卸载docker
- 进程同步与互斥——哲学家就餐问题源码实现(dining philosopher’s problem)
- module ***: Get “https://proxy.golang.org/***“: dial tcp 172.217.160.113:443: connectex: A connectio
- java中在方法体内抛出异常_Java异常处理中___用于方法体内,抛出一个异常对象。...
- Docker中Mysql容器启动
- Webpack5优化之提高代码运行性能(Preload、Network Cache、Core-js、PWA)