Trial this

This commit is contained in:
Daniël Koek 2024-10-04 14:17:29 +01:00
parent 79eae18acb
commit d3f435cd92
2 changed files with 19 additions and 42 deletions

View file

@ -2,18 +2,6 @@
namespace esphome { namespace esphome {
namespace ebyte_lora { namespace ebyte_lora {
void IRAM_ATTR HOT EbyteAuxStore::gpio_intr(EbyteAuxStore *arg) {
const bool can_send = !arg->pin.digital_read();
if (can_send == arg->can_send)
return;
arg->can_send = can_send;
const uint32_t now = micros();
if (!can_send)
arg->on_time += now - arg->last_interrupt;
arg->last_interrupt = now;
}
// when this is called it is asking peers to say something about repeater // when this is called it is asking peers to say something about repeater
static const uint8_t REQUEST_REPEATER_INFO = 0x88; static const uint8_t REQUEST_REPEATER_INFO = 0x88;
static const uint8_t REPEATER_INFO = 0x99; static const uint8_t REPEATER_INFO = 0x99;
@ -309,8 +297,6 @@ void EbyteLoraComponent::setup() {
this->should_send_ |= !this->binary_sensors_.empty(); this->should_send_ |= !this->binary_sensors_.empty();
#endif #endif
this->pin_aux_->setup(); this->pin_aux_->setup();
this->pin_aux_->attach_interrupt(EbyteAuxStore::gpio_intr, &this->store_, gpio::INTERRUPT_ANY_EDGE);
this->store_.can_send = true;
this->pin_m0_->setup(); this->pin_m0_->setup();
this->pin_m1_->setup(); this->pin_m1_->setup();
this->get_current_config_(); this->get_current_config_();
@ -324,10 +310,8 @@ void EbyteLoraComponent::get_current_config_() {
} }
ModeType EbyteLoraComponent::get_mode_() { ModeType EbyteLoraComponent::get_mode_() {
ModeType internal_mode = MODE_INIT; ModeType internal_mode = MODE_INIT;
if (!this->store_.can_send) { if (this->can_send_message_())
ESP_LOGD(TAG, "Can't sent it right now");
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();
@ -355,10 +339,9 @@ ModeType EbyteLoraComponent::get_mode_() {
return internal_mode; return internal_mode;
} }
void EbyteLoraComponent::set_mode_(ModeType mode) { void EbyteLoraComponent::set_mode_(ModeType mode) {
if (!this->store_.can_send) { if (this->can_send_message_())
ESP_LOGD(TAG, "Can't sent it right now");
return; return;
}
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;
@ -395,6 +378,17 @@ void EbyteLoraComponent::set_mode_(ModeType mode) {
this->config_mode_ = mode; this->config_mode_ = mode;
ESP_LOGD(TAG, "Mode is going to be set"); ESP_LOGD(TAG, "Mode is going to be set");
} }
bool EbyteLoraComponent::can_send_message_() {
// High means no more information is needed
if (this->pin_aux_->digital_read()) {
this->flush();
ESP_LOGD(TAG, "Aux pin is High! Can send again!");
return true;
} else {
ESP_LOGD(TAG, "Can't sent it right now");
return false;
}
}
void EbyteLoraComponent::dump_config() { void EbyteLoraComponent::dump_config() {
ESP_LOGCONFIG(TAG, "Ebyte Lora E220:"); ESP_LOGCONFIG(TAG, "Ebyte Lora E220:");
ESP_LOGCONFIG(TAG, " Network id: %u", this->network_id_); ESP_LOGCONFIG(TAG, " Network id: %u", this->network_id_);
@ -497,7 +491,6 @@ void EbyteLoraComponent::process_(std::vector<uint8_t> data) {
} }
}; };
void EbyteLoraComponent::loop() { void EbyteLoraComponent::loop() {
this->store_.can_send = !this->pin_aux_->digital_read();
std::vector<uint8_t> data; std::vector<uint8_t> data;
if (!this->available()) if (!this->available())
return; return;
@ -546,10 +539,8 @@ 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->store_.can_send) { if (this->can_send_message_())
ESP_LOGD(TAG, "Can't sent it right now");
return; return;
}
std::vector<uint8_t> data; std::vector<uint8_t> data;
data.push_back(network_id_); data.push_back(network_id_);
#ifdef USE_SENSOR #ifdef USE_SENSOR
@ -589,10 +580,8 @@ void EbyteLoraComponent::send_data_(bool all) {
} }
void EbyteLoraComponent::send_repeater_info_() { void EbyteLoraComponent::send_repeater_info_() {
if (!this->store_.can_send) { if (this->can_send_message_())
ESP_LOGD(TAG, "Can't sent it right now");
return; return;
}
uint8_t data[3]; uint8_t data[3];
data[0] = REPEATER_INFO; // response data[0] = REPEATER_INFO; // response
data[1] = this->repeater_enabled_; data[1] = this->repeater_enabled_;
@ -601,10 +590,8 @@ 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->store_.can_send) { if (this->can_send_message_())
ESP_LOGD(TAG, "Can't sent it right now");
return; return;
}
uint8_t data[2]; uint8_t data[2];
data[0] = REQUEST_REPEATER_INFO; // Request data[0] = REQUEST_REPEATER_INFO; // Request
data[1] = this->network_id_; // for unique id data[1] = this->network_id_; // for unique id
@ -613,10 +600,8 @@ 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->store_.can_send) { if (this->can_send_message_())
ESP_LOGD(TAG, "Can't sent it right now");
return; return;
}
this->write_array(data.data(), data.size()); this->write_array(data.data(), data.size());
} }

View file

@ -18,14 +18,6 @@
namespace esphome { namespace esphome {
namespace ebyte_lora { namespace ebyte_lora {
/// Store data in a class that doesn't use multiple-inheritance (vtables in flash)
struct EbyteAuxStore {
volatile uint32_t last_interrupt{0};
volatile uint32_t on_time{0};
volatile bool can_send{false};
ISRInternalGPIOPin pin;
static void gpio_intr(EbyteAuxStore *arg);
};
#ifdef USE_SENSOR #ifdef USE_SENSOR
struct Sensor { struct Sensor {
sensor::Sensor *sensor; sensor::Sensor *sensor;
@ -114,6 +106,7 @@ class EbyteLoraComponent : public PollingComponent, public uart::UARTDevice {
void send_data_(bool all); void send_data_(bool all);
void request_repeater_info_(); void request_repeater_info_();
void send_repeater_info_(); void send_repeater_info_();
bool can_send_message_();
protected: protected:
bool updated_{}; bool updated_{};
@ -130,7 +123,6 @@ class EbyteLoraComponent : public PollingComponent, public uart::UARTDevice {
// used to tell one lora device apart from another // used to tell one lora device apart from another
int network_id_ = 0; int network_id_ = 0;
int rssi_ = 0; int rssi_ = 0;
EbyteAuxStore store_;
RegisterConfig current_config_; RegisterConfig current_config_;
RegisterConfig expected_config_; RegisterConfig expected_config_;
#ifdef USE_SENSOR #ifdef USE_SENSOR