SPI通信方式总结

2023-05-16


        SPI(Serial Peripheral interface)是一种同步串行传输规范,也是单片机外设芯片串行外设扩展接口,该接口是一种高速,全双工,同步的通信总线,并且在芯片的管脚上占用4根线。SPI接口主要应用在EEPROM,Flash,实时时钟,AD转换器,还有数字信号处理器和数字信号解码器之间
        SPI由一个主设备和一个或多个从设备组成,主设备启动一个与从设备的同步通讯,从而完成数据的交换。SPI接口由MOSI(串行数据输出),MISO(串行数据输入),SCLK(串行移位时钟),/SS(从设备使能信号),四种信号构成。
        MOSI(串行数据输出),MISO(串行数据输入),SCL(串行移位时钟)都是公用的,只有SS(从设备使能信号)不是公用的,每增加一个从设备,那么就要增加一个SS使能信号,从而实现寻址的功能,当你的引脚不够用的时候,最好使用IIC(只有两根线)。

引脚功能介绍:

MOSI:主设备数据输出,从设备数据输入;该引脚在从模式下发送数据,在主模式下接收数据。
MISO:主设备数据输入,从设备数据输出;该引脚在主模式下发送数据,在从模式下接收数据。
SCLK:时钟信号,由主设备产生
CS/SS:从设备使能信号,由主设备控制。当有多个从设备的时候,每个从设备都有一个片选接入到主设备机中,让主设备可以单独地与特定从设备通讯,避免数据线上的冲突。当我们的主设备和某个从设备通信时,需要将从设备对应的片选信号拉低或拉高。

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

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

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

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

         下图展示了 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

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

 模式3

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

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

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

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

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

菊花链方法

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

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

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

 

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

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

SPI 数据传输的步骤
1、主机输出时钟信号:watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBATGluZXN0LTU=,size_20,color_FFFFFF,t_70,g_se,x_162、主机将 SS/CS 引脚切换到低电平状态,来激活从机:watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBATGluZXN0LTU=,size_20,color_FFFFFF,t_70,g_se,x_163、主机沿 MOSI 线路一次一位地将数据发送到从站。从机读取接收到的位:高位先读到watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBATGluZXN0LTU=,size_20,color_FFFFFF,t_70,g_se,x_164. 如果需要响应,从机沿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中的奇偶校验位那样的错误检查形式
仅允许单个主机

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

