总体介绍

1. ESP32 共有 4 个 SPI 控制器 SPI0、SPI1、SPI2、SPI3,用于连接支持 SPI 协议的设备。
  • SPI0 控制器作为 cache 访问外部存储单元接口使用;
  • SPI1 作为主机使用;
  • SPI2 和 SPI3 控制器既可作为主机使用又可作为从机使用。作主机使用时,每个 SPI 控制器可以使用多个片选信号 (CS0 ~ CS2) 来连接多个 SPI 从机设备。
  • SPI1 ~ SPI3 控制器共享两个 DMA 通道。
2. 作为通用 SPI 支持以下特性:
  • 4 种模式的 SPI 传输格式,模式取决于 SPI 时钟的极性 (CPOL) 和相位 (CPHA);
  • 最高支持到 80 MHz(实际可支持频率还受限于所用 pad、PCB 走线、外接器件规格等);
  • 最高支持 64 byte 的 FIFO ;
  • 所有 SPI 接口都可以连接外部 flash/SRAM 和 LCD。每一个 SPI 控制器都可连接到 DMA 通道。
3. 编程指南说明:
  • SPI Features - SPI Master - SPI Bus Lock
  • SD SPI Host Driver
  • SPI Master Driver
  • SPI Slave Driver

应用分类

1 SPI Flash/PSRAM

1.1 内置 SPI Flash/PSRAM

  • SPI0:被 Flash 占用,内置 Flash 端口与芯片管脚对应关系如下,一般是 GPIO6 ~ GPIO11 ,且这几个管脚不可用于其他功能。但不同型号的模组默认的 Flash 接口可能不同,可使用 esptool 工具通过 espefuse.py summary 命令来查询默认的配置。
SPI_PAD_CONFIG_CLK (BLOCK0): Override SD_CLK pad (GPIO6/SPICLK)  = 0 R/W (0b00000)
SPI_PAD_CONFIG_Q (BLOCK0): Override SD_DATA_0 pad (GPIO7/SPIQ)  = 0 R/W (0b00000)
SPI_PAD_CONFIG_D (BLOCK0): Override SD_DATA_1 pad (GPIO8/SPID)  = 0 R/W (0b00000)
SPI_PAD_CONFIG_HD (BLOCK0): Override SD_DATA_2 pad (GPIO9/SPIHD)  = 0 R/W (0b00000)
SPI_PAD_CONFIG_CS0 (BLOCK0): Override SD_CMD pad (GPIO11/SPICS0)  = 0 R/W (0b00000)
  • ESP32 系列的模组,目前默认最大支持 16MB 的 Flash 。

  • ESP32 系列的模组,除 ESP32-WROVER 模组为 1.8V Flash 以外,其他型号的模组均为 3.3V Flash。

  • 带有内置 Flash 的芯片型号需要注意上电时的 MTDI(GPIO12) 电平。例如 ESP32-U4WDH 的内置 Flash 的工作电压是 3.3V,上电时需要将 MTDI(GPIO12) 拉低。请参见《ESP32 技术规格书》关于”Strapping 管脚“ 的说明。

  • 目前 ESP 适配过的 Flash 型号可参见 “Flash 特性支持情况”

  • SPI1:FLASH 和 PSRAM 共用一组 SPI,通过不同的 CS 线实现控制。GPIO16 ~ GPIO17 一般是用于 Flash 和 PSRAM 的共用接口,且这 2 个管脚不可用于其他功能。PSRAM 的接口除了 CS(任意 GPIO)不能与 Flash 共用外,CLK 接口(建议参考模组使用的时钟脚),其他都可以与 Flash 的接口共用;目前最大支持使用外接 8MB PSRAM。

  • 当使用 VDD_SDIO 的 1.8 V 模式给 Flash/PSRAM 等外设供电时,需要在 VDD_SDIO 上接个对地 2 kΩ 的
    电阻,参考《ESP32-WROVER 技术规格书》 中原理图。

  • SPI Flash/PSRAM 硬件原理图可参见《ESP32 硬件设计指南》

  • SPI Flash 编程指南参见 "SPI Flash API"

  • "SPI Flash 加密" 和 "ESP32-Secure Boot 安全方案"


