pATAq 发表于 2024-4-23 14:33:36

基于ESPHome的3DP舱内控制系统(1): 荆棘满途之FireBeetle2初始配置


# 前言

开一个新坑,谋划了很久,最初是为了测试 Moonraker 的 Sensor 组件,逐步扩展到设计一个完整的控制系统。硬件选择 ESP 系列芯片,功能足够,还支持 WiFi/BT。软件看了一圈选择 ESPHome,轻代码,功能强大配置简单易上手。

本文涉及的硬件:

* DFRobor FireBeetle2 ESP32-C6 迷你开发板

本文涉及的软件:

* ESPHome 2024.3.2 -> 2024.4.1(写作过程中已发布新版)
* Windows11 with WSL2(Debian Bookworm)

本文涉及的问题:

* ESPHome 和 PlatformIO 的基本命令
* ESPHome 正确支持 ESP32-C6
* C6 点灯测试
* 使用 external_components 修复 logger
* 修复报错 Refusing to overwrite
* WSL2 连接 USB 设备

# 1、文档资料

* (https://www.dfrobot.com.cn/goods-3825.html)
* [产品 WiKi 页面](https://wiki.dfrobot.com.cn/_SKU_DFR1075_FireBeetle_2_Board_ESP32_C6)
* [乐鑫科技 ESP32-C6 产品页面](https://www.espressif.com.cn/zh-hans/products/socs/esp32-c6)
* (https://docs.espressif.com/projects/esp-idf/zh_CN/v5.2.1/esp32c6/get-started/index.html)
* (https://docs.espressif.com/projects/esp-techpedia/zh_CN/latest/esp-friends/get-started/board-selection.html)

## 1.1 FireBeetle 2 硬件规格

![](https://ws.dfrobot.com.cn/FkHvaNayYatrM0dR0epU9gDjhD-6)

【图 FireBeetle 2 ESP32 C6开发板】

我们感兴趣的硬件特性总结如下:

- 搭载 ESP32-C6 芯片(160MHz的高性能 RISC-V 32位单核处理器)支持2.4Ghz WiFi 6、Bluetooth 5、Zigbee 3.0、Thread 1.3 通讯协议
- 主频:160 MHz
- SRAM:512KB
- ROM:320KB
- Flash:4MB

- 支持太阳能充电, 免电源线部署
- 电池电压检测引脚 IO0,和充电指示灯
- 熄灭:未接入电源或已充满
- 常亮:充电中
- 闪烁:电池未接入

- 板载GDI接口,轻松连接屏幕
- PH2.0电池接口,方便连接电池

- IO15/D13:板载LED引脚

- RST:复位按键

- IO9/D9/BOOT:IO引脚/BOOT按键

- (https://img.dfrobot.com.cn/wiki/5d57611a3416442fa39bffca/9ec2de70bd1093abe32e95f6c69f9cd7.pdf): 太阳能充电芯片

![](https://img.dfrobot.com.cn/wiki/5d57611a3416442fa39bffca/3abc01c920b46dab979e3cfdef706542.png)



## 1.2 ESPHome 介绍与优点

![](https://esphome.io/_static/logo-text.svg)

1. 项目主页:https://esphome.io/,默认支持 ESP32/ESP8266/RP2040/BK72XX/RTL87XX
2. 支持的硬件列表:由于使用 PlatformIO 进行编译,所以和 PIO 的支持列表相同: (https://registry.platformio.org/search?t=platform)

> ESPHome is a system to control your microcontrollers by simple yet powerful configuration files and control them remotely through Home Automation systems.
>
> ESPHome 使用配置文件来控制微控制器,旨在和家庭自动化控制系统(如 HomeAssistant 等)结合使用。它使用和配置简单,和 HA 语法基本一致,功能强大,支持多种模块,无需复杂的编程知识即可实现各种功能。

类似的还有 Tasmota/ESPEasy 等项目,相比之下 Tasmota 可以实现在固件中进行设置修改,但是支持的主控芯片与模块不如 ESPHome 多,使用流程也不像 ESPHome 那样提供一揽子方案。ESPHome 使用 PlatformIO 作为底层进行固件编译,所以支持非常多的设备。

# 2、安装使用 ESPHome(理想版)

为了防止劝退新手,先公布答案走一遍流程。以下使用 WSL2-Debian Bookworm。

```shell
## 安装配置 ESPHome
sudo apt-get install python3-venv
cd ~ && python3 -m venv esphome-env
source ~/esphome-env/bin/activate
pip3 install -U pip
pip3 install -U esphome
# 查看 esphome 软件版本
esphome version
# 创建配置文件目录
mkdir ~/esphome_config

## 使用向导创建配置文件
esphome wizard firebeetle2-esp32c6-demo.yaml
## 也可以使用 esphome dashboard 网页面板创建,后面是配置目录
# esphome dashboard ~/esphome_config

# 退出 Python 虚拟环境
deactivate
```
!(https://s2.loli.net/2024/04/23/c2YPqMj9LpsxigN.png)

## 2.1 为 ESP32-C6 编译 EPSHome 固件

查看 esphome 官方代码,已经支持 esp32c6 芯片了,再继续搜索,找到最新的一次提交:Fix logger compile error on ESP32-C6,发现需要指定使用新版的 Platformio(ESP32-C6 需要 PIO 版本最低为 6.4,目前最新为 6.6),但是目前配置文件创建向导 wizard 还不直接支持,因此我们可以选一个相近的同样采用 RISC-V 核心的 ESP32-C3,然后手动修改,配置如下:

```yaml
esphome:
name: firebeetle2-esp32c6-demo

esp32:
board: esp32-c6-devkitc-1
variant: esp32c6
flash_size: 4MB
framework:
    type: esp-idf
    version: 5.2.1 # 默认为 esp-idf 5.1.2 + PIO 6.5.0
    platform_version: 6.6.0 # at least 6.4 for ESP32-C6

ota:
password: ""

wifi:
ssid:
password:

# Enable fallback hotspot (captive portal) in case wifi connection fails
ap:
    ssid: "Firebeetle2-Esp32C6-Demo"
    password: "F4Qwm19jxEKj"

captive_portal:

```

然后可以使用命令或者 Dashboard 网页烧录固件。

```shell
# 一键命令编译烧录固件,ESP32 RISC-V 的工具链还是比较大的
esphome run firebeetle2-esp32c6-demo.yaml
# - Validates the configuration | 验证配置文件
# - Compiles a firmware | 编译固件
# - Uploads the firmware (over OTA or USB) | 上传固件(OTA 或者 USB)
# - Starts the log view | 开启日志查看

## 其他相关命令
# 验证配置文件并编译生成固件
esphome compile firebeetle2-esp32c6-demo.yaml
# 验证配置文件并上传最近一次编译的固件(USB首次上传需要进入烧录模式)
esphome upload firebeetle2-esp32c6-demo.yaml -d
esphome upload firebeetle2-esp32c6-demo.yaml --host-port
```

更多命令参考:(https://esphome.io/guides/cli),可以看到整体使用还是很简单的。

## 2.2 Hello World Via Onboard LED

一切的开始都是一盏灯,根据 DFRobot 的产品介绍,FireBeetle 2 有个板载LED,连接 GPIO15,我们使用 (https://esphome.io/components/light/)。在上述配置文件中添加下述内容,重新编译上传,此时可选 OTA 无线升级。

```yaml
# 定义一个状态灯
light:
# 板载 LED灯
- platform: status_led
    name: "Switch state"
    pin: GPIO15
```

# 3、使用 ESPHome(现实版)

## 3.1 支持 ESP32-C6

查询 PIO 设备支持列表,搜索 ESP32 C6,接近的有两个,esp32-c6-devkitc-1 和 esp32-c6-devkitm-1,和前者更接近,注意 Flash 为 4MiB。

| Name                                                         | MCU   | Frequency | RAM   | Flash | Frameworks                                                   | Debug                                                      |
| ------------------------------------------------------------ | ------- | --------- | ------- | ----- | ------------------------------------------------------------ | ------------------------------------------------------------ |
| (https://docs.platformio.org/en/latest/boards/espressif32/esp32-c6-devkitc-1.html) | ESP32C6 | 160 MHz   | 512 KiB | 8 MiB | (https://registry.platformio.org/search?q=espidf&t=tool) |                                                            |
| (https://docs.platformio.org/en/latest/boards/espressif32/esp32-c6-devkitm-1.html) | ESP32C6 | 160 MHz   | 320 KiB | 4 MiB | (https://registry.platformio.org/search?q=espidf&t=tool) | (https://docs.platformio.org/en/latest/boards/espressif32/esp32-c6-devkitm-1.html#debugging) |

但是无论我们使用 Wizard 向导选择 `esp32-c6-devkitc-1` 还是 `esp32-c6-devkitm-1` 作为模板,都无法创建,提示:

> Processing firebeetle2-esp32c6-demo (board: esp32-c6-devkitc-1; framework: espidf; platform: platformio/espressif32@5.4.0) UnknownBoard: Unknown board ID 'esp32-c6-devkitc-1'

查看 esphome 官方代码,已经支持 esp32c6 芯片了,再继续搜索,找到最新的一次提交:(https://github.com/esphome/esphome/pull/6323),发现需要指定使用新版的 Platformio(ESP32-C6 需要 PIO 版本最低为 6.4,目前最新为 6.6),但是目前配置文件创建向导 wizard 还不直接支持,因此我们可以选一个相近的同样采用 RISC-V 核心的 ESP32-C3,然后手动修改,配置如上文。关于 (https://esphome.io/components/esp32.html#esp32-platform) 的介绍:

- **platform_version** (*Optional*, string): The version of the (https://github.com/platformio/platform-espressif32/releases/) package to use.
- **version** (*Optional*, string): The base framework version number to use, from (https://github.com/espressif/arduino-esp32/releases). Defaults to `recommended`. Additional values are:

当前工具链版本如下, 可以看到使用的版本为4.4.6:

```shell
HARDWARE: ESP32C6 160MHz, 512KB RAM, 8MB Flash
- framework-espidf @ 3.40406.240122 (4.4.6)
- tool-cmake @ 3.16.4
- tool-ninja @ 1.7.1
- tool-riscv32-esp-elf-gdb @ 12.1.0+20221002
- tool-xtensa-esp-elf-gdb @ 12.1.0+20221002
- toolchain-esp32ulp @ 2.35.0-20220830
- toolchain-riscv32-esp @ 13.2.0+20230928
```

查看 ESP-IDF 版本:https://registry.platformio.org/tools/platformio/framework-espidf/versions

## 3.2 修复 logger 组件

当使用 ESP-IDF 5.1.2 和 PIO 6.5.0 时编译通过,但是升级到最新的 5.2.1 和 6.6.0 后,报错 logger uart。有人遇到相似的情况,具体见 ESPHome PR#6487:(https://github.com/esphome/esphome/pull/6487)

由于此 PR 还未被合并到官方仓库,我们可以借用 external_components 来支持,详细的用法请移步:https://esphome.io/components/external_components.html

```yaml
# Enable logging
logger:

external_components:
- source:
      type: git
      url: https://github.com/luar123/esphome
      ref: fix_logger
    components: [ logger ]
```

## 3.3 报错 Refusing to overwrite

编译固件时报错:

> A fatal error occurred: Contents of segment at SHA256 digest offset 0xb0 are not all zero. Refusing to overwrite.

```shell
cd /home/pi/esphome_config/.esphome/build/firebeetle2-esp32c6-demo/
pio run -t menuconfig
# 修改 Serial flasher config 的 Flash size 为 4MB

## 其他
# ESP32 的编译工具链较大,约数G,必要时可以挂代理。
# 查看已安装包
pio pkg list
# 查询无用 PIO 数据
pio system prune --dry-run
# 清理无用 PIO 数据
pio system prune
```

## !(https://s2.loli.net/2024/04/23/oCN2zV3YHDkBUSw.png)

## 3.4 WSL2 使用 USB 设备

这部分可以参考微软官方文档:(https://learn.microsoft.com/zh-cn/windows/wsl/connect-usb)

如果使用物理机编译上传固件直接连接即可,但是由于我使用的是 Windows11 + WSL2(使用 (https://github.com/bostrot/wsl2-distro-manager) + Docker Hub Debian Bookworm 镜像),如果想要给 ESP32-C6 烧录固件,需要转发宿主机的 USB 使用,和我们常用的方式不同,不需要在客户机上安装 usbip。以下宿主机称为 host,wsl 称为 wsl。方法如下:

```shell
## host 安装 usbip
# 可以从此处下载并安装:https://github.moeyy.xyz/https://github.com/dorssel/usbipd-win/releases/download/v4.1.0/usbipd-win_4.1.0.msi

## host 更新 wsl 内核,重启生效,以下于 PowerShell 中运行
wsl --update --inbox
wsl --shutdown

# host 查看可用 USB 设备并进行转发
usbipd list
usbipd bind --busid 3-1
usbipd list # 验证已转发共享 (Shared)
usbipd detach --busid <busid> # 断开 USB 设备
```

!(https://s2.loli.net/2024/04/23/KvYZ2hMFNsOaGju.png)

接下来我们再配置 wsl,由于我用的精简版 Debian,需要进行一些额外的安装设置:

```shell
## 【WSL2 Debian】加速 git,使用国内镜像
cat << _EOF_ > $HOME/.gitconfig

#
      insteadOf = https://github.com/
_EOF_

## 【WSL2】设置 locale,选择 97,314,具体移步 https://wiki.debian.org/Locale
sudo apt install locales usbutils
sudo dpkg-reconfigure locales

## 【WSL2】设置当前用户(pi)的串口设备读写权限,重新登录生效,注意填写正确的串口设备号
sudo usermod -a -G dialout pi
sudo chown -R root:dialout /dev/ttyACM0
sudo chmod 664 /dev/ttyACM0

```

# 4、小结

至此我们可以正常使用 ESPHome 为 ESP32-C6 编译固件,后续可以测试板载蓝牙、使用 IO0 读取电池电压等功能。
页: [1]
查看完整版本: 基于ESPHome的3DP舱内控制系统(1): 荆棘满途之FireBeetle2初始配置