From 4516953cd450549276c699984a41330b1ca8b613 Mon Sep 17 00:00:00 2001 From: Chelios Date: Wed, 9 Oct 2024 22:18:53 +0300 Subject: [PATCH] registration in network with minimal delays --- esphome/components/modem/__init__.py | 1 + esphome/components/modem/modem_component.cpp | 53 ++++++++++++++------ esphome/components/modem/modem_component.h | 6 ++- 3 files changed, 43 insertions(+), 17 deletions(-) diff --git a/esphome/components/modem/__init__.py b/esphome/components/modem/__init__.py index d4846b459c..9f9b750066 100644 --- a/esphome/components/modem/__init__.py +++ b/esphome/components/modem/__init__.py @@ -99,6 +99,7 @@ async def to_code(config): cg.add_library("WiFi", None) if CORE.using_esp_idf: add_idf_sdkconfig_option("CONFIG_LWIP_PPP_SUPPORT", True) + # add_idf_sdkconfig_option("CONFIG_TASK_WDT_TIMEOUT_S", 10) add_idf_component( name="esp_modem", repo="https://github.com/espressif/esp-protocols.git", diff --git a/esphome/components/modem/modem_component.cpp b/esphome/components/modem/modem_component.cpp index 848ce5e61c..b9c8c7cb45 100644 --- a/esphome/components/modem/modem_component.cpp +++ b/esphome/components/modem/modem_component.cpp @@ -4,11 +4,13 @@ #include "esphome/core/util.h" #include "esphome/core/application.h" -#include "esp_modem_c_api_types.h" -#include "esp_netif_ppp.h" #ifdef USE_ESP32 +#include "esp_modem_c_api_types.h" +#include "esp_netif_ppp.h" +#include "cxx_include/esp_modem_types.hpp" + #include #include "driver/gpio.h" #include @@ -22,6 +24,7 @@ uint32_t time_turn_on_modem = 0; #define TIME_TO_NEXT_HARD_RESET 30000 #define TIME_TO_START_MODEM 9000 +#define TIME_CHECK_REGISTRATION_IN_NETWORK 1000 namespace esphome { namespace modem { @@ -108,35 +111,50 @@ void ModemComponent::loop() { const uint32_t now = millis(); switch (this->state_) { case ModemComponentState::STOPPED: - if (time_check_rssi + TIME_TO_START_MODEM < now) { + this->turn_on_modem(); + // if (time_check_rssi + TIME_TO_START_MODEM < now) { + // time_check_rssi = now; + // // this->dce->set_command_mode(); + // if (get_rssi()) { + // ESP_LOGD(TAG, "Starting modem connection"); + // ESP_LOGD(TAG, "SIgnal quality: rssi=%d", get_rssi()); + // this->state_ = ModemComponentState::CONNECTING; + // this->dce->set_data(); + // // this->start_connect_(); + // } + // if (time_hard_reset_modem + TIME_TO_NEXT_HARD_RESET < now) { + // time_hard_reset_modem = now; + // reset_modem(); + // } + // } + break; + case ModemComponentState::TURNING_ON: + if (this->dce->sync() != esp_modem::command_result::OK){ + ESP_LOGD(TAG, "sync OK"); + this->state_ = ModemComponentState::REGISTRATION_IN_NETWORK; + } + break; + case ModemComponentState::REGISTRATION_IN_NETWORK: + if (time_check_rssi + TIME_CHECK_REGISTRATION_IN_NETWORK < now){ time_check_rssi = now; - // this->dce->set_command_mode(); if (get_rssi()) { ESP_LOGD(TAG, "Starting modem connection"); ESP_LOGD(TAG, "SIgnal quality: rssi=%d", get_rssi()); this->state_ = ModemComponentState::CONNECTING; this->dce->set_data(); // this->start_connect_(); - } - if (time_hard_reset_modem + TIME_TO_NEXT_HARD_RESET < now) { - time_hard_reset_modem = now; - reset_modem(); + } else { + ESP_LOGD(TAG, "Wait RSSI"); } } break; - case ModemComponentState::RESETTING: - break; - case ModemComponentState::TURNING_ON: - - break; - case ModemComponentState::TURNING_OFF: - break; case ModemComponentState::CONNECTING: break; case ModemComponentState::CONNECTED: if (time_info_print < now) { // ESP_LOGI(TAG, "voltage %dV.", get_modem_voltage() / 1000); if (esp_netif_is_netif_up(this->modem_netif_)) { + ESP_LOGD(TAG, "esp_netif_is_netif_UP"); } else { ESP_LOGD(TAG, "esp_netif_is_netif_DOWN"); @@ -144,6 +162,10 @@ void ModemComponent::loop() { time_info_print = now + 5000; } break; + case ModemComponentState::RESETTING: + break; + case ModemComponentState::TURNING_OFF: + break; } } @@ -152,6 +174,7 @@ bool ModemComponent::turn_on_modem() { this->power_pin_->digital_write(true); time_turn_on_modem = millis(); vTaskDelay(pdMS_TO_TICKS(1900)); // NOLINT + this->state_ = ModemComponentState::TURNING_ON; ESP_LOGD(TAG, "modem is on"); return true; } else { diff --git a/esphome/components/modem/modem_component.h b/esphome/components/modem/modem_component.h index cf98eb4c33..7d0d81da7f 100644 --- a/esphome/components/modem/modem_component.h +++ b/esphome/components/modem/modem_component.h @@ -6,6 +6,7 @@ #include "esphome/core/hal.h" #include "esphome/components/network/ip_address.h" + #ifdef USE_ESP32 using esphome::esp_log_printf_; @@ -26,11 +27,12 @@ enum ModemType { enum class ModemComponentState { STOPPED, - RESETTING, TURNING_ON, - TURNING_OFF, + REGISTRATION_IN_NETWORK, CONNECTING, CONNECTED, + RESETTING, + TURNING_OFF, }; class ModemComponent : public Component {