【软件应用例程】

  • 对自带的 Flash 设置特定的分区,作为操作 SPIFFS 文件系统的分区。可参见例程:esp-idf/examples/storage/spiffs
  • 对自带的 Flash 设置特定的分区,构建 SPIFFS 图像生成示例:esp-idf/examples/storage/spiffsgen
  • 对自带的 Flash 设置特定的分区存储音频文件并播放存在 Flash 中的 MP3 文件示例:esp-adf/examples/player/pipeline_flash_tone
  • 对自带的 Flash 设置特定的分区构建 SPIFFS 文件系统来存储 MP3 文件,并播放存在 SPIFFS 文件系统中的 MP3 文件示例:esp-adf/examples/player/pipeline_spiffs_mp3

【Flash & PSRAM 常见应用问题】

  • Flash 常见应用问题
  • PSRAM 常见应用问题

1.2 外接 SPI Flash 存储外部数据

  • 可使用通用 SPI ,支持任意 GPIO 管脚进行映射。使用任意 GPIO 进行映射时,需要注意对时序产生的影响,可参考 “Timing Considerations” 说明。
  • 目前只支持外接 SPI NOR Flash 芯片,以 W25Q32 型号的 SPI NOR Flash 芯片为例,可参见例程 esp-idf/examples/storage/ext_flash_fatfs

1.3 外接 SPI PSRAM 存储外部数据

  • 硬件上支持使用 SPI2 或 SPI3 接口外接 PSRAM 芯片,但是 SPI2 和 SPI3 不支持 Cache ,且目前软件上无 SPI2、SPI3 的 PSRAM 的驱动,所以目前使用 SPI2\SPI3 外接 PSRAM 是可不用的。

2 SD SPI(可使用 SPI 接口或 SDIO 接口)

  • SD SPI Host Driver 说明
  • SDSPI 例程参见:esp-idf/examples/storage/sd_card/sdspi,包含硬件接线及上拉要求;支持 SD(SDSC、SDHC、SDXC)卡。

3 SPI 外接 LCD

ESP32 目前支持 SPI 串行接口、6800、8080 并口的 LCD。

3.1 ESP32 适配的 LCD 参数

1. SPI 接口

  • 最大分辨率:480*320
  • 最大帧率:80MHz 的频率大概是 12 帧

2. 8080/6800 接口协议

  • 最大分辨率:854*480

3.2 SPI LCD 硬件设计参考

  • 官方提供了 ESP32-LCDKit 开发板,开发板预留屏幕接口类型:SPI 串行接口、8 位和16 位并行接口,可用于测试。对应原理图请参见 “esp-dev-kits/docs/zh_CN/esp32/esp32-lcdkit/hw/schematics/SCH_ESP32-LCDKit_V1.1_20190218.pdf”
  • ESP-WROVER-KIT 开发板贴装一款 3.2 寸的 SPI(标准四线串行外设接口)LCD 显示器,分辨率为 320*240。请见 ESP-WROVER-KIT V4.1 原理图。

3.3 SPI LCD 软件应用

  • ESP32 的 SPI LCD 的 HMI 示例程序参考 esp-iot-solution/tree/master/examples/hmi
  • 适配的 LCD 的驱动库可参见 esp-iot-solution/components/display/screen/controller_driver; 默认使用的是 ILI9341 LCD 。
  • ESP32 的 8080 并口的例程可参见 esp-iot-solution/examples/screen 例程。对于 8080 协议的 LCD 接口,我们使用的是 I2S 接口软件方式实现,但此方式只支持 “写”,不支持 “读”。
  • ESP32 SPI 驱动墨水屏的例程可参考 esp-idf/examples/peripherals/spi_master/lcd 例程

3.4 SPI LCD 方案介绍

  • “乐鑫 ESP-LCD 多媒体智能控制方案” 视频介绍
  • 乐鑫 ESP-LCD 多媒体智能控制方案优势

4 SPI 通信

