RGB LED indications for RNode NG
This commit is contained in:
parent
bc57f695e1
commit
8307b3c0d1
24
Config.h
24
Config.h
@ -20,6 +20,8 @@
|
|||||||
#define BOARD_GENERIC_ESP32 0x35
|
#define BOARD_GENERIC_ESP32 0x35
|
||||||
#define BOARD_LORA32_V2_0 0x36
|
#define BOARD_LORA32_V2_0 0x36
|
||||||
#define BOARD_LORA32_V2_1 0x37
|
#define BOARD_LORA32_V2_1 0x37
|
||||||
|
#define BOARD_RNODE_NG_20 0x40
|
||||||
|
#define BOARD_RNODE_NG_21 0x41
|
||||||
|
|
||||||
#define MODE_HOST 0x11
|
#define MODE_HOST 0x11
|
||||||
#define MODE_TNC 0x12
|
#define MODE_TNC 0x12
|
||||||
@ -127,6 +129,28 @@
|
|||||||
const int pin_led_rx = 25;
|
const int pin_led_rx = 25;
|
||||||
const int pin_led_tx = 25;
|
const int pin_led_tx = 25;
|
||||||
#endif
|
#endif
|
||||||
|
#elif BOARD_MODEL == BOARD_RNODE_NG_20
|
||||||
|
const int pin_cs = 18;
|
||||||
|
const int pin_reset = 12;
|
||||||
|
const int pin_dio = 26;
|
||||||
|
#if defined(EXTERNAL_LEDS)
|
||||||
|
const int pin_led_rx = 2;
|
||||||
|
const int pin_led_tx = 0;
|
||||||
|
#else
|
||||||
|
const int pin_led_rx = 22;
|
||||||
|
const int pin_led_tx = 22;
|
||||||
|
#endif
|
||||||
|
#elif BOARD_MODEL == BOARD_RNODE_NG_21
|
||||||
|
const int pin_cs = 18;
|
||||||
|
const int pin_reset = 23;
|
||||||
|
const int pin_dio = 26;
|
||||||
|
#if defined(EXTERNAL_LEDS)
|
||||||
|
const int pin_led_rx = 15;
|
||||||
|
const int pin_led_tx = 4;
|
||||||
|
#else
|
||||||
|
const int pin_led_rx = 25;
|
||||||
|
const int pin_led_tx = 25;
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
#error An unsupported board was selected. Cannot compile RNode firmware.
|
#error An unsupported board was selected. Cannot compile RNode firmware.
|
||||||
#endif
|
#endif
|
||||||
|
6
Makefile
6
Makefile
@ -30,6 +30,9 @@ firmware-lora32_v20_extled:
|
|||||||
firmware-lora32_v21_extled:
|
firmware-lora32_v21_extled:
|
||||||
arduino-cli compile --fqbn esp32:esp32:ttgo-lora32 --build-property "compiler.cpp.extra_flags=\"-DBOARD_MODEL=0x37\" \"-DEXTERNAL_LEDS=true\""
|
arduino-cli compile --fqbn esp32:esp32:ttgo-lora32 --build-property "compiler.cpp.extra_flags=\"-DBOARD_MODEL=0x37\" \"-DEXTERNAL_LEDS=true\""
|
||||||
|
|
||||||
|
firmware-rnode_ng_20:
|
||||||
|
arduino-cli compile --fqbn esp32:esp32:ttgo-lora32 --build-property "compiler.cpp.extra_flags=\"-DBOARD_MODEL=0x40\""
|
||||||
|
|
||||||
firmware-featheresp32:
|
firmware-featheresp32:
|
||||||
arduino-cli compile --fqbn esp32:esp32:featheresp32 --build-property "compiler.cpp.extra_flags=\"-DBOARD_MODEL=0x34\""
|
arduino-cli compile --fqbn esp32:esp32:featheresp32 --build-property "compiler.cpp.extra_flags=\"-DBOARD_MODEL=0x34\""
|
||||||
|
|
||||||
@ -53,6 +56,9 @@ upload-lora32_v20:
|
|||||||
upload-lora32_v21:
|
upload-lora32_v21:
|
||||||
arduino-cli upload -p /dev/ttyACM0 --fqbn esp32:esp32:ttgo-lora32
|
arduino-cli upload -p /dev/ttyACM0 --fqbn esp32:esp32:ttgo-lora32
|
||||||
|
|
||||||
|
upload-rnode_ng_20:
|
||||||
|
arduino-cli upload -p /dev/ttyUSB0 --fqbn esp32:esp32:ttgo-lora32
|
||||||
|
|
||||||
upload-featheresp32:
|
upload-featheresp32:
|
||||||
arduino-cli upload -p /dev/ttyUSB0 --fqbn esp32:esp32:featheresp32
|
arduino-cli upload -p /dev/ttyUSB0 --fqbn esp32:esp32:featheresp32
|
||||||
|
|
||||||
|
@ -24,6 +24,8 @@
|
|||||||
#include <SPI.h>
|
#include <SPI.h>
|
||||||
#include "Utilities.h"
|
#include "Utilities.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
FIFOBuffer serialFIFO;
|
FIFOBuffer serialFIFO;
|
||||||
uint8_t serialBuffer[CONFIG_UART_BUFFER_SIZE+1];
|
uint8_t serialBuffer[CONFIG_UART_BUFFER_SIZE+1];
|
||||||
|
|
||||||
|
137
Utilities.h
137
Utilities.h
@ -30,6 +30,26 @@ uint8_t boot_vector = 0x00;
|
|||||||
// TODO: Get ESP32 boot flags
|
// TODO: Get ESP32 boot flags
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if BOARD_MODEL == BOARD_RNODE_NG_20
|
||||||
|
#include <Adafruit_NeoPixel.h>
|
||||||
|
#define NP_PIN 4
|
||||||
|
#define NUMPIXELS 1
|
||||||
|
#define NP_M 0.15
|
||||||
|
Adafruit_NeoPixel pixels(NUMPIXELS, NP_PIN, NEO_GRB + NEO_KHZ800);
|
||||||
|
|
||||||
|
uint8_t npr = 0;
|
||||||
|
uint8_t npg = 0;
|
||||||
|
uint8_t npb = 0;
|
||||||
|
void npset(uint8_t r, uint8_t g, uint8_t b) {
|
||||||
|
if (r != npr || g != npg || b != npb) {
|
||||||
|
npr = r; npg = g; npb = b;
|
||||||
|
pixels.setPixelColor(0, pixels.Color(npr*NP_M, npg*NP_M, npb*NP_M));
|
||||||
|
// pixels.setPixelColor(0, pixels.Color(npr, npg, npb));
|
||||||
|
pixels.show();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#if MCU_VARIANT == MCU_1284P || MCU_VARIANT == MCU_2560
|
#if MCU_VARIANT == MCU_1284P || MCU_VARIANT == MCU_2560
|
||||||
void led_rx_on() { digitalWrite(pin_led_rx, HIGH); }
|
void led_rx_on() { digitalWrite(pin_led_rx, HIGH); }
|
||||||
void led_rx_off() { digitalWrite(pin_led_rx, LOW); }
|
void led_rx_off() { digitalWrite(pin_led_rx, LOW); }
|
||||||
@ -58,6 +78,16 @@ uint8_t boot_vector = 0x00;
|
|||||||
void led_rx_off() { digitalWrite(pin_led_rx, LOW); }
|
void led_rx_off() { digitalWrite(pin_led_rx, LOW); }
|
||||||
void led_tx_on() { digitalWrite(pin_led_tx, HIGH); }
|
void led_tx_on() { digitalWrite(pin_led_tx, HIGH); }
|
||||||
void led_tx_off() { digitalWrite(pin_led_tx, LOW); }
|
void led_tx_off() { digitalWrite(pin_led_tx, LOW); }
|
||||||
|
#elif BOARD_MODEL == BOARD_RNODE_NG_20
|
||||||
|
void led_rx_on() { npset(0, 0, 0xFF); }
|
||||||
|
void led_rx_off() { npset(0, 0, 0); }
|
||||||
|
void led_tx_on() { npset(0xFF, 0x50, 0x00); }
|
||||||
|
void led_tx_off() { npset(0, 0, 0); }
|
||||||
|
#elif BOARD_MODEL == BOARD_RNODE_NG_21
|
||||||
|
void led_rx_on() { digitalWrite(pin_led_rx, HIGH); }
|
||||||
|
void led_rx_off() { digitalWrite(pin_led_rx, LOW); }
|
||||||
|
void led_tx_on() { digitalWrite(pin_led_tx, HIGH); }
|
||||||
|
void led_tx_off() { digitalWrite(pin_led_tx, LOW); }
|
||||||
#elif BOARD_MODEL == BOARD_HUZZAH32
|
#elif BOARD_MODEL == BOARD_HUZZAH32
|
||||||
void led_rx_on() { digitalWrite(pin_led_rx, HIGH); }
|
void led_rx_on() { digitalWrite(pin_led_rx, HIGH); }
|
||||||
void led_rx_off() { digitalWrite(pin_led_rx, LOW); }
|
void led_rx_off() { digitalWrite(pin_led_rx, LOW); }
|
||||||
@ -82,7 +112,19 @@ void hard_reset(void) {
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// LED Indication: Error
|
||||||
void led_indicate_error(int cycles) {
|
void led_indicate_error(int cycles) {
|
||||||
|
#if BOARD_MODEL == BOARD_RNODE_NG_20
|
||||||
|
bool forever = (cycles == 0) ? true : false;
|
||||||
|
cycles = forever ? 1 : cycles;
|
||||||
|
while(cycles > 0) {
|
||||||
|
npset(0xFF, 0x00, 0x00);
|
||||||
|
delay(100);
|
||||||
|
npset(0xFF, 0x50, 0x00);
|
||||||
|
delay(100);
|
||||||
|
}
|
||||||
|
npset(0,0,0);
|
||||||
|
#else
|
||||||
bool forever = (cycles == 0) ? true : false;
|
bool forever = (cycles == 0) ? true : false;
|
||||||
cycles = forever ? 1 : cycles;
|
cycles = forever ? 1 : cycles;
|
||||||
while(cycles > 0) {
|
while(cycles > 0) {
|
||||||
@ -96,9 +138,16 @@ void led_indicate_error(int cycles) {
|
|||||||
}
|
}
|
||||||
led_rx_off();
|
led_rx_off();
|
||||||
led_tx_off();
|
led_tx_off();
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// LED Indication: Boot Error
|
||||||
void led_indicate_boot_error() {
|
void led_indicate_boot_error() {
|
||||||
|
#if BOARD_MODEL == BOARD_RNODE_NG_20
|
||||||
|
while(true) {
|
||||||
|
npset(0xFF, 0xFF, 0xFF);
|
||||||
|
}
|
||||||
|
#else
|
||||||
while (true) {
|
while (true) {
|
||||||
led_tx_on();
|
led_tx_on();
|
||||||
led_rx_off();
|
led_rx_off();
|
||||||
@ -107,9 +156,22 @@ void led_indicate_boot_error() {
|
|||||||
led_tx_off();
|
led_tx_off();
|
||||||
delay(5);
|
delay(5);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// LED Indication: Warning
|
||||||
void led_indicate_warning(int cycles) {
|
void led_indicate_warning(int cycles) {
|
||||||
|
#if BOARD_MODEL == BOARD_RNODE_NG_20
|
||||||
|
bool forever = (cycles == 0) ? true : false;
|
||||||
|
cycles = forever ? 1 : cycles;
|
||||||
|
while(cycles > 0) {
|
||||||
|
npset(0xFF, 0x50, 0x00);
|
||||||
|
delay(100);
|
||||||
|
npset(0x00, 0x00, 0x00);
|
||||||
|
delay(100);
|
||||||
|
}
|
||||||
|
npset(0,0,0);
|
||||||
|
#else
|
||||||
bool forever = (cycles == 0) ? true : false;
|
bool forever = (cycles == 0) ? true : false;
|
||||||
cycles = forever ? 1 : cycles;
|
cycles = forever ? 1 : cycles;
|
||||||
digitalWrite(pin_led_tx, HIGH);
|
digitalWrite(pin_led_tx, HIGH);
|
||||||
@ -121,8 +183,10 @@ void led_indicate_warning(int cycles) {
|
|||||||
if (!forever) cycles--;
|
if (!forever) cycles--;
|
||||||
}
|
}
|
||||||
led_tx_off();
|
led_tx_off();
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// LED Indication: Info
|
||||||
#if MCU_VARIANT == MCU_1284P || MCU_VARIANT == MCU_2560
|
#if MCU_VARIANT == MCU_1284P || MCU_VARIANT == MCU_2560
|
||||||
void led_indicate_info(int cycles) {
|
void led_indicate_info(int cycles) {
|
||||||
bool forever = (cycles == 0) ? true : false;
|
bool forever = (cycles == 0) ? true : false;
|
||||||
@ -137,7 +201,19 @@ void led_indicate_warning(int cycles) {
|
|||||||
led_rx_off();
|
led_rx_off();
|
||||||
}
|
}
|
||||||
#elif MCU_VARIANT == MCU_ESP32
|
#elif MCU_VARIANT == MCU_ESP32
|
||||||
#if BOARD_MODEL == BOARD_LORA32_V2_1
|
#if BOARD_MODEL == BOARD_RNODE_NG_20
|
||||||
|
void led_indicate_info(int cycles) {
|
||||||
|
bool forever = (cycles == 0) ? true : false;
|
||||||
|
cycles = forever ? 1 : cycles;
|
||||||
|
while(cycles > 0) {
|
||||||
|
npset(0x00, 0x00, 0xFF);
|
||||||
|
delay(100);
|
||||||
|
npset(0x00, 0x00, 0x00);
|
||||||
|
delay(100);
|
||||||
|
}
|
||||||
|
npset(0,0,0);
|
||||||
|
}
|
||||||
|
#elif BOARD_MODEL == BOARD_LORA32_V2_1
|
||||||
void led_indicate_info(int cycles) {
|
void led_indicate_info(int cycles) {
|
||||||
bool forever = (cycles == 0) ? true : false;
|
bool forever = (cycles == 0) ? true : false;
|
||||||
cycles = forever ? 1 : cycles;
|
cycles = forever ? 1 : cycles;
|
||||||
@ -185,7 +261,21 @@ unsigned long led_standby_ticks = 0;
|
|||||||
uint8_t led_standby_min = 1;
|
uint8_t led_standby_min = 1;
|
||||||
uint8_t led_standby_max = 40;
|
uint8_t led_standby_max = 40;
|
||||||
unsigned long led_standby_wait = 11000;
|
unsigned long led_standby_wait = 11000;
|
||||||
|
|
||||||
#elif MCU_VARIANT == MCU_ESP32
|
#elif MCU_VARIANT == MCU_ESP32
|
||||||
|
|
||||||
|
#if BOARD_MODEL == BOARD_RNODE_NG_20
|
||||||
|
uint8_t led_standby_min = 0;
|
||||||
|
uint8_t led_standby_max = 255;
|
||||||
|
uint8_t led_notready_min = 0;
|
||||||
|
uint8_t led_notready_max = led_standby_max;
|
||||||
|
uint8_t led_notready_value = led_notready_min;
|
||||||
|
int8_t led_notready_direction = 0;
|
||||||
|
unsigned long led_notready_ticks = 0;
|
||||||
|
unsigned long led_standby_wait = 5000;
|
||||||
|
unsigned long led_notready_wait = 20000;
|
||||||
|
|
||||||
|
#else
|
||||||
uint8_t led_standby_min = 200;
|
uint8_t led_standby_min = 200;
|
||||||
uint8_t led_standby_max = 255;
|
uint8_t led_standby_max = 255;
|
||||||
uint8_t led_notready_min = 0;
|
uint8_t led_notready_min = 0;
|
||||||
@ -195,7 +285,9 @@ unsigned long led_standby_ticks = 0;
|
|||||||
unsigned long led_notready_ticks = 0;
|
unsigned long led_notready_ticks = 0;
|
||||||
unsigned long led_standby_wait = 1768;
|
unsigned long led_standby_wait = 1768;
|
||||||
unsigned long led_notready_wait = 150;
|
unsigned long led_notready_wait = 150;
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
uint8_t led_standby_value = led_standby_min;
|
uint8_t led_standby_value = led_standby_min;
|
||||||
int8_t led_standby_direction = 0;
|
int8_t led_standby_direction = 0;
|
||||||
|
|
||||||
@ -214,7 +306,27 @@ int8_t led_standby_direction = 0;
|
|||||||
led_tx_off();
|
led_tx_off();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#elif MCU_VARIANT == MCU_ESP32
|
#elif MCU_VARIANT == MCU_ESP32
|
||||||
|
#if BOARD_MODEL == BOARD_RNODE_NG_20
|
||||||
|
void led_indicate_standby() {
|
||||||
|
led_standby_ticks++;
|
||||||
|
|
||||||
|
if (led_standby_ticks > led_standby_wait) {
|
||||||
|
led_standby_ticks = 0;
|
||||||
|
|
||||||
|
if (led_standby_value <= led_standby_min) {
|
||||||
|
led_standby_direction = 1;
|
||||||
|
} else if (led_standby_value >= led_standby_max) {
|
||||||
|
led_standby_direction = -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
led_standby_value += led_standby_direction;
|
||||||
|
npset(0x00, 0x00, led_standby_value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
void led_indicate_standby() {
|
void led_indicate_standby() {
|
||||||
led_standby_ticks++;
|
led_standby_ticks++;
|
||||||
if (led_standby_ticks > led_standby_wait) {
|
if (led_standby_ticks > led_standby_wait) {
|
||||||
@ -243,6 +355,7 @@ int8_t led_standby_direction = 0;
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MCU_VARIANT == MCU_1284P || MCU_VARIANT == MCU_2560
|
#if MCU_VARIANT == MCU_1284P || MCU_VARIANT == MCU_2560
|
||||||
@ -261,6 +374,25 @@ int8_t led_standby_direction = 0;
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
#elif MCU_VARIANT == MCU_ESP32
|
#elif MCU_VARIANT == MCU_ESP32
|
||||||
|
#if BOARD_MODEL == BOARD_RNODE_NG_20
|
||||||
|
void led_indicate_not_ready() {
|
||||||
|
led_notready_ticks++;
|
||||||
|
if (led_notready_ticks > led_notready_wait) {
|
||||||
|
led_notready_ticks = 0;
|
||||||
|
if (led_notready_value <= led_notready_min) {
|
||||||
|
led_notready_direction = 1;
|
||||||
|
} else if (led_notready_value >= led_notready_max) {
|
||||||
|
led_notready_direction = -1;
|
||||||
|
}
|
||||||
|
led_notready_value += led_notready_direction;
|
||||||
|
if (led_notready_value > 252) {
|
||||||
|
npset(0xFF, 0x00, 0x00);
|
||||||
|
} else {
|
||||||
|
npset(0x00, 0x00, 0x00);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
void led_indicate_not_ready() {
|
void led_indicate_not_ready() {
|
||||||
led_notready_ticks++;
|
led_notready_ticks++;
|
||||||
if (led_notready_ticks > led_notready_wait) {
|
if (led_notready_ticks > led_notready_wait) {
|
||||||
@ -289,6 +421,7 @@ int8_t led_standby_direction = 0;
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void escapedSerialWrite(uint8_t byte) {
|
void escapedSerialWrite(uint8_t byte) {
|
||||||
@ -651,6 +784,8 @@ bool eeprom_model_valid() {
|
|||||||
if (model == MODEL_B3 || model == MODEL_B8) {
|
if (model == MODEL_B3 || model == MODEL_B8) {
|
||||||
#elif BOARD_MODEL == BOARD_LORA32_V2_1
|
#elif BOARD_MODEL == BOARD_LORA32_V2_1
|
||||||
if (model == MODEL_B4 || model == MODEL_B9) {
|
if (model == MODEL_B4 || model == MODEL_B9) {
|
||||||
|
#elif BOARD_MODEL == BOARD_RNODE_NG_20
|
||||||
|
if (model == MODEL_B3 || model == MODEL_B8) {
|
||||||
#elif BOARD_MODEL == BOARD_HUZZAH32
|
#elif BOARD_MODEL == BOARD_HUZZAH32
|
||||||
if (model == MODEL_FF) {
|
if (model == MODEL_FF) {
|
||||||
#elif BOARD_MODEL == BOARD_GENERIC_ESP32
|
#elif BOARD_MODEL == BOARD_GENERIC_ESP32
|
||||||
|
Loading…
Reference in New Issue
Block a user