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

嵌入式科普(24)从SPI和CAN通信重新理解“全双工”

目录

一、概述

二、参考资料

三、嵌入式常见的通信对比

四、驱动函数对比

五、总结


一、概述

  • 前段时间因为没有真正理解“全双工”的概念,导致spi的驱动写了好几天

  • 大家知道spi是全双工;can是全双工/半双工争议非常多

  • 究竟什么是“全双工/半双工”?有没有标准?

  • 真正理解这个概念的好处:正确的编写驱动函数;深刻理解才能思路清晰

二、参考资料

  • https://www.bosch-semiconductors.com/zh/ip模块/can-协议/

  • IEEE802.3-2018.pdf

  • CAN入门书.pdf

  • STM32H723/733 Reference manual

  • https://blog.csdn.net/weixin_43746325/article/details/119837354

三、嵌入式常见的通信对比

图片

关键:

  • SPI

    的时钟SCLK是主发给从,是单向的;但时钟线是两根,是双向的

  • CAN

    的物理层是2跟差分信号,是单向的;但控制器是tx rx两根,是双向的

四、驱动函数对比

通信协议

API函数

I²C

HAL_I2C_Master_Transmit
HAL_I2C_Master_Receive

UART

HAL_UART_Transmit
HAL_UART_Receive

SPI

HAL_SPI_Transmit
HAL_SPI_Receive
HAL_SPI_TransmitReceive

CAN

HAL_FDCAN_AddMessageToTxFifoQ
HAL_FDCAN_GetRxMessage

五、总结

  • 全双工

    物理介质能够在没有干扰的情况下支持同步传输和接收

  • CAN的本质是半双工

    ,因为差分信号只能单向通信;所谓CAN在协议层是全双工,实际是FIFO、仲裁机制等实现

  • SPI

    收发两根数据线,可以同时收发,满足全双工,但时钟是主发给从单向,所以从无法主动发送数据,从只能等待主发送时“顺带”发送。类似zigbee休眠的poll机制,收发数据的时机是同时发生的,也算全双工

  • 从SPI的API的命名(HAL_SPI_TransmitReceive)也能发现,所以写spi的驱动函数与其他协议是不同的。


http://www.kler.cn/a/450613.html

相关文章:

  • 使用TC命令模拟弱网丢包
  • 石岩基督教福音堂
  • 餐饮业的数字化转型:JSP订餐管理系统的设计与开发
  • Flask中@app.route()的methods参数详解
  • 一体式IO模块:打印机加工产线国产化降本增效的新利器
  • MyBatis 中常用标签
  • 智能脂肪秤方案pcba设计研发步骤解析
  • 开发场景中Java 集合的最佳选择
  • 华为浏览器(HuaweiBrowser),简约高效上网更轻松
  • uniapp Native.js原生arr插件服务发送广播到uniapp页面中
  • leetcode 面试经典 150 题:螺旋矩阵
  • Spring基础分析13-Spring Security框架
  • Python中zip
  • H3C MPLS跨域optionB
  • MacOS M3源代码编译Qt6.8.1
  • Linux系统文件
  • 前端Python应用指南(二)深入Flask:理解Flask的应用结构与模块化设计
  • 1688商品详情api接口开发返回值说明中skus商品规格和props商品详情
  • leetcode hot100 两两交换链表之中的节点
  • 深度学习从入门到精通——图像分割实战DeeplabV3
  • 基于Springboot的在线问卷调查系统【附源码】
  • JVM执行引擎JIT深度剖析
  • 【MySQL】InnoDB存储引擎中的索引
  • 深入理解C++23的Deducing this特性(下):高级应用与实战技巧
  • mapbox基础,加载mapbox官方地图
  • RGCL:A Review-aware Graph Contrastive Learning Framework for Recommendation