当前位置: 首页 > news >正文

单片机通信协议(1):SPI简介

关于SPI

SPI(串行外设接口)是板载设备间通信接口之一。它是由摩托罗拉公司(飞思卡尔半导体)推出的。由于其简单性和通用性,它被纳入各种外围设备中,并与飞利浦I2C总线并列。 SPI的三线或四线信号数量比IIC的两线多,但传输速率可以升至20 Mbps或更高,具体取决于设备的能力(比IIC快5-50倍)。因此,它主要用于需要尽可能高数据传输速率的应用,ADC、DAC或通信IC。

SPI的结构

在这里插入图片描述

SPI的基本结构如上图所示。主设备和从设备通过SCLK(串行时钟)、MISO(主输入从输出)和MOSI(主输出从输入)三个信号线连接,两个8位移位寄存器的内容为与主设备驱动的移位时钟交换。另外,除上述三个之外的SS(从机选择)信号用于同步数据包或字节边界的开始,并用于同时实现多从机配置。大多数从机设备为 SPI 接口分配不同的引脚名称,例如 DI、DO 和 CS。对于单向传输器件,例如DAC和单通道 ADC,可以省略任一数据线。数据位首先以 MSB 方式移位。

当将一些从属设备连接到 SPI 时,从属设备并行连接,主设备的CS信号连接到每个从属设备。由CS信号选择的从属设备的数据输出被启用,而未选择的设备与MISO 断开连接。

SPI的传输时序

对于SPI,数据移位和数据锁存分别在相反的时钟沿进行,移位和锁存操作分开可以避免两个操作之间的关键时序,从而减轻芯片设计和电路板设计的时序考虑。但另一方面,由于时钟极性和时钟相位的组合,存在四种操作模式,主设备必须将其SPI接口配置为从设备所需的SPI模式。

模式0

时钟极性(CPOL)为0,时钟相位(CPHA)为0,SCK在空闲状态时为低电平,数据的采样和传输分别发生在SCK的上升沿和下降沿。即正脉冲,锁定,然后移位,如下图:

在这里插入图片描述

模式1

时钟极性(CPOL)为0,时钟相位(CPHA)为1,SCK在空闲状态仍保持低电平,但是数据的采样和传输分别发生在SCK的下降沿和上升沿。即:正脉冲,先移动,然后锁定,如下图:

在这里插入图片描述

模式2

时钟极性(CPOL)为1,时钟相位(CPHA)为0,SCK信号在空闲状态时为高电平,数据在SCK的下降沿被采样,并在上升沿传输。即:负脉冲,锁定,然后移动。如下图:
在这里插入图片描述

模式3

时钟极性(CPOL)为1,时钟相位(CPHA)为1,SCK在空闲状态为高电平,与模式2相反,数据在SCK的上升沿被采样,在下降沿进行传输。即:负脉冲。移位,然后锁存。如下图:
在这里插入图片描述

总结

这四种模式的主要区别在于如何在时钟信号的不同边缘采样和改变数据。CPOL参数规定了SCK时钟信号在空闲状态时的电平,而CPHA参数则规定了数据是在SCK时钟的上升沿还是下降沿被采样。

http://www.lryc.cn/news/355429.html

相关文章:

  • 免税商品优选购物商城,基于 SpringBoot+Vue+MySQL 开发的前后端分离的免税商品优选购物商城设计实现
  • 京准电子、NTP电子时钟系统(网络时钟系统)概述
  • 【常用的队列总结】
  • 机器学习过拟合和欠拟合!看这一篇文章就够了 建议收藏!(上篇)
  • 关于阳光雨露外派联想的面试感想
  • 深度神经网络介绍与实战
  • 图解 Transformer
  • SpringCloud配置文件bootstrap不生效问题解决
  • Java面试八股之自旋是什么意思
  • 做好随时离开的准备:前一天还在为618加班到凌晨,第二天就被裁了
  • 利用ESP32(Arduino IDE)向匿名上位机发送欧拉角
  • Java开发工具类(JDK、Hutool、Guava)
  • TCP协议的相关特性
  • Lombok,一款超级强大的Java工具库
  • FreeBSD下使用原生虚拟机管理器bhyve
  • CTFshow之文件上传web入门151关-161关解密。包教包会!!!!
  • 【学习记录】服务器转发使用tensorboard
  • 类型转换之显式转换
  • Mybatis多表查询,报错:Column ‘id‘ in field list is ambiguous
  • PyCharm面板ctrl+鼠标滚轮放大缩小代码
  • 【Qt】数据库(一)SQLITE创建、增删查改
  • 【模拟面试问答】力扣165题:比较版本号(逐个比较与双指针法详解及模拟面试问答)
  • 用PhpStudy在本地电脑搭建WordPress网站教程(2024版)
  • 高中数学:平面向量-题型总结及解题思路梳理
  • 【玩转google云】Google Cloud Platform (GCP) (WAF)详解
  • 前端开发工程师——数据可视化
  • 【代码随想录训练营】【Day 35】【贪心-2】| Leetcode 122, 55, 45
  • 【深度学习】ultralytics, yolo seg,实例分割图绘制,核对yolo seg 的txt标记对不对
  • 如何保证员工在精益变革中始终保持积极的态度?
  • 【Java面试】三、Redis篇(下)