#include #include #include #include "U8g2lib.hh" #include "sx127x_driver.h" #include "sx127x_registers.h" #include "ugv_comms.h" #include "ugv_config.h" #include "ugv_io.hh" namespace ugv { using ugv::io::IO; static const char *TAG = "ugv_main"; U8G2 *oled; void setup_oled(void) { oled = new U8G2_SSD1306_128X64_NONAME_F_HW_I2C(U8G2_R0, 16, 15, 4); oled->initDisplay(); oled->clearDisplay(); oled->setPowerSave(false); } void setup(void) { ESP_LOGI(TAG, "setup"); setup_oled(); ugv_comms_init(); IO.Init(); } #define BUF_SZ 32 void loop(void) { static int32_t lora_rssi; static uint8_t lora_lna_gain; static TickType_t last_packet_tick; static int32_t last_packet_rssi; static int8_t last_packet_snr; static char buf[BUF_SZ]; static io::Inputs inputs; IO.ReadInputs(inputs); // ESP_LOGI(TAG, "inputs %s", inputs.ToString()); oled->firstPage(); sx127x_read_rssi(ugv_comms_state.lora, &lora_rssi); sx127x_read_lna_gain(ugv_comms_state.lora, &lora_lna_gain); xSemaphoreTake(ugv_comms_state.mutex, portMAX_DELAY); last_packet_tick = ugv_comms_state.last_packet_tick; last_packet_rssi = ugv_comms_state.last_packet_rssi; last_packet_snr = ugv_comms_state.last_packet_snr; xSemaphoreGive(ugv_comms_state.mutex); do { oled->drawRFrame(0, 0, OLED_W, OLED_H, 4); multi_heap_info_t heap_info; heap_caps_get_info(&heap_info, MALLOC_CAP_DEFAULT); oled->setFont(u8g2_font_4x6_mr); oled->drawStr(4, 8, "=====UAS UGV====="); snprintf(buf, BUF_SZ, "heap allc/free %d/%d", heap_info.total_allocated_bytes, heap_info.total_free_bytes); oled->drawStr(4, 2 * 8, buf); snprintf(buf, BUF_SZ, "rssi: %d lna gain: %d", lora_rssi, lora_lna_gain); oled->drawStr(4, 3 * 8, buf); if (last_packet_tick > 0) { double time_since_last_packet = 1000.0f / ((xTaskGetTickCount() - last_packet_tick) * portTICK_RATE_MS); snprintf(buf, BUF_SZ, "last pkt rx %f s ago", time_since_last_packet); oled->drawStr(4, 4 * 8, buf); snprintf(buf, BUF_SZ, "pkt rssi: %d, snr: %f", last_packet_rssi, last_packet_snr * 0.25f); oled->drawStr(4, 5 * 8, buf); } else { oled->drawStr(4, 4 * 8, "no pkt rx"); } } while (oled->nextPage()); vTaskDelay(pdMS_TO_TICKS(1000)); } void loopTask(void *pvUser) { setup(); while (1) { loop(); } } } // namespace ugv extern "C" void app_main() { xTaskCreatePinnedToCore(ugv::loopTask, "loopTask", 8192, NULL, 1, NULL, 1); }