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

SPI协议介绍

SPI协议介绍


文章目录

  • SPI协议介绍
    • 一、 SPI硬件知识
      • 1.1 硬件连线
      • 1.2 SPI控制器内部结构
    • 二、 SPI协议
      • 2.1 传输示例
      • 2.2 SPI模式
  • 致谢



一、 SPI硬件知识

1.1 硬件连线

在这里插入图片描述
引脚含义如下:

引脚含义
DO(MOSI)Master Output, Slave Input,
SPI主控用来发出数据,SPI从设备用来接收数据
DI(MISO)Master Input, Slave Output,
SPI主控用来发出数据,SPI从设备用来接收数据
SCKSerial Clock,时钟
CSChip Select,芯片选择引脚

1.2 SPI控制器内部结构

这个图等看完后面的SPI协议,再回过头来讲解:

在这里插入图片描述

二、 SPI协议

2.1 传输示例

假设现在主控芯片要传输一个0x56数据给SPI Flash,时序如下:
在这里插入图片描述
首先CS0先拉低选中SPI Flash,0x56的二进制就是0b0101 0110,因此在每个SCK时钟周期,DO输出对应的电平。
SPI Flash会在每个时钟周期的上升沿读取D0上的电平。

2.2 SPI模式

在SPI协议中,有两个值来确定SPI的模式。
CPOL:表示SPICLK的初始电平,0为电平,1为高电平
CPHA:表示相位,即第一个还是第二个时钟沿采样数据,0为第一个时钟沿,1为第二个时钟沿

CPOLCPHA模式含义
000SPICLK初始电平为低电平,在第一个时钟沿采样数据
011SPICLK初始电平为低电平,在第二个时钟沿采样数据
102SPICLK初始电平为高电平,在第一个时钟沿采样数据
113SPICLK初始电平为高电平,在第二个时钟沿采样数据
我们常用的是模式0和模式3,因为它们都是在上升沿采样数据,不用去在乎时钟的初始电平是什么,只要在上升沿采集数据就行。

极性选什么?格式选什么?通常去参考外接的模块的芯片手册。比如对于OLED,查看它的芯片手册时序部分:
在这里插入图片描述SCLK的初始电平我们并不需要关心,只要保证在上升沿采样数据就行。



致谢

以上笔记源自韦东山老师的视频课程,感谢韦老师,韦老师是嵌入式培训界一股清流,为嵌入式linux开发点起的星星之火,也愿韦老师桃李满园。聚是一团火,散是满天星!

在这样一个速食的时代,坚持做自己,慢下来,潜心琢磨,心怀敬畏,领悟知识,才能向下扎到根,向上捅破天,背着世界往前行!
仅此向嵌入行业里的每一个认真做技术的从业者致敬!



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

相关文章:

  • MySQL数据库中索引的优点及缺点
  • (q)sort函数总结(基础篇)
  • 【数据库】MongoDB数据库详解
  • 【linux】进程间通信——system V
  • 计算机网络的基本组成
  • 【数据结构趣味多】Map和Set
  • Redis 之企业级解决方案
  • 雷达实战之射频前端配置说明
  • Android SDK删除内置的触宝输入法
  • [202002][Spring 实战][第5版][张卫滨][译]
  • H5视频上传与播放
  • 通过OpenAI来做机械智能故障诊断-测试(1)
  • ASE40N50SH-ASEMI高压MOS管ASE40N50SH
  • MySQL基础命令大全——新手必看
  • sklearn学习-朴素贝叶斯(二)
  • MySQL_主从复制读写分离
  • shell基础学习
  • 考虑交叉耦合因素的IPMSM无传感器改进线性自抗扰控制策略
  • 2023年全国最新食品安全管理员精选真题及答案5
  • git 笔记
  • ChatGPT 的盈利潜力:我使用语言模型赚取第一笔钱的个人旅程
  • 计算机网络——问答2023自用
  • 【1247. 交换字符使得字符串相同】
  • 【一天一门编程语言】Lisp 语言程序设计极简教程
  • 全后端交互数据加密
  • 稀疏特征和密集特征
  • Linux网络TCP sticky分析工具
  • 华为OD机试题,用 Java 解【DNA 序列】问题
  • python的所有知识点+代码+注释,不看就亏死了
  • 读懂分布式事务