diff --git a/components/openthread/CMakeLists.txt b/components/openthread/CMakeLists.txt index 2a018a6de0..455b346924 100644 --- a/components/openthread/CMakeLists.txt +++ b/components/openthread/CMakeLists.txt @@ -149,6 +149,11 @@ if(CONFIG_OPENTHREAD_ENABLED) "src/port/esp_openthread_sleep.c") endif() + if(NOT CONFIG_OPENTHREAD_PLATFORM_MSGPOOL_MANAGEMENT) + list(APPEND exclude_srcs + "src/port/esp_openthread_messagepool.c") + endif() + if(CONFIG_OPENTHREAD_FTD) set(device_type "OPENTHREAD_FTD=1") elseif(CONFIG_OPENTHREAD_MTD) diff --git a/components/openthread/Kconfig b/components/openthread/Kconfig index 51af2e36ec..1742ccd239 100644 --- a/components/openthread/Kconfig +++ b/components/openthread/Kconfig @@ -207,11 +207,19 @@ menu "OpenThread" help Select this option to enable border router features in OpenThread. + config OPENTHREAD_PLATFORM_MSGPOOL_MANAGEMENT + bool 'Allocate message pool buffer from PSRAM' + depends on OPENTHREAD_ENABLED && (SPIRAM_USE_CAPS_ALLOC || SPIRAM_USE_MALLOC) + default n + help + If enabled, the message pool is managed by platform defined logic. + config OPENTHREAD_NUM_MESSAGE_BUFFERS int "The number of openthread message buffers" depends on OPENTHREAD_ENABLED default 65 - range 50 100 + range 10 100 if !OPENTHREAD_PLATFORM_MSGPOOL_MANAGEMENT + range 10 8191 if OPENTHREAD_PLATFORM_MSGPOOL_MANAGEMENT config OPENTHREAD_DNS64_CLIENT bool "Use dns64 client" diff --git a/components/openthread/private_include/esp_openthread_flash.h b/components/openthread/private_include/esp_openthread_flash.h deleted file mode 100644 index d6ba1467c6..0000000000 --- a/components/openthread/private_include/esp_openthread_flash.h +++ /dev/null @@ -1,25 +0,0 @@ -/* - * SPDX-FileCopyrightText: 2021-2022 Espressif Systems (Shanghai) CO LTD - * - * SPDX-License-Identifier: Apache-2.0 - */ - -#pragma once - -#include "esp_partition.h" - -#ifdef __cplusplus -extern "C" { -#endif - -/** - * @brief Set the partition to store OpenThread dataset. - * - * @param[in] partition The storage partition. - * - */ -void esp_openthread_flash_set_partition(const esp_partition_t *partition); - -#ifdef __cplusplus -} -#endif diff --git a/components/openthread/private_include/openthread-core-esp32x-ftd-config.h b/components/openthread/private_include/openthread-core-esp32x-ftd-config.h index 14479dac73..166edab9aa 100644 --- a/components/openthread/private_include/openthread-core-esp32x-ftd-config.h +++ b/components/openthread/private_include/openthread-core-esp32x-ftd-config.h @@ -517,4 +517,23 @@ #define OPENTHREAD_CONFIG_OPERATIONAL_DATASET_AUTO_INIT 1 #endif + +/** + * + * Define as 1 to enable support for allocating message pool buffer in PSRAM + * + */ +#if CONFIG_OPENTHREAD_PLATFORM_MSGPOOL_MANAGEMENT + +/** + * @def OPENTHREAD_CONFIG_PLATFORM_MESSAGE_MANAGEMENT + * + * The message pool is managed by platform defined logic when this flag is set. + * This feature would typically be used when operating in a multi-threaded system + * and multiple threads need to access the message pool. + * + */ +#define OPENTHREAD_CONFIG_PLATFORM_MESSAGE_MANAGEMENT 1 +#endif + #define OPENTHREAD_FTD 1 diff --git a/components/openthread/src/esp_openthread_platform.cpp b/components/openthread/src/esp_openthread_platform.cpp index 24b39b6531..fbeba5b2b8 100644 --- a/components/openthread/src/esp_openthread_platform.cpp +++ b/components/openthread/src/esp_openthread_platform.cpp @@ -11,7 +11,6 @@ #include "esp_log.h" #include "esp_openthread_alarm.h" #include "esp_openthread_common_macro.h" -#include "esp_openthread_flash.h" #include "esp_openthread_lock.h" #include "esp_openthread_radio.h" #include "esp_openthread_spi_slave.h" diff --git a/components/openthread/src/port/esp_openthread_flash.c b/components/openthread/src/port/esp_openthread_flash.c deleted file mode 100644 index e9e79bd030..0000000000 --- a/components/openthread/src/port/esp_openthread_flash.c +++ /dev/null @@ -1,65 +0,0 @@ -/* - * SPDX-FileCopyrightText: 2021-2022 Espressif Systems (Shanghai) CO LTD - * - * SPDX-License-Identifier: Apache-2.0 - */ - -#include "esp_openthread_flash.h" -#include "esp_partition.h" -#include "openthread/instance.h" -#include "openthread/platform/flash.h" -#include "openthread/platform/settings.h" - -#define ESP_OT_FLASH_PAGE_NUM 2 -#define ESP_OT_FLASH_PAGE_SIZE 4096 - -static const esp_partition_t *s_ot_partition = NULL; - -void esp_openthread_flash_set_partition(const esp_partition_t *partition) -{ - s_ot_partition = partition; -} - -void otPlatFlashInit(otInstance *instance) -{ - assert(s_ot_partition != NULL); - assert(s_ot_partition->size >= otPlatFlashGetSwapSize(instance)); -} - -uint32_t otPlatFlashGetSwapSize(otInstance *instance) -{ - return ESP_OT_FLASH_PAGE_SIZE; -} - -void otPlatFlashErase(otInstance *instance, uint8_t index) -{ - uint32_t address = ESP_OT_FLASH_PAGE_SIZE * (index != 0); - uint32_t size = ESP_OT_FLASH_PAGE_SIZE; - esp_err_t err = ESP_OK; - - err = esp_partition_erase_range(s_ot_partition, address, size); - - assert(err == ESP_OK); -} - -void otPlatFlashRead(otInstance *instance, uint8_t index, uint32_t offset, void *data, uint32_t size) -{ - esp_err_t err = ESP_OK; - - offset += ESP_OT_FLASH_PAGE_SIZE * (index != 0); - - err = esp_partition_read(s_ot_partition, offset, data, size); - - assert(err == ESP_OK); -} - -void otPlatFlashWrite(otInstance *instance, uint8_t index, uint32_t offset, const void *data, uint32_t size) -{ - esp_err_t err = ESP_OK; - - offset += ESP_OT_FLASH_PAGE_SIZE * (index != 0); - - err = esp_partition_write(s_ot_partition, offset, data, size); - - assert(err == ESP_OK); -} diff --git a/components/openthread/src/port/esp_openthread_messagepool.c b/components/openthread/src/port/esp_openthread_messagepool.c new file mode 100644 index 0000000000..0e0794dc8a --- /dev/null +++ b/components/openthread/src/port/esp_openthread_messagepool.c @@ -0,0 +1,52 @@ +/* + * SPDX-FileCopyrightText: 2023 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include "openthread-core-config.h" +#include "esp_openthread_common_macro.h" +#include "esp_err.h" +#include "esp_log.h" +#include "esp_heap_caps.h" +#include "openthread/instance.h" +#include "openthread/platform/messagepool.h" + +int s_buffer_pool_head = -1; +otMessageBuffer **s_buffer_pool_pointer = NULL; + +void otPlatMessagePoolInit(otInstance *aInstance, uint16_t aMinNumFreeBuffers, size_t aBufferSize) +{ + otMessageBuffer *buffer_pool = (otMessageBuffer *)heap_caps_calloc(aMinNumFreeBuffers, aBufferSize, MALLOC_CAP_SPIRAM); + s_buffer_pool_pointer = (otMessageBuffer **)heap_caps_calloc(aMinNumFreeBuffers, sizeof(otMessageBuffer **), MALLOC_CAP_SPIRAM); + if (buffer_pool == NULL || s_buffer_pool_pointer == NULL) { + ESP_LOGE(OT_PLAT_LOG_TAG, "Failed to create message buffer pool"); + assert(false); + } + for (uint16_t i = 0; i < aMinNumFreeBuffers; i++) { + s_buffer_pool_pointer[i] = buffer_pool + i * aBufferSize / sizeof(otMessageBuffer); + } + s_buffer_pool_head = aMinNumFreeBuffers - 1; + ESP_LOGI(OT_PLAT_LOG_TAG, "Create message buffer pool successfully, size %d", aMinNumFreeBuffers*aBufferSize); +} + +otMessageBuffer *otPlatMessagePoolNew(otInstance *aInstance) +{ + otMessageBuffer *ret = NULL; + if (s_buffer_pool_head >= 0) { + ret = s_buffer_pool_pointer[s_buffer_pool_head]; + s_buffer_pool_head--; + } + return ret; +} + +void otPlatMessagePoolFree(otInstance *aInstance, otMessageBuffer *aBuffer) +{ + s_buffer_pool_head++; + s_buffer_pool_pointer[s_buffer_pool_head] = aBuffer; +} + +uint16_t otPlatMessagePoolNumFreeBuffers(otInstance *aInstance) +{ + return s_buffer_pool_head + 1; +} diff --git a/docs/en/api-guides/performance/ram-usage.rst b/docs/en/api-guides/performance/ram-usage.rst index 8621454c2c..33b89d4275 100644 --- a/docs/en/api-guides/performance/ram-usage.rst +++ b/docs/en/api-guides/performance/ram-usage.rst @@ -41,6 +41,7 @@ To minimize static memory use: - Constant data can be stored in flash memory instead of RAM, thus it is recommended to declare structures, buffers, or other variables as ``const``. This approach may require modifying firmware functions to accept ``const *`` arguments instead of mutable pointer arguments. These changes can also help reduce the stack usage of certain functions. :SOC_BT_SUPPORTED: - If using Bluedroid, setting the option :ref:`CONFIG_BT_BLE_DYNAMIC_ENV_MEMORY` will cause Bluedroid to allocate memory on initialization and free it on deinitialization. This does not necessarily reduce the peak memory usage, but changes it from static memory usage to runtime memory usage. + - If using OpenThread, enabling the option :ref:`CONFIG_OPENTHREAD_PLATFORM_MSGPOOL_MANAGEMENT` will cause OpenThread to allocate message pool buffers from PSRAM, which will reduce static memory use. .. _optimize-stack-sizes: diff --git a/docs/zh_CN/api-guides/performance/ram-usage.rst b/docs/zh_CN/api-guides/performance/ram-usage.rst index 9db06886fe..23c9c14b19 100644 --- a/docs/zh_CN/api-guides/performance/ram-usage.rst +++ b/docs/zh_CN/api-guides/performance/ram-usage.rst @@ -41,6 +41,7 @@ ESP-IDF 包含一系列堆 API,可以在运行时测量空闲堆内存,请 - 由于常量数据可以存储在 flash 中,不占用 RAM,建议尽量将结构体、缓冲区或其他变量声明为 ``const``。为此,可能需要修改固件参数,使其接收 ``const *`` 参数而非可变指针参数。以上更改还可以减少某些函数的栈内存使用。 :SOC_BT_SUPPORTED: - 若使用 Bluedroid,请设置 :ref:`CONFIG_BT_BLE_DYNAMIC_ENV_MEMORY` 选项,Bluedroid 将在初始化时分配内存,并在去初始化时释放内存。这并不一定会降低内存使用峰值,但可以将使用静态内存改为运行时使用动态内存。 + - 若使用 OpenThread,请设置 :ref:`CONFIG_OPENTHREAD_PLATFORM_MSGPOOL_MANAGEMENT` 选项,OpenThread 将从外部 PSRAM 中分配消息池缓冲区,从而减少对内部静态内存的使用。 .. _optimize-stack-sizes: