Update ebyte_lora_component.cpp

This commit is contained in:
Daniël Koek 2024-10-04 14:42:01 +01:00
parent 6e5983beaf
commit 29ebbedcbf

View file

@ -303,40 +303,38 @@ void EbyteLoraComponent::setup() {
ESP_LOGD(TAG, "Setup success"); ESP_LOGD(TAG, "Setup success");
} }
void EbyteLoraComponent::get_current_config_() { void EbyteLoraComponent::get_current_config_() {
this->set_mode_(CONFIGURATION); if (this->get_mode_() != CONFIGURATION)
this->set_mode_(CONFIGURATION);
if (this->can_send_message_()) { if (this->can_send_message_()) {
uint8_t data[3] = {PROGRAM_CONF, 0x00, 0x08}; uint8_t data[3] = {PROGRAM_CONF, 0x00, 0x08};
this->write_array(data, sizeof(data)); this->write_array(data, sizeof(data));
ESP_LOGD(TAG, "Config info requested"); ESP_LOGD(TAG, "Config info requested");
} else {
ESP_LOGD(TAG, "Config info can't be requested right now, since device is busy");
} }
} }
ModeType EbyteLoraComponent::get_mode_() { ModeType EbyteLoraComponent::get_mode_() {
ModeType internal_mode = MODE_INIT; ModeType internal_mode = MODE_INIT;
if (this->can_send_message_()) if (!this->can_send_message_())
return internal_mode; return internal_mode;
bool pin1 = this->pin_m0_->digital_read(); bool pin1 = this->pin_m0_->digital_read();
bool pin2 = this->pin_m1_->digital_read(); bool pin2 = this->pin_m1_->digital_read();
if (!pin1 && !pin2) { if (!pin1 && !pin2) {
// ESP_LOGD(TAG, "MODE NORMAL!"); // ESP_LOGD(TAG, "MODE NORMAL!");
internal_mode = NORMAL; return NORMAL;
} }
if (pin1 && !pin2) { if (pin1 && !pin2) {
// ESP_LOGD(TAG, "MODE WOR!"); // ESP_LOGD(TAG, "MODE WOR!");
internal_mode = WOR_SEND; return WOR_SEND;
} }
if (!pin1 && pin2) { if (!pin1 && pin2) {
// ESP_LOGD(TAG, "MODE WOR!"); // ESP_LOGD(TAG, "MODE WOR!");
internal_mode = WOR_RECEIVER; return WOR_RECEIVER;
} }
if (pin1 && pin2) { if (pin1 && pin2) {
// ESP_LOGD(TAG, "MODE Conf!"); // ESP_LOGD(TAG, "MODE Conf!");
internal_mode = CONFIGURATION; return CONFIGURATION;
}
if (internal_mode != this->config_mode_) {
ESP_LOGD(TAG, "Modes are not equal, calling the set function!! , checked: %u, expected: %u", internal_mode,
this->config_mode_);
this->set_mode_(internal_mode);
} }
return internal_mode; return internal_mode;
} }
@ -344,35 +342,40 @@ void EbyteLoraComponent::set_mode_(ModeType mode) {
if (this->pin_m0_ == nullptr || this->pin_m1_ == nullptr) { if (this->pin_m0_ == nullptr || this->pin_m1_ == nullptr) {
ESP_LOGD(TAG, "The M0 and M1 pins is not set, this mean that you are connect directly the pins as you need!"); ESP_LOGD(TAG, "The M0 and M1 pins is not set, this mean that you are connect directly the pins as you need!");
return; return;
} else { }
switch (mode) { // no need to do anything if the mode is correct
case NORMAL: if (mode == this->get_mode_()) {
// Mode 0 | normal operation this->config_mode_ = mode;
this->pin_m0_->digital_write(false); ESP_LOGD(TAG, "Mode is already correct");
this->pin_m1_->digital_write(false); return;
ESP_LOGD(TAG, "MODE NORMAL!"); }
break; switch (mode) {
case WOR_SEND: case NORMAL:
this->pin_m0_->digital_write(true); // Mode 0 | normal operation
this->pin_m1_->digital_write(false); this->pin_m0_->digital_write(false);
ESP_LOGD(TAG, "MODE WOR SEND!"); this->pin_m1_->digital_write(false);
break; ESP_LOGD(TAG, "MODE NORMAL!");
case WOR_RECEIVER: break;
// case MODE_2_PROGRAM: case WOR_SEND:
this->pin_m0_->digital_write(false); this->pin_m0_->digital_write(true);
this->pin_m1_->digital_write(true); this->pin_m1_->digital_write(false);
ESP_LOGD(TAG, "MODE RECEIVING!"); ESP_LOGD(TAG, "MODE WOR SEND!");
break; break;
case CONFIGURATION: case WOR_RECEIVER:
// Mode 3 | Setting operation // case MODE_2_PROGRAM:
this->pin_m0_->digital_write(true); this->pin_m0_->digital_write(false);
this->pin_m1_->digital_write(true); this->pin_m1_->digital_write(true);
ESP_LOGD(TAG, "MODE SLEEP and CONFIG!"); ESP_LOGD(TAG, "MODE RECEIVING!");
break; break;
case MODE_INIT: case CONFIGURATION:
ESP_LOGD(TAG, "Don't call this!"); // Mode 3 | Setting operation
break; this->pin_m0_->digital_write(true);
} this->pin_m1_->digital_write(true);
ESP_LOGD(TAG, "MODE SLEEP and CONFIG!");
break;
case MODE_INIT:
ESP_LOGD(TAG, "Don't call this!");
break;
} }
this->config_mode_ = mode; this->config_mode_ = mode;
} }
@ -538,7 +541,7 @@ void EbyteLoraComponent::setup_conf_(std::vector<uint8_t> conf) {
this->current_config_.enable_rssi = (conf[8] >> 7) & 0b1; this->current_config_.enable_rssi = (conf[8] >> 7) & 0b1;
} }
void EbyteLoraComponent::send_data_(bool all) { void EbyteLoraComponent::send_data_(bool all) {
if (this->can_send_message_()) if (!this->can_send_message_())
return; return;
std::vector<uint8_t> data; std::vector<uint8_t> data;
data.push_back(network_id_); data.push_back(network_id_);
@ -579,7 +582,7 @@ void EbyteLoraComponent::send_data_(bool all) {
} }
void EbyteLoraComponent::send_repeater_info_() { void EbyteLoraComponent::send_repeater_info_() {
if (this->can_send_message_()) if (!this->can_send_message_())
return; return;
uint8_t data[3]; uint8_t data[3];
data[0] = REPEATER_INFO; // response data[0] = REPEATER_INFO; // response
@ -589,7 +592,7 @@ void EbyteLoraComponent::send_repeater_info_() {
this->write_array(data, sizeof(data)); this->write_array(data, sizeof(data));
} }
void EbyteLoraComponent::request_repeater_info_() { void EbyteLoraComponent::request_repeater_info_() {
if (this->can_send_message_()) if (!this->can_send_message_())
return; return;
uint8_t data[2]; uint8_t data[2];
data[0] = REQUEST_REPEATER_INFO; // Request data[0] = REQUEST_REPEATER_INFO; // Request
@ -599,7 +602,7 @@ void EbyteLoraComponent::request_repeater_info_() {
} }
void EbyteLoraComponent::repeat_message_(std::vector<uint8_t> data) { void EbyteLoraComponent::repeat_message_(std::vector<uint8_t> data) {
ESP_LOGD(TAG, "Got some info that i need to repeat for network %u", data[1]); ESP_LOGD(TAG, "Got some info that i need to repeat for network %u", data[1]);
if (this->can_send_message_()) if (!this->can_send_message_())
return; return;
this->write_array(data.data(), data.size()); this->write_array(data.data(), data.size());
} }