前言:

为了方便查看博客,特意申请了一个公众号,附上二维码,有兴趣的朋友可以关注,和我一起讨论学习,一起享受技术,一起成长。


1. 简述

前面也就 SPI 的通信进行过基础的学习,针对的是标准 4 线的 SPI ,近期因为芯片资源有限,不得不使用一根片选 CS 去控制两个 SPI 从设备,在这个过程中,也重新对 SPI 的通信细节有了进一步的了解与认识,还是觉得有必要记录下来,以供查询和学习,也是对 SPI 通信协议的进一步理解。

几篇以前的博客

  1. STM32硬件SPI驱动0.96寸的OLED
  2. 51 软件模拟SPI驱动OLED
  3. SPI专题(二)——STM32驱动FLASH(W25Q64)
  4. SPI专题(一)——基础知识

2. 定义:

CS: (SS, S̅S̅, SSEL, CS, C̅S̅, CE, nSS, /SS, SS#) Slave Select (often active low, output from master)。

CS: SPI从设备是否被选中的,只有片选信号为预先规定的使能信号时(高电位或低电位),对此 SPI 从设备的操作才有效。

通常使用如下图:一个从设备分配一根 SPI 的片选 CS 信号:

3. CS 信号的有效性

SS: Slave Select (often active low, output from master)。常见的 SPI 从设备的片选信号为低电平选中设备,高电平释放设备。

3.1 时序:

3.2 程序

void Flash_WriteEnable(void)
{FLASH_CS_LOW;Spi_WriteByte(FLASH_WRITE_ENABLE_CMD);//开启写使能FLASH_CS_HIGH;
}

3.3 数据通信

一般读写数据的流程如上图所示,依次是:指令——>地址——>数据。一些设备如:I2C 还具有应答信号。

当 SPI 从设备的片选信号选中后,通信开始,SPI 总线上开始有数据,空闲状态的总线(CS、SCK、MOSI、MISO)是确定的高或者低电平。

3.4 CS片选有效性

3.4.1 OLED、LCD12864等设备,可直接接地,或者通过下拉电阻接地

数据手册:

3.4.2 SPI Flash,命令执行前需要有一个从高到低的状态变化,不可直接接地

因为 Flash CS 的状态在通信过程中是变化的,只有在执行 SPI 通信的时候为低,其余是高电平,所以示波器看到的是高低电平之间的变化(Flash 的读写)。若直接接地,CS 状态无法改变,通信失败。

4. 一个CS 控制两个 SPI Slave

从 SPI 的通信协议,我们知道 SPI 总线上的多个 Slave 之间是互斥、分时通信的,即同一时刻只能有一个设备有效,根据这种思路,当需要一个 CS 信号控制两个 Spi Slave 的时候,我们可以在 CS 的控制线上增加一个非门,这样就将两个设备的通信时间区分开了,一个高,另一个低。当然,GPIO 富余的时候,一个设备一个 CS 是简单方便的。

4.1 非门选择

4.1.1 可以用一个逻辑器件实现,非门芯片
4.1.1 简单的可用一个三极管或 MOS 管实现非门逻辑,此处采用 NMOS 实现,如下图:

5. 注意

  1. 当一起 SPI 从设备的 CS 被选中后,SPI 的总线上时钟、数据开始启动,要留意这种一个 CS 控制两个设备的情况,防止切换过程中数据被改写。

  2. 对于需要提供一个电平跳变的 SPI 从设备,可以在软件中进行设置,如下:

void SPI_SlaveEnable(void)
{FLASH_CS_HIGH;FLASH_CS_LOW;
}

参考:

1.Serial Peripheral Interface (SPI)

再学 SPI ——(一)SPI片选信号相关推荐

  1. 高通平台SPI外设的片选信号配置

    spi master 和spi device有各自的dts配置: 这是spi master的配置示例,也就是spi控制器 这是一个spi device的配置示例,也就是spi外设(从设备) 一个spi ...

  2. SPI接口扫盲 SPI定义/SPI时序(CPHA CPOL)

    SPI接口扫盲 douqingl@gmail.com 为何要写这篇文档? 百度上找出来的SPI接口中文描述都说的太过简略,没有一篇文档能够详尽的将SPI介绍清楚的.wikipedia英文版[注释1]中 ...

  3. STM32 SPI片选信号拉不高的解决方案

    发现SPI数据和时钟正常输出,就是没有片选信号,这样配置之后就正常了 1.初始化SPI外设时 把NSS信号配置为软件管理 2.初始化SPI引脚时 把NSS引脚重新配置为普通GPIO

  4. SPI之 ------- 片选信号CS

    通常SPI是四线, MISO, MOSI, CS, CLK 但是也存在多个片选的情况,有好多个CS信号, 这钟情况下SPI如何控制slave设备实现读写呢? CS: SPI从设备是否被选中的,只有片选 ...

  5. SaleaeLogic 16 逻辑分析仪的安装及使用【对 I2C、SPI、串口的信号进行测量】

    文章内容: 安装 SaleaeLogic 16 逻辑分析仪 用示波器和逻辑分析仪对 I2C.SPI.串口的信号进行测量,深入了解这些协议原理:并对照前两篇文章:[STM32 基于 I2C 通信协议的温 ...

  6. 【SPI】SPI学习之SPI硬件相关

    关联内容: [SPI]SPI学习之SPI硬件相关 [SPI]SPI学习之SPI驱动相关 [SPI]SPI学习之SPI调试相关 目录 SPI硬件知识 SPI相关的缩写或说法 SPI外部信号描述 SPI硬 ...

  7. 【SPI】SPI学习之SPI驱动相关

    关联内容: [SPI]SPI学习之SPI硬件相关 [SPI]SPI学习之SPI驱动相关 [SPI]SPI学习之SPI调试相关 目录 spi驱动框架 SPI控制器 spi_master 结构体 spi主 ...

  8. linux内核添加spi驱动,Linux内核驱动之spi子系统spi协议.docx

    Linux内核驱动之spi子系统spi协议 概况 SPI接口是摩托罗拉首先提出的全双工三线同步串行外围接口SCK,MOSI,MISO,采用主从模式(Master Slave)架构:支持多slave模式 ...

  9. STM32F103C8T6+SD/Micro TF卡+SFATS+软SPI+硬SPI

    使用环境(蓝色粗体字为特别注意内容) 1.软件环境:Keil MDK 5.15 2.硬件环境:STM32F103C8T6最小系统,Micro TF卡 在一个项目中需要用到SD卡,于是在某宝买了一块Mi ...

最新文章

  1. 2020年,图机器学习的趋势有哪些?
  2. Windows 2000 SP4 Server 找不到网络名
  3. NLTK基础 | 一文轻松使用NLTK进行NLP任务(附视频)
  4. [Python爬虫] 在Windows下安装PIP+Phantomjs+Selenium
  5. ebs 供应商地点信息_EBS标准的查看供应商地址
  6. 传输层端口号的范围是多少?被分为哪两部分_根据资金习性可以把资金分为哪几类?_中级会计职称考试视频...
  7. 《『若水新闻』客户端开发教程》——11.代码编码(3)
  8. 如何查找涉密文件_企业如何处理涉密信息文件?这四点必知
  9. zoj2901【DP·二进制优化】
  10. 会话推荐和 序列推荐
  11. ts 报错:‘new‘ expression, whose target lacks a construct signature, implicitly has an ‘any‘ type.
  12. div+css视频教程大全免费下载更有html5教程
  13. Django中使用163邮箱发送邮件
  14. 03.计算机网络--- 网络层、IP协议、手工配置IP地址
  15. html空格语言,HTML中如何键入空格
  16. Windows下如何批量重命名
  17. 使用pandas读取excel表格如何去掉标题
  18. 像诗人一样睿智,像天才一样疯狂
  19. 使用Bootstrap框架写的一个小实例
  20. HTML实现遮罩层的方法 HTML中如何使用遮罩层

热门文章

  1. 基于java的HashMap遍历
  2. [数据压缩]_实验① bmp转yuv
  3. 【matplotlib】windows系统解决jupyter notebook中文显示问题
  4. Qt 之 去除窗口部件被选中后的焦点虚线框
  5. (附源码)计算机毕业设计SSM连锁便民超市前端系统
  6. 详解linux下mnt目录作用
  7. pyqtgraph:GLSurfacePlotItem如何在三维地形表面自定义颜色分布(读取图片给三维平面分区域着色)
  8. 诸葛io , 面向数据智能时代的大数据实践(下)
  9. hive任务优化-Current usage: 2.0 GB of 2 GB physical memory used; 4.0 GB of 16.2 GB virtual memory used.
  10. 2020 java面试部分汇总