Betaflight关于STM32F405 SBUS协议兼容硬件电气特性问题

2023-10-28 18:52

本文主要是介绍Betaflight关于STM32F405 SBUS协议兼容硬件电气特性问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Betaflight关于STM32F405 SBUS协议兼容硬件电气特性问题

  • 1. 源由
  • 2. 储备知识
    • 2.1 三态逻辑(Tri-state Logic)
    • 2.1 上拉 (Pull-up)
    • 2.2 下拉 (Pull-down)
    • 2.3 Current Sink
    • 2.4 Current Source
    • 2.5 GPIO输入模式
    • 2.6 GPIO输出模式
  • 3. FPV系统协议简介
    • 3.1 TX Protocols – communication between radio transmitter (TX) and radio receiver (RX)
    • 3.2 RX Protocols – communication between radio receiver (RX) and flight controller (FC)
    • 3.3 ESC Protocols – communication between FC and ESC
  • 4. 分析
    • 4.1 硬件方案
    • 4.2 接收机sbus翻转
    • 4.3 飞控固件
  • 5. 实测4.4.2固件
    • 5.1 固件编译
    • 5.2 配置ELRS接收机
    • 5.3 配置F405飞控
    • 5.4 实测结果
  • 6. 总结
  • 7. 参考资料

1. 源由

最近遇到一个问题:
1)现象:STM32F405飞控,无法接sbus接收机。
2)原因:与通常F405飞控差异是没有sbus接口。

为了更好的解释这个问题,先储备一些基础知识。

2. 储备知识

2.1 三态逻辑(Tri-state Logic)

通常MCU的GPIO会设计成三态,此时信号取决于外部电路逻辑。

  • 逻辑0 (connection to ground)
  • 逻辑1 (connection to VCC, mostly through resistor)
  • 高阻 (High-impedance, also called “floating”, “Hi-Z”, “tri-stated”)

注:高阻态是一种信号线共享的机制,当需要使用信号线是进行拉高、拉低输出信号。高阻时放弃信号线使用权。

2.1 上拉 (Pull-up)

通过上拉电阻,将信号线拉至默认输出状态。MCU控制器设计时也有内部上拉选项,相当于外部上拉电阻的效果。

2.2 下拉 (Pull-down)

通过下拉电阻,将信号线拉至默认输出状态。MCU控制器设计时也有内部下拉选项,相当于外部下拉电阻的效果。

2.3 Current Sink

通常指IO能够承受多少负载电流,超出负载将会损坏IO(芯片)。

2.4 Current Source

通常指IO能提供的负载的驱动能力,超出负债将无法工作。

2.5 GPIO输入模式

  • High-impedance (often the default – floats if not driven)
  • Pull-up (internal resistor connected to VCC)
  • Pull-down (internal resistor connected to Ground)

2.6 GPIO输出模式

  • Push-pull输出: 常见GPIO配置方式,具备Current Sink/Source能力

在这里插入图片描述

  • Open-Drain输出: 相当于一个对地的开关,具备Current Sink能力

Open-drain
Open-drain with internal pull-up // 常用于通信,比如:I2C

在这里插入图片描述
注:Open-Collector是BJT,Open-Drain指FET 【 2 】 ^{【2】} 2

3. FPV系统协议简介

3.1 TX Protocols – communication between radio transmitter (TX) and radio receiver (RX)

  • ACCST (Frsky)
  • ACCESS (Frsky)
  • DSM (Spektrum)
  • DSM2 (Spektrum)
  • DSMX (Spektrum)
  • AFHDS (Flysky)
  • AFHDS 2A (Flysky)
  • A-FHSS (Hitec)
  • FASST (Futaba)
  • Hi-Sky (Deviation / Devo)

3.2 RX Protocols – communication between radio receiver (RX) and flight controller (FC)

  • PWM (universal)
  • PPM or CPPM (universal)
  • SBUS (Futaba, Frsky)
  • IBUS (Flysky)
  • XBUS (JR)
  • MSP (Multiwii)
  • CRSF (ExpressLRS, TBS Crossfire and Tracer)
  • SPEKTRUM1024 (Spektrum DSM2)
  • SPEKTRUM2048 (Spektrum DSMX)
  • FPort (Frsky)
  • SPI_RX (universal) – More detail in this article
  • GHST (ImmersionRC Ghost)

3.3 ESC Protocols – communication between FC and ESC

  • PWM
  • Oneshot (Oneshot42, Oneshot125)
  • Multishot
  • Proshot
  • Dshot (Dshot150, Dshot300, Dshot600, Dshot1200)

4. 分析

回到本文的主要目标:没有sbus焊盘的F405飞控与sbus接收机通信。

首先,从前面储备知识我们了解到以下几个信息:

  1. SBUS 是接收机与飞控之间的协议
  2. MCU的GPIO作为输入:可以处于高组态,根据外部信号的变化而感知高低电平
  3. SBUS协议是futaba编制RC控制协议 【 5 】 ^{【5】} 5,未减少干扰使用低电平有效 【 1 】【 3 】 ^{【1】【3】} 1】【3

