软件学习——spi(8)

spi

PI电路设计

SPI(Serial Peripheral lnterface--串行外设接口)总线系统是一种同步串行外设接口,它可以使处理器与各种外围设备以串行方式进行通信以交换信息。

> MOSI - 主设备数据输出,从设备数据输入

> MISO - 主设备数据输入,从设备数据输出

SCLK - 时钟信号,由主设备产生

SS - 从设备使能信号,由主设备控制,SS是控制芯片是否被选中,只有片选信号使能操作才有效。

通过不同的SS线,控制不同的从设备

ESP32 集成了四个SPI外设。

SPI0 和 SPI1 在内部用于访问 ESP32 附加的闪存,因此目前不对用户开放。它们通过仲裁器共享一条信号总线。

SPI2 和 SPI3 是通用 SPI 控制器,有时分别称为 HSPI 和 VSPI。它们对用户开放。SPI2 和 SPI3 具有具有相同名称的独立信号总线。每条总线有三条CS线,可驱动多达三个SPI从站。

SPI主控驱动的概念是将多个设备连接到一条总线(共享一个 ESP32SPI外围设备)。只要每个设备仅由一个任务访问,驱动程序就是线程安全的。但是,如果多个任务尝试访问同一 SPI 设备,则驱动程序不是线程安全的。在这种情况下,建议:

重构应用程序,以便每个应用程序SPI外设一次只能由单个任务访问。

使用 xSemaphoreCreateMutex 在共享设备周围添加互斥锁。

代码解析:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值