2021-10-20 16:48:09 +08:00
|
|
|
/*
|
2024-01-29 17:50:48 +08:00
|
|
|
* SPDX-FileCopyrightText: 2021-2024 Espressif Systems (Shanghai) CO LTD
|
2021-10-20 16:48:09 +08:00
|
|
|
*
|
2021-12-21 16:53:20 +08:00
|
|
|
* SPDX-License-Identifier: CC0-1.0
|
2021-10-20 16:48:09 +08:00
|
|
|
*
|
|
|
|
* OpenThread Command Line Example
|
|
|
|
*
|
|
|
|
* This example code is in the Public Domain (or CC0 licensed, at your option.)
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, this
|
|
|
|
* software is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
|
|
|
|
* CONDITIONS OF ANY KIND, either express or implied.
|
2021-07-30 15:55:37 +08:00
|
|
|
*/
|
2021-04-02 14:49:49 +08:00
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <unistd.h>
|
2021-12-21 16:53:20 +08:00
|
|
|
#include <string.h>
|
2021-04-02 14:49:49 +08:00
|
|
|
|
2024-01-29 17:50:48 +08:00
|
|
|
#include "sdkconfig.h"
|
2021-04-02 14:49:49 +08:00
|
|
|
#include "esp_err.h"
|
2021-05-19 11:52:51 +08:00
|
|
|
#include "esp_event.h"
|
2021-04-02 14:49:49 +08:00
|
|
|
#include "esp_log.h"
|
|
|
|
#include "esp_netif.h"
|
2021-06-08 15:49:05 +08:00
|
|
|
#include "esp_netif_types.h"
|
2021-04-02 14:49:49 +08:00
|
|
|
#include "esp_openthread.h"
|
2021-09-27 12:10:00 +08:00
|
|
|
#include "esp_openthread_cli.h"
|
2021-04-02 14:49:49 +08:00
|
|
|
#include "esp_openthread_lock.h"
|
2021-05-19 11:52:51 +08:00
|
|
|
#include "esp_openthread_netif_glue.h"
|
2021-04-02 14:49:49 +08:00
|
|
|
#include "esp_openthread_types.h"
|
2021-07-09 12:18:41 +08:00
|
|
|
#include "esp_ot_config.h"
|
2021-03-22 15:44:58 +08:00
|
|
|
#include "esp_vfs_eventfd.h"
|
2021-04-02 14:49:49 +08:00
|
|
|
#include "driver/uart.h"
|
|
|
|
#include "freertos/FreeRTOS.h"
|
|
|
|
#include "freertos/task.h"
|
|
|
|
#include "hal/uart_types.h"
|
2022-12-19 10:50:08 +08:00
|
|
|
#include "nvs_flash.h"
|
2021-04-02 14:49:49 +08:00
|
|
|
#include "openthread/cli.h"
|
|
|
|
#include "openthread/instance.h"
|
2021-09-23 17:23:38 +08:00
|
|
|
#include "openthread/logging.h"
|
2021-04-02 14:49:49 +08:00
|
|
|
#include "openthread/tasklet.h"
|
|
|
|
|
2024-01-29 17:50:48 +08:00
|
|
|
#if CONFIG_OPENTHREAD_STATE_INDICATOR_ENABLE
|
|
|
|
#include "ot_led_strip.h"
|
|
|
|
#endif
|
|
|
|
|
2021-07-19 16:37:56 +08:00
|
|
|
#if CONFIG_OPENTHREAD_CLI_ESP_EXTENSION
|
2021-05-25 21:13:41 +08:00
|
|
|
#include "esp_ot_cli_extension.h"
|
2021-07-19 16:37:56 +08:00
|
|
|
#endif // CONFIG_OPENTHREAD_CLI_ESP_EXTENSION
|
2021-05-25 21:13:41 +08:00
|
|
|
|
2021-04-02 14:49:49 +08:00
|
|
|
#define TAG "ot_esp_cli"
|
|
|
|
|
2021-06-28 19:20:51 +08:00
|
|
|
static esp_netif_t *init_openthread_netif(const esp_openthread_platform_config_t *config)
|
2021-06-08 15:49:05 +08:00
|
|
|
{
|
|
|
|
esp_netif_config_t cfg = ESP_NETIF_DEFAULT_OPENTHREAD();
|
|
|
|
esp_netif_t *netif = esp_netif_new(&cfg);
|
|
|
|
assert(netif != NULL);
|
2021-06-28 19:20:51 +08:00
|
|
|
ESP_ERROR_CHECK(esp_netif_attach(netif, esp_openthread_netif_glue_init(config)));
|
2021-06-08 15:49:05 +08:00
|
|
|
|
|
|
|
return netif;
|
|
|
|
}
|
|
|
|
|
2021-04-02 14:49:49 +08:00
|
|
|
static void ot_task_worker(void *aContext)
|
|
|
|
{
|
|
|
|
esp_openthread_platform_config_t config = {
|
2021-07-09 12:18:41 +08:00
|
|
|
.radio_config = ESP_OPENTHREAD_DEFAULT_RADIO_CONFIG(),
|
|
|
|
.host_config = ESP_OPENTHREAD_DEFAULT_HOST_CONFIG(),
|
2021-06-28 19:20:51 +08:00
|
|
|
.port_config = ESP_OPENTHREAD_DEFAULT_PORT_CONFIG(),
|
2021-04-02 14:49:49 +08:00
|
|
|
};
|
2021-05-19 11:52:51 +08:00
|
|
|
|
2021-06-08 15:49:05 +08:00
|
|
|
// Initialize the OpenThread stack
|
|
|
|
ESP_ERROR_CHECK(esp_openthread_init(&config));
|
2021-05-19 11:52:51 +08:00
|
|
|
|
2024-01-29 17:50:48 +08:00
|
|
|
#if CONFIG_OPENTHREAD_STATE_INDICATOR_ENABLE
|
|
|
|
ESP_ERROR_CHECK(esp_openthread_state_indicator_init(esp_openthread_get_instance()));
|
|
|
|
#endif
|
|
|
|
|
2022-09-27 14:30:46 +08:00
|
|
|
#if CONFIG_OPENTHREAD_LOG_LEVEL_DYNAMIC
|
2021-09-23 17:23:38 +08:00
|
|
|
// The OpenThread log level directly matches ESP log level
|
|
|
|
(void)otLoggingSetLevel(CONFIG_LOG_DEFAULT_LEVEL);
|
2022-09-27 14:30:46 +08:00
|
|
|
#endif
|
2021-06-08 15:49:05 +08:00
|
|
|
// Initialize the OpenThread cli
|
2023-01-13 22:12:54 +08:00
|
|
|
#if CONFIG_OPENTHREAD_CLI
|
2021-09-27 12:10:00 +08:00
|
|
|
esp_openthread_cli_init();
|
2023-01-13 22:12:54 +08:00
|
|
|
#endif
|
2021-04-02 14:49:49 +08:00
|
|
|
|
2021-07-19 16:37:56 +08:00
|
|
|
esp_netif_t *openthread_netif;
|
2021-06-08 15:49:05 +08:00
|
|
|
// Initialize the esp_netif bindings
|
2021-06-28 19:20:51 +08:00
|
|
|
openthread_netif = init_openthread_netif(&config);
|
2023-02-03 16:27:40 +08:00
|
|
|
esp_netif_set_default_netif(openthread_netif);
|
2021-04-02 14:49:49 +08:00
|
|
|
|
2022-09-27 14:30:46 +08:00
|
|
|
#if CONFIG_OPENTHREAD_CLI_ESP_EXTENSION
|
2021-05-25 21:13:41 +08:00
|
|
|
esp_cli_custom_command_init();
|
2021-07-19 16:37:56 +08:00
|
|
|
#endif // CONFIG_OPENTHREAD_CLI_ESP_EXTENSION
|
2021-04-02 14:49:49 +08:00
|
|
|
|
2021-06-08 15:49:05 +08:00
|
|
|
// Run the main loop
|
2023-01-13 22:12:54 +08:00
|
|
|
#if CONFIG_OPENTHREAD_CLI
|
2021-09-27 12:10:00 +08:00
|
|
|
esp_openthread_cli_create_task();
|
2023-07-31 17:56:49 +08:00
|
|
|
#endif
|
|
|
|
#if CONFIG_OPENTHREAD_AUTO_START
|
|
|
|
otOperationalDatasetTlvs dataset;
|
|
|
|
otError error = otDatasetGetActiveTlvs(esp_openthread_get_instance(), &dataset);
|
|
|
|
ESP_ERROR_CHECK(esp_openthread_auto_start((error == OT_ERROR_NONE) ? &dataset : NULL));
|
2023-01-13 22:12:54 +08:00
|
|
|
#endif
|
2021-06-08 15:49:05 +08:00
|
|
|
esp_openthread_launch_mainloop();
|
|
|
|
|
|
|
|
// Clean up
|
2021-05-19 11:52:51 +08:00
|
|
|
esp_openthread_netif_glue_deinit();
|
2023-12-15 18:35:34 +08:00
|
|
|
esp_netif_destroy(openthread_netif);
|
2021-07-19 16:37:56 +08:00
|
|
|
|
2021-03-22 15:44:58 +08:00
|
|
|
esp_vfs_eventfd_unregister();
|
2021-04-02 14:49:49 +08:00
|
|
|
vTaskDelete(NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
void app_main(void)
|
|
|
|
{
|
2021-06-08 18:12:53 +08:00
|
|
|
// Used eventfds:
|
|
|
|
// * netif
|
2021-07-09 12:18:41 +08:00
|
|
|
// * ot task queue
|
2021-06-08 18:12:53 +08:00
|
|
|
// * radio driver
|
2021-06-08 15:49:05 +08:00
|
|
|
esp_vfs_eventfd_config_t eventfd_config = {
|
2021-07-09 12:18:41 +08:00
|
|
|
.max_fds = 3,
|
2021-06-08 15:49:05 +08:00
|
|
|
};
|
|
|
|
|
2022-12-19 10:50:08 +08:00
|
|
|
ESP_ERROR_CHECK(nvs_flash_init());
|
2021-05-19 11:52:51 +08:00
|
|
|
ESP_ERROR_CHECK(esp_event_loop_create_default());
|
2021-03-22 15:44:58 +08:00
|
|
|
ESP_ERROR_CHECK(esp_netif_init());
|
2021-06-08 15:49:05 +08:00
|
|
|
ESP_ERROR_CHECK(esp_vfs_eventfd_register(&eventfd_config));
|
2021-04-02 14:49:49 +08:00
|
|
|
xTaskCreate(ot_task_worker, "ot_cli_main", 10240, xTaskGetCurrentTaskHandle(), 5, NULL);
|
|
|
|
}
|