spi时序图怎么分析,怎么看懂spi时序图

spi时序图怎么分析,怎么看懂spi时序图我做产品的时候 最怕就是做 IIC 和 SPI 的通信 这两种协议时序哪怕是延时时间有误差 都有可能导致通信不上 出现问题的时候 如果没设备也很难排查问题到底出在哪里 有时候这个产品写好的时序程序 换一个单片机用同一个程序移植过去就不行了 而且很多公司都没有设备可以调试这些协议 大多数时候都是完全靠蒙 今天就拿新手比较头痛的 SPI 来进行时序图的分析和讲解 看不懂你打我 我记得第一次 SPI 通讯的时候 完全是照抄网络上的程序 因为芯片手册的时序图看起来太可怕了 根本看不懂

我做产品的时候,最怕就是做IIC和SPI的通信。

这两种协议时序哪怕是延时时间有误差,都有可能导致通信不上。

出现问题的时候,如果没设备也很难排查问题到底出在哪里。

有时候这个产品写好的时序程序,换一个单片机用同一个程序移植过去就不行了。

而且很多公司都没有设备可以调试这些协议,大多数时候都是完全靠蒙。

今天就拿新手比较头痛的SPI来进行时序图的分析和讲解,看不懂你打我!

我记得第一次SPI通讯的时候,完全是照抄网络上的程序,因为芯片手册的时序图看起来太可怕了,根本看不懂。

后面各种模拟时序写多了,才有了经验,然后用经验去理解数据手册以及网络上的教程

很多新手看各种数据手册和教程被吓到了,其实很多时候不是你的问题,而是数据手册和教程写的太学术化了。

举个例子,就像SPI协议用CPOLCPHA真值表来选择不同的模式。

spi时序图怎么分析,怎么看懂spi时序图

因为在很多SPI接口芯片的数据手册根本没提CPOLCPHA这两个东西,那要怎么知道芯片的通讯模式?

其实是要我们自己根据芯片手册的时序图去分析模式的,而不会直接告诉你是用的哪个模式。

所以在看时序之前,我们先要了解CPOLCPHA到底有啥区别。

CPHA用来控制数据是在第一个跳变沿还是第二个跳变沿采集的

spi时序图怎么分析,怎么看懂spi时序图

通过上图可以看到:

CPHA=0的时候,数据是在第一个跳变沿的时候就会被采集

CPHA=1的时候,数据是在第二个跳变沿的时候才会被采集

那问题来了,到底是上升沿还是下降沿采集?

这个就由CPOL来决定了:

CPOL=0的时候是上升沿采集。

CPOL=1的时候是下降沿采集

spi时序图怎么分析,怎么看懂spi时序图

除此以外,CPOL还决定了我们时钟线SCLK空闲时的状态。

CPOL=0的时候表示SCLK在空闲时为低电平。

CPOL=1的时候表示SCLK在空闲时为高电平

Ok,明白了这个,我们再分析4种模式的时序图

1.模式0(CPOL=0 CPOL=0)

CPOL = 0:时钟线空闲时是低电平,第1个跳变沿是上升沿,第2个跳变沿是下降沿

CPHA = 0:数据在第1个跳变沿(上升沿)采样

时序图如下:

spi时序图怎么分析,怎么看懂spi时序图

2.模式1(CPOL=0 CPOL=1)

CPOL = 0:空闲时是低电平,第1个跳变沿是上升沿,第2个跳变沿是下降沿

CPHA = 1:数据在第2个跳变沿(下降沿)采样

时序图如下:

spi时序图怎么分析,怎么看懂spi时序图

3.模式2(CPOL=1 CPOL=0)

CPOL = 1:空闲时是高电平,第1个跳变沿是下降沿,第2个跳变沿是上升沿

CPHA = 0:数据在第1个跳变沿(下降沿)采样

时序图如下:

spi时序图怎么分析,怎么看懂spi时序图

4.模式3(CPOL=1 CPOL=1)

CPOL = 1:空闲时是高电平,第1个跳变沿是下降沿,第2个跳变沿是上升沿

CPHA = 1:数据在第2个跳变沿(上升沿)采样

时序图如下:

spi时序图怎么分析,怎么看懂spi时序图

这样看是不是对4种模式的区别比较清晰了?

下面,我们再拿OLED的驱动芯片SSD1306的时序图来作为实战讲解。

SSD13064线SPI通讯时序如下:

spi时序图怎么分析,怎么看懂spi时序图

从这个时序图可以看出几个关键点:

  1. 在发送数据之前,要把CS引脚拉低。
  2. D/C一般是用来控制发送命令还是数据的。
  3. 数据在第二个SCLK跳变开始传输。
  4. 数据在SCLK上升沿的时候进行传输,每次发送一个Bit,高位在前。

所以,由这个时序图可以判断出来,用的是SPI模式3的通讯方式。

知道这个之后,你就知道单片机的硬件SPI模式要怎么配置了(下图以STM32为例)

spi时序图怎么分析,怎么看懂spi时序图

ok,今天时间关系,就先写到这里,如果赞多的话再回来更。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/218308.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 上午7:33
下一篇 2026年3月18日 上午7:34


相关推荐

  • C++类指针初始化

    C++类指针初始化上面的代码会打印 A C 类指针定义的时候没有初始化的时候 居然可以安全的调用类内部的成员函数而不出错 在网上查了一下 初始化为 NULL 的类指针可以安全的调用不涉及类成员变量的类成员函数而不出错 但是如果类成员函数中调用了类成员变量则会出错 既然赋值为 NULL 的情况都可以使用 那么自然不初始化的类指针同样满足这类情况 假设现在有一个简单的类

    2026年3月16日
    2
  • python命名规则标识符_python中有效的标识符

    python命名规则标识符_python中有效的标识符标识符规则1、由大小写字母、数字和下划线组成,只能以字母或者下划线开头。2、不能高阔除下划线以外的其他热河字符,如%……%¥#@3、不能包含换行符、空格和制表符等空白字符。4、不能使用Python中的关键字和约定俗成的名称,如print5、Python区分大小写。…

    2025年10月13日
    7
  • 41-新的信号注册函数 sigaction

    41-新的信号注册函数 sigaction在这之前,我们一直使用signal来注册信号处理函数,而且一开始我甚至都没有提起过甚至signal还有一个兄弟——sigaction.我相信,把sigaction放到这里是适合的,因为你已经具备了足够的基础去理解它了。1.sigaction函数不同于signal函数,sigaction函数是符合POSIX标准的,而signal只是ANSIC标准函数。除了上面的区

    2022年5月25日
    38
  • pandas fillna详解

    pandas fillna详解pandas中补全nan具体的参数Series.fillna(self,value=None,method=None,axis=None,inplace=False,limit=None,downcast=None,**kwargs)[source]参数: value:scalar,dict,Series,orDataFrameValuetouset…

    2022年8月12日
    16
  • python求乘积_Python实现求笛卡尔乘积方法详解

    python求乘积_Python实现求笛卡尔乘积方法详解这篇文章主要介绍了 Python 实现求笛卡尔乘积的方法 结合实例形式分析了 Python 计算笛卡尔乘积的原理与实现技巧 需要的朋友可以参考下本文实例讲述了 Python 实现求笛卡尔乘积的方法 分享给大家供大家参考 具体如下 在数学中 两个集合 X 和 Y 的笛卡尓乘积 Cartesianpro 又称直积 表示为 X Y 第一个对象是 X 的成员而第二个对象是 Y 的所有可能有序对的其中一个成员 假设集合 A

    2025年11月17日
    5
  • 在电脑上安装部署OpenClaw详细教程指南

    在电脑上安装部署OpenClaw详细教程指南

    2026年3月13日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号