SPI通信方式总结 的相关文章

  • IMX6ULL + SPI LCD(驱动IC ILI9341)显示简单的QT界面

    1 硬件 xff1a 使用正点原子的IMX6ULL Linux开发板 开发板底板原理图版本 xff1a V2 1 核心板原理图版本 xff1a V1 6 LCD xff1a MSP2402 IC ILI9341 2 查找可用引脚 开发板上引
  • STM32的SPI

    1 SPI硬件层共有4个引脚SCK MISO MOSI NSS 不需要接上拉及下拉电阻等 2 SPI跟I2C一样是一种通讯总线 所以可以挂载多个从机 通过NSS片选引脚控制从机 3 SPI主模式时钟与挂载总线相关 STM32时钟为fpclk
  • SPI通信方式总结

    SPI xff08 Serial Peripheral interface xff09 是一种同步串行传输规范 xff0c 也是单片机外设芯片串行外设扩展接口 xff0c 该接口是一种高速 xff0c 全双工 xff0c 同步的通信总线 x
  • 使用DMA+SPI驱动Aliyun Things 上的ST7789H2 LCD屏幕

    目录 前言硬件CUBEMX时钟树GPIOSPI 代码部分LCD驱动中断服务函数测试代码现象 前言 1 xff1a 驱动程序参考自https blog csdn net BearPi article details 104311705 2 x
  • 一文搞懂——软件模拟SPI

    关于stm32通信协议 xff1a 软件模拟SPI 软件模拟I2C的总结 xff08 fishing 8 xff09 To be a fisher的博客 CSDN博客 stm32 软件spi 发现一篇写的软件模拟SPI的比较容易理解的博客
  • Linux SPI 驱动示例

    一 Linux 下 SPI 驱动框架 SPI 驱动框架分为主机控制器驱动和设备驱动 xff0c 主机控制器也就是 SOC 的 SPI 控制器接口 1 1 SPI 主机驱动 SPI 主机驱动就是 SOC 的 SPI 控制器驱动 xff0c L
  • stm32 操作W25Q256 W25Q16 spi flash

    硬件连接 本函数库来自正点原子官方 xff0c 本人稍作修改和添加注释 W25Q16 2M Byte W25Q256 32M Byte spi 配置 2022 7 27 经过测试 华邦的 W25Q256JV 32M 字节 容量的spi fl
  • SPI 通讯协议

    Cuitbasics 汽车ECU设计 2 2 当您将微控制器连接到传感器 xff0c 显示器或其他模块时 xff0c 您是否考虑过这两种设备是如何相互通信的 xff1f 他们到底在说什么 xff1f 事实上电子设备之间的通信就像人类之间的交
  • pixhawk px4 spi设备驱动

    此篇blog是以nuttx官网介绍为出发点 xff0c 先分析如何初始化的 xff0c 再分析如何读取传感器数据的 xff0c 最后对比了字符型设备操作和spi驱动的实现方式的差别 如有错误还请指正 6 字符型设备 所有的结构体和API都在
  • ((硬件spi+dma)+模拟spi)驱动LCD5110

    span class hljs preprocessor ifndef spi dma h span span class hljs preprocessor define spi dma h span span class hljs pr
  • spi,iic,uart,pcie区别

    一 spi SPI 是英语Serial Peripheral interface的缩写 xff0c 顾名思义就是串行外围设备接口 xff0c 是同步传输协议 xff0c 特征是 xff1a 设备有主机 xff08 master xff09
  • WS2812灯珠(二)-- STM32 SPI+DMA方式驱动

    通过硬件SPI的可以很巧妙的模拟出WS2812的通信时序 xff0c 用spi的8位数据模拟ws281x的一位数据 要将系统时钟设置为56M xff0c SPI分频数设置为8 xff0c 则SPI的通信频率为7M xff0c 1s 7M 1
  • 关于IKEv2中安全策略索引SPI的生成

    首先引入一个PF key的概念 PF KEY Key Management API 提供IKE模块和IPSec核心之间的接口 在RFC 2367中 有一个SADB GETSPI消息 这个消息就是实现允许一个进程获取SPI值 该值标识所给的s
  • SPI技术-JDK实现

    SPI是什么 SPI全称Service Provider Interface 是Java提供的一套用来被第三方实现或者扩展的API 它可以用来启用框架扩展和替换组件 Java SPI 实际上是 基于接口的编程 策略模式 配置文件 组合实现的
  • FPGA驱动0.96oled显示屏 (4线 SPI) verilog语言

    之前也陆陆续续看了很多博客 也都能在自己的屏幕上显示出来 但是问题就是不知道怎么修改代码显示自己希望显示的东西 而且由于没注释原因看不太懂 最终的实现效果最终实现效果视频 b站视频链接1 评论区有人给了源码的百度网盘链接 csdn博客链接1
  • SpringBoot系列--自定义Starter

    提到Spring Boot时 很多人想到的是它的自动化装配特性 当我们项目需要Redis MongoDB时 只需要引入相应的 spring boot starter data redis spring boot starter data m
  • 谁在驱动程序代码中调用“probe”函数?

    我试图理解thisomap2 panda 板的 mcspi 驱动程序代码 我不明白谁打电话probe函数以及调用链是什么this驱动代码 设备连接时如何通知驱动程序 探针函数由spi omap2 mcspi c保存在static struc
  • Python - 如何使用 ioctl 或 spidev 从设备读取输入?

    我有一个提供它的供应商提供了一些 C 代码来监听按钮按下 该代码使用ioctl 该设备具有 SSD1289 控制器 按钮不需要额外的引脚 可以通过 SPI 读取其状态 这就是我想要的 读取按下了哪个按钮 我试图在 Python 中为我自己的
  • 树莓派 pico rfid rc522 (Micropython)

    我想使用 RPi Pico 从 mfrc522 Iduino RFID rc522 读卡器读取数据 但我不知道如何操作 我试图使用为此目的制作的 mfrc522 py MicroPython 库 阅读器正在通过 SPI 与 Pi 通信 我将
  • 如何用 C 语言从串行(SPI)连接读取数据?

    我正在尝试编写一个程序 该程序将安装在 Linux MCU Raspberry Pi 上 该程序将读取从另一个 MCU 我将自己构建的自制程序 发送到它的串行数据 我研究了如何做到这一点 并认为我有 大局 但仍然缺少一些东西 其一 我需要启

随机推荐

  • 向日葵连接已断开的解决办法

    方法一 打开ubuntu系统的终端 xff0c 依次输入如下命令 xff1a sudo apt get update sudo apt get upgrade sudo apt install lightdm 重启电脑 方法二 xff08
  • UDP传输图片(分包)

    前提 xff1a 需要了解QUdp的简单通信 xff0c 比如收发个字符串 QP ixmap图片类 xff0c 以此类来加载图片 Q B uffer和Q B yteArray来记录数据 memcpy函数的用法 分包概念 xff1a 举个例子
  • 结构型设计模式(七种)

    3 结构型设计模式 结构型模式描述如何将类或对象按某种布局组成更大的结构 它分为类结构型模式和对象结构型模式 xff0c 前者采用继承机制来组织接口和类 xff0c 后者采用组合或聚合组合对象 由于组合关系或聚合关系比较继承关系耦合度低 x
  • IDEA+Log4j2 设置控制台打印彩色日志

    在Log4j 2 10以前的版本 xff0c pattern中配置 highlight属性是可以正常打印彩色日志的 例如 xff1a pattern 34 d yyyy MM dd HH mm ss SSS highlight 5level
  • weex打包安卓艰苦之路

    weex打包安卓 一 配置安卓环境 下载安卓SDK配置ANDROID HOME配置 ANDROID HOME tools android h 检查是否配置成功 二 weex的安装使用 一 weex简介以及开发前提 1 简介 官网的解释为We
  • docker命令

    Docker命令详解 语法 docker run OPTIONS IMAGE COMMAND ARG Usage Run a command in a new container 中文意思为 xff1a 通过run命令创建一个新的容器 xf
  • PX4 mixer load

    mixer load dev pwm output0 fs microsd mixer ttt mix 启动一个自定义的mixer 系统默认从 etc mixers加载mixer 如果在 fs microsd etc mixers有相同名称
  • Bean三级缓存

    一 核心步骤 提前引用进行动态代理 后置处理器进行动态代理 二 具体步骤 1 获取bean AbstractBeanFactory doGetBean 2 第一次去单例池查询bean 最终调用 xff1a DefaultSingletonB
  • MinIO Client客户端使用

    安装 文档地址 xff1a https docs min io 基本上MinIO服务器和客户端支持在很多系统上安装 xff0c 比如Windows macOS等 xff0c 这里主要说Linux系统 minio安装 span class t
  • Security+Thymeleaf整合

    文章目录 1 版本介绍2 演示demo3 常见使用表达式Using the expression utility objectsUsing the attributes 官方地址 1 版本介绍 2 演示demo html界面 span cl
  • java正则的使用

    java util regex是一个用正则表达式所订制的模式来对字符串进行匹配工作的类库包 它包括两个类 xff1a Pattern和Matcher Pattern 一个Pattern是一个正则表达式经编译后的表现模式 Matcher 一个
  • cas服务端动态servers

    一 什么是servers cas的分为服务端和客户端 xff0c 如果客户端要使用cas需要把自己的域名或ip注册到cas服务端才可以使用 默认的servers为静态的 src main resources services HTTPSan
  • cas 配置相关

    默认配置 span class token comment span span class token comment CAS Cloud Bus Configuration span span class token comment sp
  • Elasticsearch分词器

    内置分词器 中文分词器 这篇博客主要讲 xff1a 分词器概念 ES内置分词器 ES中文分词器 一 分词器概念 1 Analysis 和 Analyzer Analysis xff1a 文本分析是把全文本转换一系列单词 term token
  • java中的引用

    背景 最近在研究ThreadLocal中发现最终存储的ThreadLocalMap中的key为弱引用 xff0c 因此来分析下使用弱引用的原因 实验 引用链为 list 61 gt gt person1 因此在GC的时候 list还强引用三
  • charles

    Charles 的简介如何安装 Charles将 Charles 设置成系统代理Charles 主界面介绍过滤网络请求截取 iPhone 上的网络封包截取 Https 通讯信息模拟慢速网络修改网络请求内容给服务器做压力测试修改服务器返回内容
  • CAN通信

    CAN通信控制器通过两根线上的电位差来判断总线电平 xff0c 是ISO国际标准化的串行通信协议 总线电平分为显性电平和隐形电平 xff0c 二者必居其一 发送方通过总线上电平的变化将信息发送给接收方 CAN通讯是半双工的 xff0c 收发
  • maddpg 复现过程中遇到的问题

    最近在复现论文Multi Agent Actor Critic for Mixed Cooperative Competitive Environments https github com openai multiagent partic
  • 【解决】VSCode在windows下不能打开标准头文件

    鼠标放到标准头文件上 xff0c VSCode提示一下错误 xff1a include errors detected Please update your includePath IntelliSense features for thi
  • SPI通信方式总结

    SPI xff08 Serial Peripheral interface xff09 是一种同步串行传输规范 xff0c 也是单片机外设芯片串行外设扩展接口 xff0c 该接口是一种高速 xff0c 全双工 xff0c 同步的通信总线 x