mirror of
https://github.com/esphome/esphome.git
synced 2025-01-13 08:03:18 +01:00
boot modem with minimal delay
This commit is contained in:
parent
4516953cd4
commit
feff0d541c
2 changed files with 40 additions and 42 deletions
|
@ -19,12 +19,13 @@
|
||||||
uint32_t time_info_print = 0;
|
uint32_t time_info_print = 0;
|
||||||
uint32_t time_hard_reset_modem = 0;
|
uint32_t time_hard_reset_modem = 0;
|
||||||
uint32_t time_check_rssi = 0;
|
uint32_t time_check_rssi = 0;
|
||||||
uint32_t time_push_pwrkey = 0;
|
uint32_t time_check_pwrkey = 0;
|
||||||
uint32_t time_turn_on_modem = 0;
|
uint32_t time_turn_on_modem = 0;
|
||||||
|
|
||||||
#define TIME_TO_NEXT_HARD_RESET 30000
|
#define TIME_TO_NEXT_HARD_RESET 30000
|
||||||
#define TIME_TO_START_MODEM 9000
|
#define TIME_TO_START_MODEM 9000
|
||||||
#define TIME_CHECK_REGISTRATION_IN_NETWORK 1000
|
#define TIME_CHECK_REGISTRATION_IN_NETWORK 1000
|
||||||
|
#define TIME_CHECK_START_MODEM 1000
|
||||||
|
|
||||||
namespace esphome {
|
namespace esphome {
|
||||||
namespace modem {
|
namespace modem {
|
||||||
|
@ -61,8 +62,8 @@ void ModemComponent::setup() {
|
||||||
}
|
}
|
||||||
this->reset_pin_->setup();
|
this->reset_pin_->setup();
|
||||||
|
|
||||||
this->turn_on_modem();
|
// this->turn_on_modem();
|
||||||
this->use_pwrkey();
|
// this->use_pwrkey();
|
||||||
// esp_modem_hard_reset();
|
// esp_modem_hard_reset();
|
||||||
|
|
||||||
if (esp_reset_reason() != ESP_RST_DEEPSLEEP) {
|
if (esp_reset_reason() != ESP_RST_DEEPSLEEP) {
|
||||||
|
@ -112,6 +113,9 @@ void ModemComponent::loop() {
|
||||||
switch (this->state_) {
|
switch (this->state_) {
|
||||||
case ModemComponentState::STOPPED:
|
case ModemComponentState::STOPPED:
|
||||||
this->turn_on_modem();
|
this->turn_on_modem();
|
||||||
|
this->turn_on_pwrkey();
|
||||||
|
|
||||||
|
|
||||||
// if (time_check_rssi + TIME_TO_START_MODEM < now) {
|
// if (time_check_rssi + TIME_TO_START_MODEM < now) {
|
||||||
// time_check_rssi = now;
|
// time_check_rssi = now;
|
||||||
// // this->dce->set_command_mode();
|
// // this->dce->set_command_mode();
|
||||||
|
@ -128,10 +132,16 @@ void ModemComponent::loop() {
|
||||||
// }
|
// }
|
||||||
// }
|
// }
|
||||||
break;
|
break;
|
||||||
case ModemComponentState::TURNING_ON:
|
case ModemComponentState::TURNING_ON: //time_check_pwrkey
|
||||||
if (this->dce->sync() != esp_modem::command_result::OK){
|
if (time_check_pwrkey + TIME_CHECK_START_MODEM < now){
|
||||||
ESP_LOGD(TAG, "sync OK");
|
time_check_pwrkey = now;
|
||||||
this->state_ = ModemComponentState::REGISTRATION_IN_NETWORK;
|
if (this->dce->sync() == esp_modem::command_result::OK){
|
||||||
|
ESP_LOGD(TAG, "sync OK");
|
||||||
|
this->turn_off_pwrkey();
|
||||||
|
this->state_ = ModemComponentState::REGISTRATION_IN_NETWORK;
|
||||||
|
} else {
|
||||||
|
ESP_LOGD(TAG, "Wait sync");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case ModemComponentState::REGISTRATION_IN_NETWORK:
|
case ModemComponentState::REGISTRATION_IN_NETWORK:
|
||||||
|
@ -169,44 +179,31 @@ void ModemComponent::loop() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ModemComponent::turn_on_modem() {
|
void ModemComponent::turn_on_modem() {
|
||||||
if (this->power_pin_) {
|
this->power_pin_->digital_write(true);
|
||||||
this->power_pin_->digital_write(true);
|
time_turn_on_modem = millis();
|
||||||
time_turn_on_modem = millis();
|
this->state_ = ModemComponentState::TURNING_ON;
|
||||||
vTaskDelay(pdMS_TO_TICKS(1900)); // NOLINT
|
ESP_LOGD(TAG, "modem turn on");
|
||||||
this->state_ = ModemComponentState::TURNING_ON;
|
|
||||||
ESP_LOGD(TAG, "modem is on");
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
ESP_LOGD(TAG, "failed to turn on modem because power_pin_ is not initialized");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
// wait no more than 1.9 sec for signs of life to appear
|
// wait no more than 1.9 sec for signs of life to appear
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ModemComponent::turn_off_modem() {
|
void ModemComponent::turn_off_modem() {
|
||||||
if (this->power_pin_) {
|
this->power_pin_->digital_write(true);
|
||||||
this->power_pin_->digital_write(true);
|
ESP_LOGD(TAG, "modem turn off");
|
||||||
vTaskDelay(pdMS_TO_TICKS(1900)); // NOLINT
|
|
||||||
ESP_LOGD(TAG, "modem is off");
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
ESP_LOGD(TAG, "failed to turn off modem because power_pin_ is not initialized");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
// wait no more than 1.9 sec for signs of life to appear
|
// wait no more than 1.9 sec for signs of life to appear
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ModemComponent::use_pwrkey() {
|
void ModemComponent::turn_on_pwrkey() {
|
||||||
if (this->pwrkey_pin_) {
|
ESP_LOGD(TAG, "pwrkey turn on");
|
||||||
ESP_LOGD(TAG, "pwrkey used");
|
this->pwrkey_pin_->digital_write(false);
|
||||||
this->pwrkey_pin_->digital_write(false);
|
// delay 1050
|
||||||
vTaskDelay(pdMS_TO_TICKS(1050)); // NOLINT
|
|
||||||
this->pwrkey_pin_->digital_write(true);
|
//vTaskDelay(pdMS_TO_TICKS(500)); // NOLINT
|
||||||
} else {
|
}
|
||||||
ESP_LOGD(TAG, "failed to press button because pwrkey_pin_ is not initialized");
|
|
||||||
}
|
void ModemComponent::turn_off_pwrkey() {
|
||||||
return true;
|
ESP_LOGD(TAG, "pwrkey turn off");
|
||||||
|
this->pwrkey_pin_->digital_write(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ModemComponent::reset_modem() {
|
void ModemComponent::reset_modem() {
|
||||||
|
|
|
@ -66,9 +66,10 @@ class ModemComponent : public Component {
|
||||||
protected:
|
protected:
|
||||||
static void got_ip_event_handler(void *arg, esp_event_base_t event_base, int32_t event_id, void *event_data);
|
static void got_ip_event_handler(void *arg, esp_event_base_t event_base, int32_t event_id, void *event_data);
|
||||||
|
|
||||||
bool turn_on_modem();
|
void turn_on_modem();
|
||||||
bool turn_off_modem();
|
void turn_off_modem();
|
||||||
bool use_pwrkey();
|
void turn_on_pwrkey();
|
||||||
|
void turn_off_pwrkey();
|
||||||
void start_connect_();
|
void start_connect_();
|
||||||
void reset_modem();
|
void reset_modem();
|
||||||
int get_rssi();
|
int get_rssi();
|
||||||
|
|
Loading…
Reference in a new issue