mirror of https://github.com/meshcore-dev/MeshCore
5 changed files with 168 additions and 5 deletions
@ -0,0 +1,37 @@ |
|||||
|
#pragma once |
||||
|
|
||||
|
#include <RadioLib.h> |
||||
|
|
||||
|
#define RH_RF95_MODEM_STATUS_CLEAR 0x10 |
||||
|
#define RH_RF95_MODEM_STATUS_HEADER_INFO_VALID 0x08 |
||||
|
#define RH_RF95_MODEM_STATUS_RX_ONGOING 0x04 |
||||
|
#define RH_RF95_MODEM_STATUS_SIGNAL_SYNCHRONIZED 0x02 |
||||
|
#define RH_RF95_MODEM_STATUS_SIGNAL_DETECTED 0x01 |
||||
|
|
||||
|
class CustomSX1276 : public SX1276 { |
||||
|
public: |
||||
|
CustomSX1276(Module *mod) : SX1276(mod) { } |
||||
|
|
||||
|
bool isReceiving() { |
||||
|
return (getModemStatus() & |
||||
|
(RH_RF95_MODEM_STATUS_SIGNAL_DETECTED |
||||
|
| RH_RF95_MODEM_STATUS_SIGNAL_SYNCHRONIZED |
||||
|
| RH_RF95_MODEM_STATUS_HEADER_INFO_VALID)) != 0; |
||||
|
} |
||||
|
|
||||
|
int tryScanChannel() { |
||||
|
// start CAD
|
||||
|
int16_t state = startChannelScan(); |
||||
|
RADIOLIB_ASSERT(state); |
||||
|
|
||||
|
// wait for channel activity detected or timeout
|
||||
|
unsigned long timeout = millis() + 16; |
||||
|
while(!this->mod->hal->digitalRead(this->mod->getIrq()) && millis() < timeout) { |
||||
|
this->mod->hal->yield(); |
||||
|
if(this->mod->hal->digitalRead(this->mod->getGpio())) { |
||||
|
return(RADIOLIB_PREAMBLE_DETECTED); |
||||
|
} |
||||
|
} |
||||
|
return 0; // timed out
|
||||
|
} |
||||
|
}; |
||||
@ -0,0 +1,26 @@ |
|||||
|
#pragma once |
||||
|
|
||||
|
#include "CustomSX1276.h" |
||||
|
#include "RadioLibWrappers.h" |
||||
|
|
||||
|
class CustomSX1276Wrapper : public RadioLibWrapper { |
||||
|
public: |
||||
|
CustomSX1276Wrapper(CustomSX1276& radio, mesh::MainBoard& board) : RadioLibWrapper(radio, board) { } |
||||
|
bool isReceiving() override { |
||||
|
if (((CustomSX1276 *)_radio)->isReceiving()) return true; |
||||
|
|
||||
|
idle(); // put into standby
|
||||
|
// do some basic CAD (blocks for ~12780 micros (on SF 10)!)
|
||||
|
bool activity = (((CustomSX1276 *)_radio)->tryScanChannel() == RADIOLIB_PREAMBLE_DETECTED); |
||||
|
idle(); |
||||
|
|
||||
|
return activity; |
||||
|
} |
||||
|
float getLastRSSI() const override { return ((CustomSX1276 *)_radio)->getRSSI(); } |
||||
|
float getLastSNR() const override { return ((CustomSX1276 *)_radio)->getSNR(); } |
||||
|
|
||||
|
float packetScore(float snr, int packet_len) override { |
||||
|
int sf = ((CustomSX1276 *)_radio)->spreadingFactor; |
||||
|
return packetScoreInt(snr, sf, packet_len); |
||||
|
} |
||||
|
}; |
||||
@ -0,0 +1,77 @@ |
|||||
|
#pragma once |
||||
|
|
||||
|
#include <Arduino.h> |
||||
|
|
||||
|
// LoRa radio module pins for Heltec V2
|
||||
|
#define P_LORA_DIO_1 26 // DIO0
|
||||
|
#define P_LORA_NSS 18 |
||||
|
#define P_LORA_RESET RADIOLIB_NC // 14
|
||||
|
#define P_LORA_BUSY RADIOLIB_NC |
||||
|
#define P_LORA_SCLK 5 |
||||
|
#define P_LORA_MISO 19 |
||||
|
#define P_LORA_MOSI 27 |
||||
|
|
||||
|
// built-ins
|
||||
|
#define PIN_VBAT_READ 37 |
||||
|
#define PIN_LED_BUILTIN 25 |
||||
|
|
||||
|
#include "ESP32Board.h" |
||||
|
|
||||
|
#include <driver/rtc_io.h> |
||||
|
|
||||
|
class HeltecV2Board : public ESP32Board { |
||||
|
public: |
||||
|
void begin() { |
||||
|
ESP32Board::begin(); |
||||
|
|
||||
|
esp_reset_reason_t reason = esp_reset_reason(); |
||||
|
if (reason == ESP_RST_DEEPSLEEP) { |
||||
|
long wakeup_source = esp_sleep_get_ext1_wakeup_status(); |
||||
|
if (wakeup_source & (1 << P_LORA_DIO_1)) { // received a LoRa packet (while in deep sleep)
|
||||
|
startup_reason = BD_STARTUP_RX_PACKET; |
||||
|
} |
||||
|
|
||||
|
rtc_gpio_hold_dis((gpio_num_t)P_LORA_NSS); |
||||
|
rtc_gpio_deinit((gpio_num_t)P_LORA_DIO_1); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
void enterDeepSleep(uint32_t secs, int pin_wake_btn = -1) { |
||||
|
esp_sleep_pd_config(ESP_PD_DOMAIN_RTC_PERIPH, ESP_PD_OPTION_ON); |
||||
|
|
||||
|
// Make sure the DIO1 and NSS GPIOs are hold on required levels during deep sleep
|
||||
|
rtc_gpio_set_direction((gpio_num_t)P_LORA_DIO_1, RTC_GPIO_MODE_INPUT_ONLY); |
||||
|
rtc_gpio_pulldown_en((gpio_num_t)P_LORA_DIO_1); |
||||
|
|
||||
|
rtc_gpio_hold_en((gpio_num_t)P_LORA_NSS); |
||||
|
|
||||
|
if (pin_wake_btn < 0) { |
||||
|
esp_sleep_enable_ext1_wakeup( (1L << P_LORA_DIO_1), ESP_EXT1_WAKEUP_ANY_HIGH); // wake up on: recv LoRa packet
|
||||
|
} else { |
||||
|
esp_sleep_enable_ext1_wakeup( (1L << P_LORA_DIO_1) | (1L << pin_wake_btn), ESP_EXT1_WAKEUP_ANY_HIGH); // wake up on: recv LoRa packet OR wake btn
|
||||
|
} |
||||
|
|
||||
|
if (secs > 0) { |
||||
|
esp_sleep_enable_timer_wakeup(secs * 1000000); |
||||
|
} |
||||
|
|
||||
|
// Finally set ESP32 into sleep
|
||||
|
esp_deep_sleep_start(); // CPU halts here and never returns!
|
||||
|
} |
||||
|
|
||||
|
uint16_t getBattMilliVolts() override { |
||||
|
analogReadResolution(10); |
||||
|
|
||||
|
uint32_t raw = 0; |
||||
|
for (int i = 0; i < 8; i++) { |
||||
|
raw += analogRead(PIN_VBAT_READ); |
||||
|
} |
||||
|
raw = raw / 8; |
||||
|
|
||||
|
return (1.883 * (2 * 3.3 / 1024.0) * raw) * 1000; |
||||
|
} |
||||
|
|
||||
|
const char* getManufacturerName() const override { |
||||
|
return "Heltec V2"; |
||||
|
} |
||||
|
}; |
||||
Loading…
Reference in new issue