4.1 硬件方案

市面上常见的处理方法:采用一个转换器进行转换。

在这里插入图片描述
除了上述硬件方法以外,其实还有两个思路可以考虑:

  1. 接收机信号输出时进行信号翻转
  2. 飞控端协议解析时,进行信号翻转

4.2 接收机sbus翻转

ELRS接收机配置inverted sbus信号。

在这里插入图片描述

4.3 飞控固件

经过调查后发现:F405芯片与F3/F7不一样,芯片内部没有反向器。通常STM32F405的飞控板都是通过一个外置反向电路,来转换接收机的sbus信号。

来自参考资料【1】
A serial signal is composed of a series of High and Low electrical signals sent down a wire. In the standard serial protocol, a high signal is 0 and low is 1. In an inverted signal this is reversed so that a high is 1 and low is 0. You might think it makes more sense that low should always be 0 and high be 1 but electronics engineers decided that standard serial protocol should be the former.

To convert a standard serial signal to an inverted signal you run it through an inverter chip (which can be as simple as a single transistor) which will simply change all high signals to low and vice versa.

F3 and F7 chips have inbuilt inverters on their hardware uarts, which enable them to transmit or receive serial signals in any polarity. For some reason, F4’s were designed without that feature and thus do not support inverted signals on their uarts.

通常“硬”的不行,我们总希望“软”的能解决。这个思路在软件技术发展条件下,确实能解决或者绕过很多硬件问题。这也是GPIO(General Purpose IO)的一些优势。

经代码分析,曾经F411的时代,确实有软串口来进行串口的扩展。同时也支持了采用定时器方案进行sbus协议解析。

在这里插入图片描述
主要配置内容有以下几点:

  1. 固件要确保配置定义USE_SOFTSERIAL,以便将软串口代码进行编译;
  2. 正确配置软件串口翻转状态:

SBUS协议接收机 ⇒ set serialrx_inverted = ON
Inverted SBUS接收机 ⇒ set serialrx_inverted = OFF

5. 实测4.4.2固件

5.1 固件编译

  1. SBUS协议
  2. USE_SOFTSERIAL
  3. 4.4.2 BF固件 云编译

在这里插入图片描述

5.2 配置ELRS接收机

首先,使用ELRS接收机采用CRSF协议确保硬件接线正确UART2-RX与ELRS-TX连接,接收RC遥控正常(油门会高于没有接收机的885数值)。

在这里插入图片描述

当协议切换到SBUS时,ELRS-TX即ELRS-SBUS硬件接口。

然后,配置Inverted SBUS协议,使用硬件UART2-RX确保接收机与飞控工作正常。

在这里插入图片描述

5.3 配置F405飞控

首先,配置软件串口。
在这里插入图片描述

然后,配置软件串口资源和端口。

# resource SERIAL_RX 11 A03Resource is set to A03

在这里插入图片描述最后,检查serialrx_inverted 状态。

# get serialrx_inverted
serialrx_inverted = OFF
Allowed values: OFF, ON
Default value: OFF

5.4 实测结果

在这里插入图片描述

测试结果:Betaflight 4.4.2 固件软件串口无法解析SBUS或inverted SBUS协议。

相关跟踪,详见:

  • Does ELRS 3.3.0 supoort SBUS inverted? #2462
  • Does BF support sbus on softserial? #13144

6. 总结

目前,大量的STM32F405飞控设计时,就考虑采用BJT/FET 【 2 】 ^{【2】} 2inverter进行硬件翻转SBUS信号与MCU兼容。

在这里插入图片描述

舍弃软件串口的可能原因大概有以下几点:

  1. 主流飞控F7/H7,以及后续的产品会在新片端内置inverter设计;
  2. 市场上大量STM32F405飞控硬件上也都采用的硬件兼容方式,提供SBUS焊盘;
  3. 软件串口占用大量的资源:定时器,中断、时序等;
  4. 固件新功能的发展,以及飞控趋势,软串口可能会淡出视线;

7. 参考资料

【1】What does it mean for SBUS to be an inverted protocol?
【2】difference-between-bjt-and-fet
【3】What is the advantage of SBUS over IBUS?
【4】Uninverted SBUS and Smart Port on Frsky Receivers
【5】Protocol decoder:sbus_futaba
【6】Tutorial: How to Setup Betaflight Softserial

这篇关于Betaflight关于STM32F405 SBUS协议兼容硬件电气特性问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/295249

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

MySQ中出现幻读问题的解决过程

《MySQ中出现幻读问题的解决过程》文章解析MySQLInnoDB通过MVCC与间隙锁机制在可重复读隔离级别下解决幻读,确保事务一致性,同时指出性能影响及乐观锁等替代方案,帮助开发者优化数据库应用... 目录一、幻读的准确定义与核心特征幻读 vs 不可重复读二、mysql隔离级别深度解析各隔离级别的实现差异

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基