4.1 SPI Master

  • ESP32 SPI1 ~ SPI3 可以作为 SPI 主机与其他从机通信。ESP32 SPI 作主机使用时,每个 SPI 控制器可以使用多个片选信号 (CS0 ~ CS2) 来连接多个 SPI 从机设备。每个 ESP32 SPI 主机默认最多可以接 3 个从机。在非 DMA 模式下,一次最多可以接收/发送 64 byte 的数据,收发数据长度以字节为单位。
  • 详细说明建议阅读《ESP32 技术参考手册》 的 “7 SPI 控制器” 章节和 “SPI Master Driver” 编程指南。
  • 参考例程:esp-idf/examples/peripherals/spi_master

4.2 SPI Slave

  • SPI2 和 SPI3 可以作为从机。SPI2,有时也称为 HSPI ;SPI3,有时也称为 VSPI 。
  • 详细说明建议阅读《ESP32 技术参考手册》 的 “7 SPI 控制器” 章节和 “SPI Slave Driver” 编程指南。
  • 参考例程:esp-idf/examples/peripherals/spi_slave

4.3 SPI 传输 AT 指令

  • ESP32-C3 、ESP32 都支持 SPI 传输 AT 指令,但由于 ESP32 的硬件条件的限制,我们更推荐使用 ESP32 的 SDIO SPI 方式传输 AT 指令,吞吐率参见 “Readme” 说明。

硬件条件的限制是指:

  • SPI Slave 支持的 SPI Clock 为10MHz, 最理想的情况下大约 1MB/s , 但是实际要损失很多。
  • SPI Slave 需要在挂载好 Buffer 之后才允许 Master 收发数据。
  • 请参见 ”SCLK Frequency Requirements“ 说明。
  • ESP32 SPI 传输 AT 参见:esp-at/examples/at_spi_master/spi
  • 同时请阅读 SPI AT Guide

5 ESP-Hosted 无线网卡方案

  • ESP-Hosted 无线网卡 (Wireless network interface controller, WNIC) 方案,可参见 “乐鑫 ESP-WNIC 无线网卡方案” 介绍。
  • ESP32 SPI 接口支持如下特性:

SPI 使用注意事项

  • ESP32 的 SPI 在专用 IO_MUX SPI 引脚上的速度可达 80 MHz ,在 GPIO matrix 引脚上的速度可达 40 MHz ,但在 GPIO matrix 上的全双工传输只支持高达 26 MHz 的速度。请阅读 “SPI Master Driver” 编程指南。

SPI 常见应用问题

可查阅 ”ESP-FAQ 外设“ 章节。

