警告

This document is not updated for ESP32C5 yet, so some of the content may not be correct.

This warning was automatically inserted due to the source file being in the add_warnings_pages list.

OpenThread

[English]

OpenThread 是在 802.15.4 MAC 层上运行的 IP 协议栈,支持 mesh 网络,具有低功耗特性。

OpenThread 协议栈运行模式

在乐鑫的芯片上,OpenThread 可按以下模式运行:

独立节点模式

在此模式下,完整的 OpenThread 协议栈及其应用层在同一芯片上运行,适用于支持 15.4 无线通信协议的芯片,如 ESP32-H2, ESP32-C6。

无线协处理器 (RCP) 模式

在此模式下,芯片通过连接到运行 OpenThread IP 协议栈的另一个主机,代表主机发送和接收 15.4 数据包。该模式适用于支持 15.4 无线通信协议的芯片,如 ESP32-H2, ESP32-C6。对于芯片和主机之间的通信方式,目前 ESP-IDF 支持 SPI 或 UART。考虑到传输延迟,建议使用 SPI。

OpenThread 主机模式

在此模式下,不支持 15.4 无线通信协议的芯片可以连接到 RCP,并在主机模式下运行 OpenThread。这种模式支持在 Wi-Fi 芯片上(如 ESP32、ESP32-S2、ESP32-S3 和 ESP32-C3 等)运行 OpenThread。下图展示了设备在不同模式下的工作方式:

OpenThread 设备模式

编写 OpenThread 应用程序

要学习编写 OpenThread 应用程序,可以从 OpenThread 应用示例 openthread/ot_cli 开始。该示例中展示了简单的 OpenThread 网络组网流程,以及在 Openthread 网络上,如何实现基于套接字的服务器和客户端之间的简单通信。

初始化 OpenThread 协议栈所需的准备

  • s1.1: 主任务调用 esp_vfs_eventfd_register(),初始化 eventfd 虚拟文件系统。eventfd 文件系统用于实现 OpenThread 协议栈中的任务通知。

  • s1.2: 主任务调用 nvs_flash_init() 初始化 NVS,即 Thread 网络数据的存储位置。

  • s1.3: 可选。主任务调用 esp_netif_init(),为 Thread 创建网络接口。

  • s1.4: 主任务调用 esp_event_loop_create() 创建系统事件任务,并初始化应用程序事件的回调函数。

OpenThread 协议栈初始化

OpenThread 网络接口初始化

以下为 可选 步骤,仅在应用程序需为 Thread 创建网络接口时使用。

OpenThread 主循环

  • s4.3:调用 esp_openthread_launch_mainloop() 启动 OpenThread 主循环。注意,OpenThread 主循环属于忙等循环,仅在 OpenThread 协议栈终止后返回。

调用 OpenThread API

OpenThread API 非线程安全。当从其他任务中调用 OpenThread API 时,请确保以 esp_openthread_lock_acquire() 获取锁,并在之后以 esp_openthread_lock_release() 释放锁。

卸载 Openthread 协议栈

要在应用程序中卸载 OpenThread 协议栈,请遵循以下步骤:

OpenThread 宏定义

在 OpenThread 协议栈中,定义宏来进行功能启用以及参数配置是常见行为。在实际使用中,用户可以通过定义宏的值来启用/禁用相关功能和修改参数。乐鑫提供以下方式来进行 OpenThread 宏定义:

  • 使用配置菜单配置 (menuconfig):部分宏已经映射到 Kconfig 文件,可通过 idf.py menuconfig Component config OpenThread 启用/关闭相应功能,并配置相关参数。

  • 使用用户自定义头文件配置:用户可编写头文件,并启用 idf.py menuconfig Component config OpenThread Thread Extensioned Features Use a header file defined by customer 来应用自定义头文件。自定义头文件的优先级将仅次于配置菜单。

  • 使用 openthread-core-esp32x-xxx-config.h 的配置:部分宏在 OpenThread private 头文件中已经设置默认值,暂不支持通过 menuconfig 修改,但可以通过用户自定义头文件修改。

  • 使用 OpenThread 协议栈默认配置:对于其他宏,OpenThread 协议栈在定义时已设置默认值。

备注

以上四种配置方式,优先级由高到低为:配置菜单 → 用户自定义头文件 → openthread-core-esp32x-xxx-config.h → OpenThread 协议栈默认配置

OpenThread 边界路由器

OpenThread 边界路由器连接了 Thread 网络和其他 IP 网络,提供 IPv6 连通性、服务注册和委托功能。

要在 ESP 芯片上启用 OpenThread 边界路由器,需要将 RCP 连接到具备 Wi-Fi 功能的芯片上,如 ESP32。

在初始化过程中,调用 esp_openthread_border_router_init() 会启用所有边界路由功能。

要了解更多有关边界路由器的详细信息,请参阅 openthread/ot_br 示例和其中的 README 文件。


此文档对您有帮助吗?