ESP32 SPI 接口的应用相关推荐

  1. 物联网开发笔记(60)- 使用Micropython开发ESP32开发板之SPI接口控制Micro SD卡TF卡模块

    一.目的 这一节我们学习如何使用我们的ESP32开发板来通过SPI接口控制Micro SD卡TF卡模块. 二.环境 ESP32 + SPI接口控制Micro SD卡TF卡模块 + Thonny IDE ...

  2. 【Esp32】Esp32+sx1268 Spi接口驱动SX1268模块

    [Esp32]Spi接口驱动SX1268模块 0. 实验结果 1.原理解析 2.硬件接线 3. SX1268 模块的 SPI 时序分析 4. 基于 ESP32 实现函数封装 4.1 读寄存器 4.2 ...

  3. ESP32 入门笔记08:1.54寸(240*240)彩色TFT 显示高清IPS LCD 屏幕 SPI接口

    目录 1.屏幕规格 2.原理图 3.程序实现 3.1引脚定义 3.2Adafruit_GFX / Arduino_ST7789版 3.3TFT_eSPI库版 3.3.1配置TFT_eSPI a.选择屏 ...

  4. 物联网开发笔记(96)- Micropython ESP32开发之SPI接口控制Micro SD卡TF卡模块挂载内存卡

    一.目的 这一节我们学习如何使用乐鑫的ESP32开发板连接SD卡模块,进行目录.文件的相关操作. 在早前我们也介绍过TFT SD卡的操作,这里我们重新复习一下. 物联网开发笔记(60)- 使用Micr ...

  5. ESP32-S2上使用SPI接口芯片DM9051NP转以太网的无线物联网网关开发指导

    前言 DM9051NP芯片 SPI接口占用管脚数量比以太网PHY的RMII/MII少,PCBA版线布局可更精简.而DM9051NP驱动软件方面,由于源代码已集成在ESP IDF中,可见其可靠度以及网口 ...

  6. ESP32 SPI驱动1.44寸TFT彩屏(5)

    TFT-LCD 即薄膜晶体管液晶显示器.其英文全称为:Thin Film Transistor-Liquid Crystal Display. TFT-LCD 与无源 TN-LCD.STN-LCD 的 ...

  7. SPI通信协议:单片机spi通信接口什么意思,spi接口干什么用的?

    讲真,以前做开发的时候最怕就是调spi和iic. 因为公司没有逻辑分析仪,调起来全凭经验,一出问题找都找不到,只能仔细看代码盲调,看是不是哪个时序有问题. 说到这里,可能刚初学的小伙伴会问:单片机sp ...

  8. NanoPi NEO Air使用十三:使用自带的fbtft驱动点亮SPI接口TFT屏幕,ST7789V,模块加载的方式

    上节使用fbtft来驱动SPI接口TFT屏幕,但是是编译进内核的方式. 本节再来测试下编译成模块的用法. 引脚 240x240分辨率,1.3寸,主控为ST7789VW. 与开发板的引脚连接确定如下: ...

  9. NanoPi NEO Air使用十二:使用自带的fbtft驱动点亮SPI接口TFT屏幕,ST7789V

    上节自己编写spi驱动来点亮spi接口的小屏幕,其实Linux内核里已经提供spi接口小屏的设备驱动,即内核中已经自带了此类驱动,名字为fbtft.本节就来使用它. 引脚 240x240分辨率,1.3 ...

最新文章

  1. power bi tutorial within Unilever
  2. 机器人从计算机应用领域看,人的素质差异,本质地不在于他们即存知识信息量的差异,而在于他们思维能力的差异。( )...
  3. STL源码剖析—stl_config
  4. 必然的宿命,绚然的《暗花》
  5. java克鲁斯卡尔算法_Java语言基于无向有权图实现克鲁斯卡尔算法代码示例
  6. JUnit与TestNG:您应该选择哪种测试框架?
  7. 【ZOJ - 2968 】Difference Game (贪心,思维模拟)
  8. 实践设计模拟计算机,个体化股骨假体的计算机辅助设计实践及模拟力学实验
  9. fw313r虚拟服务器,迅捷FW313R无线wifi怎么设置上网 - falogincn登录页面
  10. 在anaconda环境下搭建python3.5 + jupyter sparkR,scala,pyspark
  11. python实现不使用额外的空间判断输入数字是否是回文数
  12. wxWindows一些网文
  13. 记账系统推荐金蝶精斗云_金蝶精斗云的免费财务做账软件有哪些?
  14. hive中操作hdfs命令
  15. 金融银行测试面试题:网上银行转账是怎么测的?
  16. matlab-基础 取整函数 向0取整 取最近整数 向上取整 向下取整
  17. 安卓系统入门_安卓玩家不可错过的神器:55GMagisk模块下载
  18. 腾讯地图地址搜索marker标记demo
  19. uni-app 汉字转拼音 搜索和按首字母排序页面
  20. 网络协议--网络四层协议

热门文章

  1. 破解163相册防盗链
  2. 以中国矿业大学名义申软著
  3. ArcCatalog和ArcSDE
  4. SkeyeVSS矿山采盗监控系统智能化管控非法采矿解决方案
  5. 安徽一家4A级景区被撤销,为申报4A曾给官员送钱送黄金
  6. Spring认证中国教育管理中心-Spring Data Neo4j教程一
  7. 解读RF放大器规格:输出电压/电流和1dB压缩点
  8. 微型计算机最核心的补件,春季高考试卷-天津市2016年春季高考计算机模拟试卷B【精】.doc...
  9. 班章管家正规可靠20万存定时5年合算吗?3年期比照5年期哪个好?
  10. 首发 阿里P8整理万字MyBatis实战笔记,精简易懂,开源免费下载