From 979d12d6076e5a80e3166952b3093c191aba71d9 Mon Sep 17 00:00:00 2001 From: Ben Meadors Date: Thu, 29 Dec 2022 16:59:52 -0600 Subject: [PATCH 1/7] Here we go --- src/DebugConfiguration.h | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/src/DebugConfiguration.h b/src/DebugConfiguration.h index c1d95256e1..0153b2449c 100644 --- a/src/DebugConfiguration.h +++ b/src/DebugConfiguration.h @@ -19,11 +19,20 @@ #ifdef USE_SEGGER #define DEBUG_MSG(...) SEGGER_RTT_printf(0, __VA_ARGS__) +#define INFO_MSG(...) SEGGER_RTT_printf(0, __VA_ARGS__) +#define WARN_MSG(...) SEGGER_RTT_printf(0, __VA_ARGS__) +#define ERROR_MSG(...) SEGGER_RTT_printf(0, __VA_ARGS__) #else #ifdef DEBUG_PORT #define DEBUG_MSG(...) DEBUG_PORT.logDebug(__VA_ARGS__) +#define INFO_MSG(...) DEBUG_PORT.logDebug(__VA_ARGS__) +#define WARN_MSG(...) DEBUG_PORT.logDebug(__VA_ARGS__) +#define ERROR_MSG(...) DEBUG_PORT.logDebug(__VA_ARGS__) #else #define DEBUG_MSG(...) +#define INFO_MSG(...) +#define WARN_MSG(...) +#define ERROR_MSG(...) #endif #endif From 0b5cae53933d6d18b28a8ce3a3cb46938a320468 Mon Sep 17 00:00:00 2001 From: Ben Meadors Date: Thu, 29 Dec 2022 20:41:37 -0600 Subject: [PATCH 2/7] Log levels refactoring --- src/ButtonThread.h | 22 ++-- src/DebugConfiguration.h | 29 ++-- src/FSCommon.cpp | 48 +++---- src/GPSStatus.h | 14 +- src/NodeStatus.h | 2 +- src/Power.cpp | 64 ++++----- src/PowerFSM.cpp | 34 ++--- src/PowerStatus.h | 2 +- src/RedirectablePrint.h | 3 - src/airtime.cpp | 16 +-- src/concurrency/InterruptableDelay.cpp | 4 +- src/concurrency/NotifiedWorkerThread.cpp | 6 +- src/concurrency/OSThread.cpp | 6 +- src/detect/axpDebug.h | 14 +- src/detect/einkScan.h | 4 +- src/detect/i2cScan.h | 84 ++++++------ src/gps/GPS.cpp | 60 ++++----- src/gps/NMEAGPS.cpp | 22 ++-- src/gps/RTC.cpp | 18 +-- src/graphics/EInkDisplay2.cpp | 8 +- src/graphics/Screen.cpp | 48 +++---- src/graphics/TFTDisplay.cpp | 2 +- src/input/RotaryEncoderInterruptBase.cpp | 10 +- src/input/UpDownInterruptBase.cpp | 8 +- src/input/kbI2cBase.cpp | 2 +- src/main.cpp | 46 +++---- src/memtest.cpp | 8 +- src/mesh/Channels.cpp | 20 +-- src/mesh/CryptoEngine.cpp | 6 +- src/mesh/FloodingRouter.cpp | 6 +- src/mesh/MeshModule.cpp | 26 ++-- src/mesh/MeshService.cpp | 18 +-- src/mesh/NodeDB.cpp | 90 ++++++------- src/mesh/PacketHistory.cpp | 8 +- src/mesh/PhoneAPI.cpp | 46 +++---- src/mesh/ProtobufModule.h | 6 +- src/mesh/RF95Interface.cpp | 16 +-- src/mesh/RadioInterface.cpp | 66 +++++----- src/mesh/RadioLibInterface.cpp | 52 ++++---- src/mesh/RadioLibRF95.cpp | 4 +- src/mesh/ReliableRouter.cpp | 18 +-- src/mesh/Router.cpp | 54 ++++---- src/mesh/SX126xInterface.cpp | 22 ++-- src/mesh/SX128xInterface.cpp | 18 +-- src/mesh/StreamAPI.cpp | 4 +- src/mesh/eth/ethClient.cpp | 32 ++--- src/mesh/eth/ethServerAPI.cpp | 8 +- src/mesh/http/ContentHandler.cpp | 42 +++--- src/mesh/http/WebServer.cpp | 38 +++--- src/mesh/http/WiFiAPClient.cpp | 108 +++++++-------- src/mesh/mesh-pb-constants.cpp | 6 +- src/mesh/wifi/WiFiServerAPI.cpp | 8 +- src/modules/AdminModule.cpp | 110 ++++++++-------- src/modules/CannedMessageModule.cpp | 46 +++---- src/modules/ExternalNotificationModule.cpp | 40 +++--- src/modules/NodeInfoModule.cpp | 6 +- src/modules/PositionModule.cpp | 20 +-- src/modules/RemoteHardwareModule.cpp | 8 +- src/modules/ReplyModule.cpp | 2 +- src/modules/SerialModule.cpp | 12 +- src/modules/Telemetry/DeviceTelemetry.cpp | 8 +- .../Telemetry/EnvironmentTelemetry.cpp | 12 +- src/modules/Telemetry/Sensor/BME280Sensor.cpp | 4 +- src/modules/Telemetry/Sensor/BME680Sensor.cpp | 2 +- src/modules/Telemetry/Sensor/BMP280Sensor.cpp | 4 +- src/modules/Telemetry/Sensor/INA219Sensor.cpp | 2 +- src/modules/Telemetry/Sensor/INA260Sensor.cpp | 2 +- .../Telemetry/Sensor/LPS22HBSensor.cpp | 2 +- .../Telemetry/Sensor/MCP9808Sensor.cpp | 4 +- src/modules/Telemetry/Sensor/SHT31Sensor.cpp | 2 +- src/modules/Telemetry/Sensor/SHTC3Sensor.cpp | 2 +- .../Telemetry/Sensor/TelemetrySensor.h | 4 +- src/modules/TextMessageModule.cpp | 2 +- src/modules/TraceRouteModule.cpp | 10 +- src/modules/WaypointModule.cpp | 2 +- src/modules/esp32/AudioModule.cpp | 28 ++-- src/modules/esp32/RangeTestModule.cpp | 124 +++++++++--------- src/modules/esp32/StoreForwardModule.cpp | 76 +++++------ src/mqtt/MQTT.cpp | 62 ++++----- src/nimble/NimbleBluetooth.cpp | 20 +-- src/platform/esp32/ESP32CryptoEngine.cpp | 2 +- src/platform/esp32/main-esp32.cpp | 40 +++--- src/platform/nrf52/NRF52Bluetooth.cpp | 46 +++---- src/platform/nrf52/NRF52CryptoEngine.cpp | 4 +- src/platform/nrf52/hardfault.cpp | 2 +- src/platform/nrf52/main-nrf52.cpp | 16 +-- .../portduino/CrossPlatformCryptoEngine.cpp | 4 +- src/platform/portduino/SimRadio.cpp | 38 +++--- src/shutdown.h | 8 +- src/sleep.cpp | 22 ++-- 90 files changed, 1053 insertions(+), 1051 deletions(-) diff --git a/src/ButtonThread.h b/src/ButtonThread.h index 0e9830f3f6..d1076c326e 100644 --- a/src/ButtonThread.h +++ b/src/ButtonThread.h @@ -98,8 +98,8 @@ class ButtonThread : public concurrency::OSThread userButtonTouch.tick(); canSleep &= userButtonTouch.isIdle(); #endif - // if (!canSleep) DEBUG_MSG("Supressing sleep!\n"); - // else DEBUG_MSG("sleep ok\n"); + // if (!canSleep) LOG_DEBUG("Supressing sleep!\n"); + // else LOG_DEBUG("sleep ok\n"); return 5; } @@ -108,12 +108,12 @@ class ButtonThread : public concurrency::OSThread static void touchPressed() { screen->forceDisplay(); - DEBUG_MSG("touch press!\n"); + LOG_DEBUG("touch press!\n"); } static void userButtonPressed() { - // DEBUG_MSG("press!\n"); + // LOG_DEBUG("press!\n"); #ifdef BUTTON_PIN if ((BUTTON_PIN != moduleConfig.canned_message.inputbroker_pin_press) || !moduleConfig.canned_message.enabled) { @@ -123,7 +123,7 @@ class ButtonThread : public concurrency::OSThread } static void userButtonPressedLong() { - // DEBUG_MSG("Long press!\n"); + // LOG_DEBUG("Long press!\n"); #ifdef ARCH_ESP32 screen->adjustBrightness(); #endif @@ -139,7 +139,7 @@ class ButtonThread : public concurrency::OSThread // may wake the board immediatedly. if ((!shutdown_on_long_stop) && (millis() > 30 * 1000)) { screen->startShutdownScreen(); - DEBUG_MSG("Shutdown from long press"); + LOG_DEBUG("Shutdown from long press"); playBeep(); #ifdef PIN_LED1 ledOff(PIN_LED1); @@ -154,7 +154,7 @@ class ButtonThread : public concurrency::OSThread } #endif } else { - // DEBUG_MSG("Long press %u\n", (millis() - longPressTime)); + // LOG_DEBUG("Long press %u\n", (millis() - longPressTime)); } } @@ -166,11 +166,11 @@ class ButtonThread : public concurrency::OSThread #if defined(GPS_POWER_TOGGLE) if(config.position.gps_enabled) { - DEBUG_MSG("Flag set to false for gps power\n"); + LOG_DEBUG("Flag set to false for gps power\n"); } else { - DEBUG_MSG("Flag set to true to restore power\n"); + LOG_DEBUG("Flag set to true to restore power\n"); } config.position.gps_enabled = !(config.position.gps_enabled); doGPSpowersave(config.position.gps_enabled); @@ -187,7 +187,7 @@ class ButtonThread : public concurrency::OSThread static void userButtonPressedLongStart() { if (millis() > 30 * 1000) { - DEBUG_MSG("Long press start!\n"); + LOG_DEBUG("Long press start!\n"); longPressTime = millis(); } } @@ -195,7 +195,7 @@ class ButtonThread : public concurrency::OSThread static void userButtonPressedLongStop() { if (millis() > 30 * 1000) { - DEBUG_MSG("Long press stop!\n"); + LOG_DEBUG("Long press stop!\n"); longPressTime = 0; if (shutdown_on_long_stop) { playShutdownMelody(); diff --git a/src/DebugConfiguration.h b/src/DebugConfiguration.h index 0153b2449c..f7733d5b1c 100644 --- a/src/DebugConfiguration.h +++ b/src/DebugConfiguration.h @@ -13,26 +13,31 @@ #define SERIAL_BAUD 115200 // Serial debug baud rate #endif +#define LOG_LEVEL_DEBUG "DEBUG" +#define LOG_LEVEL_INFO "INFO " +#define LOG_LEVEL_WARN "WARN " +#define LOG_LEVEL_ERROR "ERROR" + #include "SerialConsole.h" #define DEBUG_PORT (*console) // Serial debug port #ifdef USE_SEGGER -#define DEBUG_MSG(...) SEGGER_RTT_printf(0, __VA_ARGS__) -#define INFO_MSG(...) SEGGER_RTT_printf(0, __VA_ARGS__) -#define WARN_MSG(...) SEGGER_RTT_printf(0, __VA_ARGS__) -#define ERROR_MSG(...) SEGGER_RTT_printf(0, __VA_ARGS__) +#define LOG_DEBUG(...) SEGGER_RTT_printf(0, __VA_ARGS__) +#define LOG_INFO(...) SEGGER_RTT_printf(0, __VA_ARGS__) +#define LOG_WARN(...) SEGGER_RTT_printf(0, __VA_ARGS__) +#define LOG_ERROR(...) SEGGER_RTT_printf(0, __VA_ARGS__) #else #ifdef DEBUG_PORT -#define DEBUG_MSG(...) DEBUG_PORT.logDebug(__VA_ARGS__) -#define INFO_MSG(...) DEBUG_PORT.logDebug(__VA_ARGS__) -#define WARN_MSG(...) DEBUG_PORT.logDebug(__VA_ARGS__) -#define ERROR_MSG(...) DEBUG_PORT.logDebug(__VA_ARGS__) +#define LOG_DEBUG(...) DEBUG_PORT.logDebug(__VA_ARGS__) +#define LOG_INFO(...) DEBUG_PORT.logDebug(__VA_ARGS__) +#define LOG_WARN(...) DEBUG_PORT.logDebug(__VA_ARGS__) +#define LOG_ERROR(...) DEBUG_PORT.logDebug(__VA_ARGS__) #else -#define DEBUG_MSG(...) -#define INFO_MSG(...) -#define WARN_MSG(...) -#define ERROR_MSG(...) +#define LOG_DEBUG(...) +#define LOG_INFO(...) +#define LOG_WARN(...) +#define LOG_ERROR(...) #endif #endif diff --git a/src/FSCommon.cpp b/src/FSCommon.cpp index 56e5510472..2f901d26af 100644 --- a/src/FSCommon.cpp +++ b/src/FSCommon.cpp @@ -21,13 +21,13 @@ bool copyFile(const char* from, const char* to) File f1 = FSCom.open(from, FILE_O_READ); if (!f1){ - DEBUG_MSG("Failed to open source file %s\n", from); + LOG_DEBUG("Failed to open source file %s\n", from); return false; } File f2 = FSCom.open(to, FILE_O_WRITE); if (!f2) { - DEBUG_MSG("Failed to open destination file %s\n", to); + LOG_DEBUG("Failed to open destination file %s\n", to); return false; } @@ -79,7 +79,7 @@ void listDir(const char * dirname, uint8_t levels, boolean del = false) #ifdef ARCH_ESP32 listDir(file.path(), levels -1, del); if(del) { - DEBUG_MSG("Removing %s\n", file.path()); + LOG_DEBUG("Removing %s\n", file.path()); strcpy(buffer, file.path()); file.close(); FSCom.rmdir(buffer); @@ -89,7 +89,7 @@ void listDir(const char * dirname, uint8_t levels, boolean del = false) #elif (defined(ARCH_RP2040) || defined(ARCH_PORTDUINO)) listDir(file.name(), levels -1, del); if(del) { - DEBUG_MSG("Removing %s\n", file.name()); + LOG_DEBUG("Removing %s\n", file.name()); strcpy(buffer, file.name()); file.close(); FSCom.rmdir(buffer); @@ -104,26 +104,26 @@ void listDir(const char * dirname, uint8_t levels, boolean del = false) } else { #ifdef ARCH_ESP32 if(del) { - DEBUG_MSG("Deleting %s\n", file.path()); + LOG_DEBUG("Deleting %s\n", file.path()); strcpy(buffer, file.path()); file.close(); FSCom.remove(buffer); } else { - DEBUG_MSG(" %s (%i Bytes)\n", file.path(), file.size()); + LOG_DEBUG(" %s (%i Bytes)\n", file.path(), file.size()); file.close(); } #elif (defined(ARCH_RP2040) || defined(ARCH_PORTDUINO)) if(del) { - DEBUG_MSG("Deleting %s\n", file.name()); + LOG_DEBUG("Deleting %s\n", file.name()); strcpy(buffer, file.name()); file.close(); FSCom.remove(buffer); } else { - DEBUG_MSG(" %s (%i Bytes)\n", file.name(), file.size()); + LOG_DEBUG(" %s (%i Bytes)\n", file.name(), file.size()); file.close(); } #else - DEBUG_MSG(" %s (%i Bytes)\n", file.name(), file.size()); + LOG_DEBUG(" %s (%i Bytes)\n", file.name(), file.size()); file.close(); #endif } @@ -131,7 +131,7 @@ void listDir(const char * dirname, uint8_t levels, boolean del = false) } #ifdef ARCH_ESP32 if(del) { - DEBUG_MSG("Removing %s\n", root.path()); + LOG_DEBUG("Removing %s\n", root.path()); strcpy(buffer, root.path()); root.close(); FSCom.rmdir(buffer); @@ -140,7 +140,7 @@ void listDir(const char * dirname, uint8_t levels, boolean del = false) } #elif (defined(ARCH_RP2040) || defined(ARCH_PORTDUINO)) if(del) { - DEBUG_MSG("Removing %s\n", root.name()); + LOG_DEBUG("Removing %s\n", root.name()); strcpy(buffer, root.name()); root.close(); FSCom.rmdir(buffer); @@ -170,13 +170,13 @@ void fsInit() #ifdef FSCom if (!FSBegin()) { - DEBUG_MSG("ERROR filesystem mount Failed. Formatting...\n"); + LOG_DEBUG("ERROR filesystem mount Failed. Formatting...\n"); assert(0); // FIXME - report failure to phone } #ifdef ARCH_ESP32 - DEBUG_MSG("Filesystem files (%d/%d Bytes):\n", FSCom.usedBytes(), FSCom.totalBytes()); + LOG_DEBUG("Filesystem files (%d/%d Bytes):\n", FSCom.usedBytes(), FSCom.totalBytes()); #else - DEBUG_MSG("Filesystem files:\n"); + LOG_DEBUG("Filesystem files:\n"); #endif listDir("/", 10); #endif @@ -189,29 +189,29 @@ void setupSDCard() SDHandler.begin(SPI_SCK, SPI_MISO, SPI_MOSI); if (!SD.begin(SDCARD_CS, SDHandler)) { - DEBUG_MSG("No SD_MMC card detected\n"); + LOG_DEBUG("No SD_MMC card detected\n"); return ; } uint8_t cardType = SD.cardType(); if (cardType == CARD_NONE) { - DEBUG_MSG("No SD_MMC card attached\n"); + LOG_DEBUG("No SD_MMC card attached\n"); return ; } - DEBUG_MSG("SD_MMC Card Type: "); + LOG_DEBUG("SD_MMC Card Type: "); if (cardType == CARD_MMC) { - DEBUG_MSG("MMC\n"); + LOG_DEBUG("MMC\n"); } else if (cardType == CARD_SD) { - DEBUG_MSG("SDSC\n"); + LOG_DEBUG("SDSC\n"); } else if (cardType == CARD_SDHC) { - DEBUG_MSG("SDHC\n"); + LOG_DEBUG("SDHC\n"); } else { - DEBUG_MSG("UNKNOWN\n"); + LOG_DEBUG("UNKNOWN\n"); } uint64_t cardSize = SD.cardSize() / (1024 * 1024); - DEBUG_MSG("SD Card Size: %lluMB\n", cardSize); - DEBUG_MSG("Total space: %llu MB\n", SD.totalBytes() / (1024 * 1024)); - DEBUG_MSG("Used space: %llu MB\n", SD.usedBytes() / (1024 * 1024)); + LOG_DEBUG("SD Card Size: %lluMB\n", cardSize); + LOG_DEBUG("Total space: %llu MB\n", SD.totalBytes() / (1024 * 1024)); + LOG_DEBUG("Used space: %llu MB\n", SD.usedBytes() / (1024 * 1024)); #endif } diff --git a/src/GPSStatus.h b/src/GPSStatus.h index ef97c59b71..9ada4e66e8 100644 --- a/src/GPSStatus.h +++ b/src/GPSStatus.h @@ -53,7 +53,7 @@ class GPSStatus : public Status { if (config.position.fixed_position) { #ifdef GPS_EXTRAVERBOSE - DEBUG_MSG("WARNING: Using fixed latitude\n"); + LOG_WARN("Using fixed latitude\n"); #endif NodeInfo *node = nodeDB.getNode(nodeDB.getNodeNum()); return node->position.latitude_i; @@ -66,7 +66,7 @@ class GPSStatus : public Status { if (config.position.fixed_position) { #ifdef GPS_EXTRAVERBOSE - DEBUG_MSG("WARNING: Using fixed longitude\n"); + LOG_WARN("Using fixed longitude\n"); #endif NodeInfo *node = nodeDB.getNode(nodeDB.getNodeNum()); return node->position.longitude_i; @@ -79,7 +79,7 @@ class GPSStatus : public Status { if (config.position.fixed_position) { #ifdef GPS_EXTRAVERBOSE - DEBUG_MSG("WARNING: Using fixed altitude\n"); + LOG_WARN("Using fixed altitude\n"); #endif NodeInfo *node = nodeDB.getNode(nodeDB.getNodeNum()); return node->position.altitude; @@ -97,7 +97,7 @@ class GPSStatus : public Status bool matches(const GPSStatus *newStatus) const { #ifdef GPS_EXTRAVERBOSE - DEBUG_MSG("GPSStatus.match() new pos@%x to old pos@%x\n", newStatus->p.pos_timestamp, p.pos_timestamp); + LOG_DEBUG("GPSStatus.match() new pos@%x to old pos@%x\n", newStatus->p.pos_timestamp, p.pos_timestamp); #endif return (newStatus->hasLock != hasLock || newStatus->isConnected != isConnected || newStatus->isPowerSaving !=isPowerSaving || newStatus->p.latitude_i != p.latitude_i || newStatus->p.longitude_i != p.longitude_i || @@ -114,7 +114,7 @@ class GPSStatus : public Status if (isDirty && p.timestamp && (newStatus->p.timestamp == p.timestamp)) { // We can NEVER be in two locations at the same time! (also PR #886) - DEBUG_MSG("BUG!! positional timestamp unchanged from prev solution\n"); + LOG_DEBUG("BUG!! positional timestamp unchanged from prev solution\n"); } initialized = true; @@ -126,11 +126,11 @@ class GPSStatus : public Status if (isDirty) { if (hasLock) { // In debug logs, identify position by @timestamp:stage (stage 3 = notify) - DEBUG_MSG("New GPS pos@%x:3 lat=%f, lon=%f, alt=%d, pdop=%.2f, track=%.2f, speed=%.2f, sats=%d\n", p.timestamp, + LOG_DEBUG("New GPS pos@%x:3 lat=%f, lon=%f, alt=%d, pdop=%.2f, track=%.2f, speed=%.2f, sats=%d\n", p.timestamp, p.latitude_i * 1e-7, p.longitude_i * 1e-7, p.altitude, p.PDOP * 1e-2, p.ground_track * 1e-5, p.ground_speed * 1e-2, p.sats_in_view); } else - DEBUG_MSG("No GPS lock\n"); + LOG_DEBUG("No GPS lock\n"); onNewStatus.notifyObservers(this); } return 0; diff --git a/src/NodeStatus.h b/src/NodeStatus.h index dc567fd2f5..7c0477cf6c 100644 --- a/src/NodeStatus.h +++ b/src/NodeStatus.h @@ -70,7 +70,7 @@ namespace meshtastic { numTotal = newStatus->getNumTotal(); } if(isDirty || newStatus->forceUpdate) { - DEBUG_MSG("Node status update: %d online, %d total\n", numOnline, numTotal); + LOG_DEBUG("Node status update: %d online, %d total\n", numOnline, numTotal); onNewStatus.notifyObservers(this); } return 0; diff --git a/src/Power.cpp b/src/Power.cpp index d2c5b01a07..bba21549b5 100644 --- a/src/Power.cpp +++ b/src/Power.cpp @@ -129,7 +129,7 @@ class AnalogBatteryLevel : public HasBatteryLevel #else scaled = VBAT_RAW_TO_SCALED(raw); // defined in variant.h #endif - // DEBUG_MSG("battery gpio %d raw val=%u scaled=%u\n", BATTERY_PIN, raw, (uint32_t)(scaled)); + // LOG_DEBUG("battery gpio %d raw val=%u scaled=%u\n", BATTERY_PIN, raw, (uint32_t)(scaled)); last_read_value = scaled; return scaled; } else { @@ -190,7 +190,7 @@ Power::Power() : OSThread("Power") bool Power::analogInit() { #ifdef BATTERY_PIN - DEBUG_MSG("Using analog input %d for battery level\n", BATTERY_PIN); + LOG_DEBUG("Using analog input %d for battery level\n", BATTERY_PIN); // disable any internal pullups pinMode(BATTERY_PIN, INPUT); @@ -242,7 +242,7 @@ void Power::shutdown() #endif #ifdef HAS_PMU - DEBUG_MSG("Shutting down\n"); + LOG_DEBUG("Shutting down\n"); if(PMU) { PMU->setChargingLedMode(XPOWERS_CHG_LED_OFF); PMU->shutdown(); @@ -283,12 +283,12 @@ void Power::readPowerStatus() const PowerStatus powerStatus2 = PowerStatus(hasBattery ? OptTrue : OptFalse, batteryLevel->isVbusIn() ? OptTrue : OptFalse, batteryLevel->isCharging() ? OptTrue : OptFalse, batteryVoltageMv, batteryChargePercent); - DEBUG_MSG("Battery: usbPower=%d, isCharging=%d, batMv=%d, batPct=%d\n", powerStatus2.getHasUSB(), + LOG_DEBUG("Battery: usbPower=%d, isCharging=%d, batMv=%d, batPct=%d\n", powerStatus2.getHasUSB(), powerStatus2.getIsCharging(), powerStatus2.getBatteryVoltageMv(), powerStatus2.getBatteryChargePercent()); newStatus.notifyObservers(&powerStatus2); #ifdef DEBUG_HEAP if (lastheap != ESP.getFreeHeap()){ - DEBUG_MSG("Heap status: %d/%d bytes free (%d), running %d threads\n", ESP.getFreeHeap(), ESP.getHeapSize(), ESP.getFreeHeap() - lastheap , concurrency::mainController.size(false)); + LOG_DEBUG("Heap status: %d/%d bytes free (%d), running %d threads\n", ESP.getFreeHeap(), ESP.getHeapSize(), ESP.getFreeHeap() - lastheap , concurrency::mainController.size(false)); lastheap = ESP.getFreeHeap(); } #endif @@ -299,11 +299,11 @@ void Power::readPowerStatus() if (powerStatus2.getHasBattery() && !powerStatus2.getHasUSB()) { if (batteryLevel->getBattVoltage() < MIN_BAT_MILLIVOLTS) { low_voltage_counter++; - DEBUG_MSG("Warning RAK4631 Low voltage counter: %d/10\n", low_voltage_counter); + LOG_DEBUG("Warning RAK4631 Low voltage counter: %d/10\n", low_voltage_counter); if (low_voltage_counter > 10) { // We can't trigger deep sleep on NRF52, it's freezing the board //powerFSM.trigger(EVENT_LOW_BATTERY); - DEBUG_MSG("Low voltage detected, but not triggering deep sleep\n"); + LOG_DEBUG("Low voltage detected, but not triggering deep sleep\n"); } } else { low_voltage_counter = 0; @@ -333,12 +333,12 @@ int32_t Power::runOnce() PMU->getIrqStatus(); if(PMU->isVbusRemoveIrq()){ - DEBUG_MSG("USB unplugged\n"); + LOG_DEBUG("USB unplugged\n"); powerFSM.trigger(EVENT_POWER_DISCONNECTED); } if (PMU->isVbusInsertIrq()) { - DEBUG_MSG("USB plugged In\n"); + LOG_DEBUG("USB plugged In\n"); powerFSM.trigger(EVENT_POWER_CONNECTED); } @@ -346,20 +346,20 @@ int32_t Power::runOnce() Other things we could check if we cared... if (PMU->isBatChagerStartIrq()) { - DEBUG_MSG("Battery start charging\n"); + LOG_DEBUG("Battery start charging\n"); } if (PMU->isBatChagerDoneIrq()) { - DEBUG_MSG("Battery fully charged\n"); + LOG_DEBUG("Battery fully charged\n"); } if (PMU->isBatInsertIrq()) { - DEBUG_MSG("Battery inserted\n"); + LOG_DEBUG("Battery inserted\n"); } if (PMU->isBatRemoveIrq()) { - DEBUG_MSG("Battery removed\n"); + LOG_DEBUG("Battery removed\n"); } */ if (PMU->isPekeyLongPressIrq()) { - DEBUG_MSG("PEK long button press\n"); + LOG_DEBUG("PEK long button press\n"); screen->setOn(false); } @@ -401,22 +401,22 @@ bool Power::axpChipInit() if (!PMU) { PMU = new XPowersAXP2101(*w); if (!PMU->init()) { - DEBUG_MSG("Warning: Failed to find AXP2101 power management\n"); + LOG_WARN("Failed to find AXP2101 power management\n"); delete PMU; PMU = NULL; } else { - DEBUG_MSG("AXP2101 PMU init succeeded, using AXP2101 PMU\n"); + LOG_DEBUG("AXP2101 PMU init succeeded, using AXP2101 PMU\n"); } } if (!PMU) { PMU = new XPowersAXP192(*w); if (!PMU->init()) { - DEBUG_MSG("Warning: Failed to find AXP192 power management\n"); + LOG_WARN("Failed to find AXP192 power management\n"); delete PMU; PMU = NULL; } else { - DEBUG_MSG("AXP192 PMU init succeeded, using AXP192 PMU\n"); + LOG_DEBUG("AXP192 PMU init succeeded, using AXP192 PMU\n"); } } @@ -538,44 +538,44 @@ bool Power::axpChipInit() PMU->enableVbusVoltageMeasure(); PMU->enableBattVoltageMeasure(); - DEBUG_MSG("=======================================================================\n"); + LOG_DEBUG("=======================================================================\n"); if (PMU->isChannelAvailable(XPOWERS_DCDC1)) { - DEBUG_MSG("DC1 : %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_DCDC1) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_DCDC1)); + LOG_DEBUG("DC1 : %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_DCDC1) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_DCDC1)); } if (PMU->isChannelAvailable(XPOWERS_DCDC2)) { - DEBUG_MSG("DC2 : %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_DCDC2) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_DCDC2)); + LOG_DEBUG("DC2 : %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_DCDC2) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_DCDC2)); } if (PMU->isChannelAvailable(XPOWERS_DCDC3)) { - DEBUG_MSG("DC3 : %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_DCDC3) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_DCDC3)); + LOG_DEBUG("DC3 : %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_DCDC3) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_DCDC3)); } if (PMU->isChannelAvailable(XPOWERS_DCDC4)) { - DEBUG_MSG("DC4 : %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_DCDC4) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_DCDC4)); + LOG_DEBUG("DC4 : %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_DCDC4) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_DCDC4)); } if (PMU->isChannelAvailable(XPOWERS_LDO2)) { - DEBUG_MSG("LDO2 : %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_LDO2) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_LDO2)); + LOG_DEBUG("LDO2 : %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_LDO2) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_LDO2)); } if (PMU->isChannelAvailable(XPOWERS_LDO3)) { - DEBUG_MSG("LDO3 : %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_LDO3) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_LDO3)); + LOG_DEBUG("LDO3 : %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_LDO3) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_LDO3)); } if (PMU->isChannelAvailable(XPOWERS_ALDO1)) { - DEBUG_MSG("ALDO1: %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_ALDO1) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_ALDO1)); + LOG_DEBUG("ALDO1: %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_ALDO1) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_ALDO1)); } if (PMU->isChannelAvailable(XPOWERS_ALDO2)) { - DEBUG_MSG("ALDO2: %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_ALDO2) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_ALDO2)); + LOG_DEBUG("ALDO2: %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_ALDO2) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_ALDO2)); } if (PMU->isChannelAvailable(XPOWERS_ALDO3)) { - DEBUG_MSG("ALDO3: %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_ALDO3) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_ALDO3)); + LOG_DEBUG("ALDO3: %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_ALDO3) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_ALDO3)); } if (PMU->isChannelAvailable(XPOWERS_ALDO4)) { - DEBUG_MSG("ALDO4: %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_ALDO4) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_ALDO4)); + LOG_DEBUG("ALDO4: %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_ALDO4) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_ALDO4)); } if (PMU->isChannelAvailable(XPOWERS_BLDO1)) { - DEBUG_MSG("BLDO1: %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_BLDO1) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_BLDO1)); + LOG_DEBUG("BLDO1: %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_BLDO1) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_BLDO1)); } if (PMU->isChannelAvailable(XPOWERS_BLDO2)) { - DEBUG_MSG("BLDO2: %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_BLDO2) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_BLDO2)); + LOG_DEBUG("BLDO2: %s Voltage:%u mV \n", PMU->isPowerChannelEnable(XPOWERS_BLDO2) ? "+" : "-", PMU->getPowerChannelVoltage(XPOWERS_BLDO2)); } - DEBUG_MSG("=======================================================================\n"); + LOG_DEBUG("=======================================================================\n"); // We can safely ignore this approach for most (or all) boards because MCU turned off // earlier than battery discharged to 2.6V. diff --git a/src/PowerFSM.cpp b/src/PowerFSM.cpp index 5bea8d7961..f35e755cac 100644 --- a/src/PowerFSM.cpp +++ b/src/PowerFSM.cpp @@ -32,7 +32,7 @@ static bool isPowered() static void sdsEnter() { - DEBUG_MSG("Enter state: SDS\n"); + LOG_DEBUG("Enter state: SDS\n"); // FIXME - make sure GPS and LORA radio are off first - because we want close to zero current draw doDeepSleep(getConfiguredOrDefaultMs(config.power.sds_secs)); } @@ -41,7 +41,7 @@ extern Power *power; static void shutdownEnter() { - DEBUG_MSG("Enter state: SHUTDOWN\n"); + LOG_DEBUG("Enter state: SHUTDOWN\n"); power->shutdown(); } @@ -51,16 +51,16 @@ static uint32_t secsSlept; static void lsEnter() { - DEBUG_MSG("lsEnter begin, ls_secs=%u\n", config.power.ls_secs); + LOG_DEBUG("lsEnter begin, ls_secs=%u\n", config.power.ls_secs); screen->setOn(false); secsSlept = 0; // How long have we been sleeping this time - // DEBUG_MSG("lsEnter end\n"); + // LOG_DEBUG("lsEnter end\n"); } static void lsIdle() { - // DEBUG_MSG("lsIdle begin ls_secs=%u\n", getPref_ls_secs()); + // LOG_DEBUG("lsIdle begin ls_secs=%u\n", getPref_ls_secs()); #ifdef ARCH_ESP32 @@ -82,7 +82,7 @@ static void lsIdle() wakeCause2 = doLightSleep(1); // leave led on for 1ms secsSlept += sleepTime; - // DEBUG_MSG("sleeping, flash led!\n"); + // LOG_DEBUG("sleeping, flash led!\n"); break; case ESP_SLEEP_WAKEUP_UART: @@ -93,7 +93,7 @@ static void lsIdle() default: // We woke for some other reason (button press, device interrupt) // uint64_t status = esp_sleep_get_ext1_wakeup_status(); - DEBUG_MSG("wakeCause2 %d\n", wakeCause2); + LOG_DEBUG("wakeCause2 %d\n", wakeCause2); #ifdef BUTTON_PIN bool pressed = !digitalRead(BUTTON_PIN); @@ -117,7 +117,7 @@ static void lsIdle() } else { // Time to stop sleeping! setLed(false); - DEBUG_MSG("reached ls_secs, servicing loop()\n"); + LOG_DEBUG("reached ls_secs, servicing loop()\n"); powerFSM.trigger(EVENT_WAKE_TIMER); } #endif @@ -125,7 +125,7 @@ static void lsIdle() static void lsExit() { - DEBUG_MSG("Exit state: LS\n"); + LOG_DEBUG("Exit state: LS\n"); // setGPSPower(true); // restore GPS power if (gps) gps->forceWake(true); @@ -133,7 +133,7 @@ static void lsExit() static void nbEnter() { - DEBUG_MSG("Enter state: NB\n"); + LOG_DEBUG("Enter state: NB\n"); screen->setOn(false); setBluetoothEnable(false); @@ -148,7 +148,7 @@ static void darkEnter() static void serialEnter() { - DEBUG_MSG("Enter state: SERIAL\n"); + LOG_DEBUG("Enter state: SERIAL\n"); setBluetoothEnable(false); screen->setOn(true); screen->print("Serial connected\n"); @@ -161,10 +161,10 @@ static void serialExit() static void powerEnter() { - DEBUG_MSG("Enter state: POWER\n"); + LOG_DEBUG("Enter state: POWER\n"); if (!isPowered()) { // If we got here, we are in the wrong state - we should be in powered, let that state ahndle things - DEBUG_MSG("Loss of power in Powered\n"); + LOG_DEBUG("Loss of power in Powered\n"); powerFSM.trigger(EVENT_POWER_DISCONNECTED); } else { screen->setOn(true); @@ -177,7 +177,7 @@ static void powerIdle() { if (!isPowered()) { // If we got here, we are in the wrong state - DEBUG_MSG("Loss of power in Powered\n"); + LOG_DEBUG("Loss of power in Powered\n"); powerFSM.trigger(EVENT_POWER_DISCONNECTED); } } @@ -191,7 +191,7 @@ static void powerExit() static void onEnter() { - DEBUG_MSG("Enter state: ON\n"); + LOG_DEBUG("Enter state: ON\n"); screen->setOn(true); setBluetoothEnable(true); @@ -221,7 +221,7 @@ static void screenPress() static void bootEnter() { - DEBUG_MSG("Enter state: BOOT\n"); + LOG_DEBUG("Enter state: BOOT\n"); } State stateSHUTDOWN(shutdownEnter, NULL, NULL, "SHUTDOWN"); @@ -240,7 +240,7 @@ void PowerFSM_setup() bool isRouter = (config.device.role == Config_DeviceConfig_Role_ROUTER ? 1 : 0); bool hasPower = isPowered(); - DEBUG_MSG("PowerFSM init, USB power=%d\n", hasPower ? 1 : 0); + LOG_DEBUG("PowerFSM init, USB power=%d\n", hasPower ? 1 : 0); powerFSM.add_timed_transition(&stateBOOT, hasPower ? &statePOWER : &stateON, 3 * 1000, NULL, "boot timeout"); // wake timer expired or a packet arrived diff --git a/src/PowerStatus.h b/src/PowerStatus.h index a276be59b4..56d19b758c 100644 --- a/src/PowerStatus.h +++ b/src/PowerStatus.h @@ -82,7 +82,7 @@ class PowerStatus : public Status isCharging = newStatus->isCharging; } if (isDirty) { - // DEBUG_MSG("Battery %dmV %d%%\n", batteryVoltageMv, batteryChargePercent); + // LOG_DEBUG("Battery %dmV %d%%\n", batteryVoltageMv, batteryChargePercent); onNewStatus.notifyObservers(this); } return 0; diff --git a/src/RedirectablePrint.h b/src/RedirectablePrint.h index b2081d046f..9443d1672f 100644 --- a/src/RedirectablePrint.h +++ b/src/RedirectablePrint.h @@ -33,9 +33,6 @@ class RedirectablePrint : public Print * If the provide format string ends with a newline we assume it is the final print of a single * log message. Otherwise we assume more prints will come before the log message ends. This * allows you to call logDebug a few times to build up a single log message line if you wish. - * - * FIXME, eventually add log levels (INFO, WARN, ERROR) and subsystems. Move into - * a different class. */ size_t logDebug(const char * format, ...) __attribute__ ((format (printf, 2, 3))); diff --git a/src/airtime.cpp b/src/airtime.cpp index 1c2fb32338..c72a21d543 100644 --- a/src/airtime.cpp +++ b/src/airtime.cpp @@ -10,18 +10,18 @@ void AirTime::logAirtime(reportTypes reportType, uint32_t airtime_ms) { if (reportType == TX_LOG) { - DEBUG_MSG("AirTime - Packet transmitted : %ums\n", airtime_ms); + LOG_DEBUG("AirTime - Packet transmitted : %ums\n", airtime_ms); this->airtimes.periodTX[0] = this->airtimes.periodTX[0] + airtime_ms; myNodeInfo.air_period_tx[0] = myNodeInfo.air_period_tx[0] + airtime_ms; this->utilizationTX[this->getPeriodUtilHour()] = this->utilizationTX[this->getPeriodUtilHour()] + airtime_ms; } else if (reportType == RX_LOG) { - DEBUG_MSG("AirTime - Packet received : %ums\n", airtime_ms); + LOG_DEBUG("AirTime - Packet received : %ums\n", airtime_ms); this->airtimes.periodRX[0] = this->airtimes.periodRX[0] + airtime_ms; myNodeInfo.air_period_rx[0] = myNodeInfo.air_period_rx[0] + airtime_ms; } else if (reportType == RX_ALL_LOG) { - DEBUG_MSG("AirTime - Packet received (noise?) : %ums\n", airtime_ms); + LOG_DEBUG("AirTime - Packet received (noise?) : %ums\n", airtime_ms); this->airtimes.periodRX_ALL[0] = this->airtimes.periodRX_ALL[0] + airtime_ms; } @@ -46,7 +46,7 @@ void AirTime::airtimeRotatePeriod() { if (this->airtimes.lastPeriodIndex != this->currentPeriodIndex()) { - DEBUG_MSG("Rotating airtimes to a new period = %u\n", this->currentPeriodIndex()); + LOG_DEBUG("Rotating airtimes to a new period = %u\n", this->currentPeriodIndex()); for (int i = PERIODS_TO_LOG - 2; i >= 0; --i) { this->airtimes.periodTX[i + 1] = this->airtimes.periodTX[i]; @@ -101,7 +101,7 @@ float AirTime::channelUtilizationPercent() uint32_t sum = 0; for (uint32_t i = 0; i < CHANNEL_UTILIZATION_PERIODS; i++) { sum += this->channelUtilization[i]; - // DEBUG_MSG("ChanUtilArray %u %u\n", i, this->channelUtilization[i]); + // LOG_DEBUG("ChanUtilArray %u %u\n", i, this->channelUtilization[i]); } return (float(sum) / float(CHANNEL_UTILIZATION_PERIODS * 10 * 1000)) * 100; @@ -189,13 +189,13 @@ int32_t AirTime::runOnce() myNodeInfo.air_util_tx = airTime->utilizationTXPercent(); } /* - DEBUG_MSG("utilPeriodTX %d TX Airtime %3.2f%\n", utilPeriodTX, airTime->utilizationTXPercent()); + LOG_DEBUG("utilPeriodTX %d TX Airtime %3.2f%\n", utilPeriodTX, airTime->utilizationTXPercent()); for (uint32_t i = 0; i < MINUTES_IN_HOUR; i++) { - DEBUG_MSG( + LOG_DEBUG( "%d,", this->utilizationTX[i] ); } - DEBUG_MSG("\n"); + LOG_DEBUG("\n"); */ return (1000 * 1); } diff --git a/src/concurrency/InterruptableDelay.cpp b/src/concurrency/InterruptableDelay.cpp index fa664e7bb4..7bddea68d4 100644 --- a/src/concurrency/InterruptableDelay.cpp +++ b/src/concurrency/InterruptableDelay.cpp @@ -13,12 +13,12 @@ InterruptableDelay::~InterruptableDelay() {} */ bool InterruptableDelay::delay(uint32_t msec) { - // DEBUG_MSG("delay %u ", msec); + // LOG_DEBUG("delay %u ", msec); // sem take will return false if we timed out (i.e. were not interrupted) bool r = semaphore.take(msec); - // DEBUG_MSG("interrupt=%d\n", r); + // LOG_DEBUG("interrupt=%d\n", r); return !r; } diff --git a/src/concurrency/NotifiedWorkerThread.cpp b/src/concurrency/NotifiedWorkerThread.cpp index 9be2bc90d5..ac6428f075 100644 --- a/src/concurrency/NotifiedWorkerThread.cpp +++ b/src/concurrency/NotifiedWorkerThread.cpp @@ -33,11 +33,11 @@ IRAM_ATTR bool NotifiedWorkerThread::notifyCommon(uint32_t v, bool overwrite) notification = v; if (debugNotification) - DEBUG_MSG("setting notification %d\n", v); + LOG_DEBUG("setting notification %d\n", v); return true; } else { if (debugNotification) - DEBUG_MSG("dropping notification %d\n", v); + LOG_DEBUG("dropping notification %d\n", v); return false; } } @@ -66,7 +66,7 @@ bool NotifiedWorkerThread::notifyLater(uint32_t delay, uint32_t v, bool overwrit if (didIt) { // If we didn't already have something queued, override the delay to be larger setIntervalFromNow(delay); // a new version of setInterval relative to the current time if (debugNotification) - DEBUG_MSG("delaying notification %u\n", delay); + LOG_DEBUG("delaying notification %u\n", delay); } return didIt; diff --git a/src/concurrency/OSThread.cpp b/src/concurrency/OSThread.cpp index 88c21d1c50..560a5cb691 100644 --- a/src/concurrency/OSThread.cpp +++ b/src/concurrency/OSThread.cpp @@ -61,13 +61,13 @@ bool OSThread::shouldRun(unsigned long time) bool r = Thread::shouldRun(time); if (showRun && r) - DEBUG_MSG("Thread %s: run\n", ThreadName.c_str()); + LOG_DEBUG("Thread %s: run\n", ThreadName.c_str()); if (showWaiting && enabled && !r) - DEBUG_MSG("Thread %s: wait %lu\n", ThreadName.c_str(), interval); + LOG_DEBUG("Thread %s: wait %lu\n", ThreadName.c_str(), interval); if (showDisabled && !enabled) - DEBUG_MSG("Thread %s: disabled\n", ThreadName.c_str()); + LOG_DEBUG("Thread %s: disabled\n", ThreadName.c_str()); return r; } diff --git a/src/detect/axpDebug.h b/src/detect/axpDebug.h index 28e3ee26e8..fc95447aa5 100644 --- a/src/detect/axpDebug.h +++ b/src/detect/axpDebug.h @@ -3,13 +3,13 @@ uint32_t axpDebugRead() { axp.debugCharging(); - DEBUG_MSG("vbus current %f\n", axp.getVbusCurrent()); - DEBUG_MSG("charge current %f\n", axp.getBattChargeCurrent()); - DEBUG_MSG("bat voltage %f\n", axp.getBattVoltage()); - DEBUG_MSG("batt pct %d\n", axp.getBattPercentage()); - DEBUG_MSG("is battery connected %d\n", axp.isBatteryConnect()); - DEBUG_MSG("is USB connected %d\n", axp.isVBUSPlug()); - DEBUG_MSG("is charging %d\n", axp.isChargeing()); + LOG_DEBUG("vbus current %f\n", axp.getVbusCurrent()); + LOG_DEBUG("charge current %f\n", axp.getBattChargeCurrent()); + LOG_DEBUG("bat voltage %f\n", axp.getBattVoltage()); + LOG_DEBUG("batt pct %d\n", axp.getBattPercentage()); + LOG_DEBUG("is battery connected %d\n", axp.isBatteryConnect()); + LOG_DEBUG("is USB connected %d\n", axp.isVBUSPlug()); + LOG_DEBUG("is charging %d\n", axp.isChargeing()); return 30 * 1000; } diff --git a/src/detect/einkScan.h b/src/detect/einkScan.h index a2509a45a2..dd2bf01c26 100644 --- a/src/detect/einkScan.h +++ b/src/detect/einkScan.h @@ -52,9 +52,9 @@ void scanEInkDevice(void) d_writeCommand(0x20); eink_found = (d_waitWhileBusy(150) > 0) ? true : false; if(eink_found) - DEBUG_MSG("EInk display found\n"); + LOG_DEBUG("EInk display found\n"); else - DEBUG_MSG("EInk display not found\n"); + LOG_DEBUG("EInk display not found\n"); SPI1.end(); } #endif diff --git a/src/detect/i2cScan.h b/src/detect/i2cScan.h index 940ebb1005..f2ebc18b8c 100644 --- a/src/detect/i2cScan.h +++ b/src/detect/i2cScan.h @@ -15,30 +15,30 @@ void printATECCInfo() #if !defined(ARCH_PORTDUINO) && !defined(ARCH_STM32WL) atecc.readConfigZone(false); - DEBUG_MSG("ATECC608B Serial Number: "); + LOG_DEBUG("ATECC608B Serial Number: "); for (int i = 0 ; i < 9 ; i++) { - DEBUG_MSG("%02x",atecc.serialNumber[i]); + LOG_DEBUG("%02x",atecc.serialNumber[i]); } - DEBUG_MSG(", Rev Number: "); + LOG_DEBUG(", Rev Number: "); for (int i = 0 ; i < 4 ; i++) { - DEBUG_MSG("%02x",atecc.revisionNumber[i]); + LOG_DEBUG("%02x",atecc.revisionNumber[i]); } - DEBUG_MSG("\n"); + LOG_DEBUG("\n"); - DEBUG_MSG("ATECC608B Config %s",atecc.configLockStatus ? "Locked" : "Unlocked"); - DEBUG_MSG(", Data %s",atecc.dataOTPLockStatus ? "Locked" : "Unlocked"); - DEBUG_MSG(", Slot 0 %s\n",atecc.slot0LockStatus ? "Locked" : "Unlocked"); + LOG_DEBUG("ATECC608B Config %s",atecc.configLockStatus ? "Locked" : "Unlocked"); + LOG_DEBUG(", Data %s",atecc.dataOTPLockStatus ? "Locked" : "Unlocked"); + LOG_DEBUG(", Slot 0 %s\n",atecc.slot0LockStatus ? "Locked" : "Unlocked"); if (atecc.configLockStatus && atecc.dataOTPLockStatus && atecc.slot0LockStatus) { if (atecc.generatePublicKey() == false) { - DEBUG_MSG("ATECC608B Error generating public key\n"); + LOG_DEBUG("ATECC608B Error generating public key\n"); } else { - DEBUG_MSG("ATECC608B Public Key: "); + LOG_DEBUG("ATECC608B Public Key: "); for (int i = 0 ; i < 64 ; i++) { - DEBUG_MSG("%02x",atecc.publicKey64Bytes[i]); + LOG_DEBUG("%02x",atecc.publicKey64Bytes[i]); } - DEBUG_MSG("\n"); + LOG_DEBUG("\n"); } } #endif @@ -51,7 +51,7 @@ uint16_t getRegisterValue(uint8_t address, uint8_t reg, uint8_t length) { Wire.endTransmission(); delay(20); Wire.requestFrom(address, length); - DEBUG_MSG("Wire.available() = %d\n", Wire.available()); + LOG_DEBUG("Wire.available() = %d\n", Wire.available()); if (Wire.available() == 2) { // Read MSB, then LSB value = (uint16_t)Wire.read() << 8; @@ -86,7 +86,7 @@ uint8_t oled_probe(byte addr) } c++; } while ((r != r_prev) && (c < 4)); - DEBUG_MSG("0x%x subtype probed in %i tries \n", r, c); + LOG_DEBUG("0x%x subtype probed in %i tries \n", r, c); return o_probe; } @@ -99,7 +99,7 @@ void scanI2Cdevice() Wire.beginTransmission(addr); err = Wire.endTransmission(); if (err == 0) { - DEBUG_MSG("I2C device found at address 0x%x\n", addr); + LOG_DEBUG("I2C device found at address 0x%x\n", addr); nDevices++; @@ -107,20 +107,20 @@ void scanI2Cdevice() screen_found = addr; screen_model = oled_probe(addr); if (screen_model == 1) { - DEBUG_MSG("ssd1306 display found\n"); + LOG_DEBUG("ssd1306 display found\n"); } else if (screen_model == 2) { - DEBUG_MSG("sh1106 display found\n"); + LOG_DEBUG("sh1106 display found\n"); } else { - DEBUG_MSG("unknown display found\n"); + LOG_DEBUG("unknown display found\n"); } } #if !defined(ARCH_PORTDUINO) && !defined(ARCH_STM32WL) if (addr == ATECC608B_ADDR) { keystore_found = addr; if (atecc.begin(keystore_found) == true) { - DEBUG_MSG("ATECC608B initialized\n"); + LOG_DEBUG("ATECC608B initialized\n"); } else { - DEBUG_MSG("ATECC608B initialization failed\n"); + LOG_DEBUG("ATECC608B initialization failed\n"); } printATECCInfo(); } @@ -128,7 +128,7 @@ void scanI2Cdevice() #ifdef RV3028_RTC if (addr == RV3028_RTC){ rtc_found = addr; - DEBUG_MSG("RV3028 RTC found\n"); + LOG_DEBUG("RV3028 RTC found\n"); Melopero_RV3028 rtc; rtc.initI2C(); rtc.writeToRegister(0x35,0x07); // no Clkout @@ -138,7 +138,7 @@ void scanI2Cdevice() #ifdef PCF8563_RTC if (addr == PCF8563_RTC){ rtc_found = addr; - DEBUG_MSG("PCF8563 RTC found\n"); + LOG_DEBUG("PCF8563 RTC found\n"); } #endif if (addr == CARDKB_ADDR) { @@ -146,86 +146,86 @@ void scanI2Cdevice() // Do we have the RAK14006 instead? registerValue = getRegisterValue(addr, 0x04, 1); if (registerValue == 0x02) { // KEYPAD_VERSION - DEBUG_MSG("RAK14004 found\n"); + LOG_DEBUG("RAK14004 found\n"); kb_model = 0x02; } else { - DEBUG_MSG("m5 cardKB found\n"); + LOG_DEBUG("m5 cardKB found\n"); kb_model = 0x00; } } if (addr == ST7567_ADDRESS) { screen_found = addr; - DEBUG_MSG("st7567 display found\n"); + LOG_DEBUG("st7567 display found\n"); } #ifdef HAS_PMU if (addr == XPOWERS_AXP192_AXP2101_ADDRESS) { pmu_found = true; - DEBUG_MSG("axp192/axp2101 PMU found\n"); + LOG_DEBUG("axp192/axp2101 PMU found\n"); } #endif if (addr == BME_ADDR || addr == BME_ADDR_ALTERNATE) { registerValue = getRegisterValue(addr, 0xD0, 1); // GET_ID if (registerValue == 0x61) { - DEBUG_MSG("BME-680 sensor found at address 0x%x\n", (uint8_t)addr); + LOG_DEBUG("BME-680 sensor found at address 0x%x\n", (uint8_t)addr); nodeTelemetrySensorsMap[TelemetrySensorType_BME680] = addr; } else if (registerValue == 0x60) { - DEBUG_MSG("BME-280 sensor found at address 0x%x\n", (uint8_t)addr); + LOG_DEBUG("BME-280 sensor found at address 0x%x\n", (uint8_t)addr); nodeTelemetrySensorsMap[TelemetrySensorType_BME280] = addr; } else { - DEBUG_MSG("BMP-280 sensor found at address 0x%x\n", (uint8_t)addr); + LOG_DEBUG("BMP-280 sensor found at address 0x%x\n", (uint8_t)addr); nodeTelemetrySensorsMap[TelemetrySensorType_BMP280] = addr; } } if (addr == INA_ADDR || addr == INA_ADDR_ALTERNATE) { registerValue = getRegisterValue(addr, 0xFE, 2); - DEBUG_MSG("Register MFG_UID: 0x%x\n", registerValue); + LOG_DEBUG("Register MFG_UID: 0x%x\n", registerValue); if (registerValue == 0x5449) { - DEBUG_MSG("INA260 sensor found at address 0x%x\n", (uint8_t)addr); + LOG_DEBUG("INA260 sensor found at address 0x%x\n", (uint8_t)addr); nodeTelemetrySensorsMap[TelemetrySensorType_INA260] = addr; } else { // Assume INA219 if INA260 ID is not found - DEBUG_MSG("INA219 sensor found at address 0x%x\n", (uint8_t)addr); + LOG_DEBUG("INA219 sensor found at address 0x%x\n", (uint8_t)addr); nodeTelemetrySensorsMap[TelemetrySensorType_INA219] = addr; } } if (addr == MCP9808_ADDR) { nodeTelemetrySensorsMap[TelemetrySensorType_MCP9808] = addr; - DEBUG_MSG("MCP9808 sensor found\n"); + LOG_DEBUG("MCP9808 sensor found\n"); } if (addr == SHT31_ADDR) { - DEBUG_MSG("SHT31 sensor found\n"); + LOG_DEBUG("SHT31 sensor found\n"); nodeTelemetrySensorsMap[TelemetrySensorType_SHT31] = addr; } if (addr == SHTC3_ADDR) { - DEBUG_MSG("SHTC3 sensor found\n"); + LOG_DEBUG("SHTC3 sensor found\n"); nodeTelemetrySensorsMap[TelemetrySensorType_SHTC3] = addr; } if (addr == LPS22HB_ADDR || addr == LPS22HB_ADDR_ALT) { - DEBUG_MSG("LPS22HB sensor found\n"); + LOG_DEBUG("LPS22HB sensor found\n"); nodeTelemetrySensorsMap[TelemetrySensorType_LPS22] = addr; } // High rate sensors, will be processed internally if (addr == QMC6310_ADDR) { - DEBUG_MSG("QMC6310 Highrate 3-Axis magnetic sensor found\n"); + LOG_DEBUG("QMC6310 Highrate 3-Axis magnetic sensor found\n"); nodeTelemetrySensorsMap[TelemetrySensorType_QMC6310] = addr; } if (addr == QMI8658_ADDR) { - DEBUG_MSG("QMI8658 Highrate 6-Axis inertial measurement sensor found\n"); + LOG_DEBUG("QMI8658 Highrate 6-Axis inertial measurement sensor found\n"); nodeTelemetrySensorsMap[TelemetrySensorType_QMI8658] = addr; } if (addr == QMC5883L_ADDR) { - DEBUG_MSG("QMC5883L Highrate 3-Axis magnetic sensor found\n"); + LOG_DEBUG("QMC5883L Highrate 3-Axis magnetic sensor found\n"); nodeTelemetrySensorsMap[TelemetrySensorType_QMC5883L] = addr; } } else if (err == 4) { - DEBUG_MSG("Unknow error at address 0x%x\n", addr); + LOG_DEBUG("Unknow error at address 0x%x\n", addr); } } if (nDevices == 0) - DEBUG_MSG("No I2C devices found\n"); + LOG_DEBUG("No I2C devices found\n"); else - DEBUG_MSG("%i I2C devices found\n",nDevices); + LOG_DEBUG("%i I2C devices found\n",nDevices); } #else void scanI2Cdevice() {} diff --git a/src/gps/GPS.cpp b/src/gps/GPS.cpp index 7e860cdd0a..d8c33a5ea4 100644 --- a/src/gps/GPS.cpp +++ b/src/gps/GPS.cpp @@ -203,7 +203,7 @@ if (!config.position.tx_gpio) 0x80, 0x25, 0x00, 0x00, 0x07, 0x00, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x91, 0xAF}; _serial_gps->write(_message_nmea, sizeof(_message_nmea)); if (!getACK(0x06, 0x00)) { - DEBUG_MSG("WARNING: Unable to enable NMEA Mode.\n"); + LOG_WARN("Unable to enable NMEA Mode.\n"); return true; } */ @@ -214,7 +214,7 @@ if (!config.position.tx_gpio) byte _message_GGL[] = {0xB5, 0x62, 0x06, 0x01, 0x08, 0x00, 0xF0, 0x01, 0x01, 0x00, 0x01, 0x01, 0x01, 0x01, 0x05, 0x3A}; _serial_gps->write(_message_GGL, sizeof(_message_GGL)); if (!getACK(0x06, 0x01)) { - DEBUG_MSG("WARNING: Unable to disable NMEA GGL.\n"); + LOG_WARN("Unable to disable NMEA GGL.\n"); return true; } @@ -222,7 +222,7 @@ if (!config.position.tx_gpio) byte _message_GSA[] = {0xB5, 0x62, 0x06, 0x01, 0x08, 0x00, 0xF0, 0x02, 0x01, 0x00, 0x01, 0x01, 0x01, 0x01, 0x06, 0x41}; _serial_gps->write(_message_GSA, sizeof(_message_GSA)); if (!getACK(0x06, 0x01)) { - DEBUG_MSG("WARNING: Unable to disable NMEA GSA.\n"); + LOG_WARN("Unable to disable NMEA GSA.\n"); return true; } @@ -230,7 +230,7 @@ if (!config.position.tx_gpio) byte _message_GSV[] = {0xB5, 0x62, 0x06, 0x01, 0x08, 0x00, 0xF0, 0x03, 0x01, 0x00, 0x01, 0x01, 0x01, 0x01, 0x07, 0x48}; _serial_gps->write(_message_GSV, sizeof(_message_GSV)); if (!getACK(0x06, 0x01)) { - DEBUG_MSG("WARNING: Unable to disable NMEA GSV.\n"); + LOG_WARN("Unable to disable NMEA GSV.\n"); return true; } @@ -238,7 +238,7 @@ if (!config.position.tx_gpio) byte _message_VTG[] = {0xB5, 0x62, 0x06, 0x01, 0x08, 0x00, 0xF0, 0x05, 0x01, 0x00, 0x01, 0x01, 0x01, 0x01, 0x09, 0x56}; _serial_gps->write(_message_VTG, sizeof(_message_VTG)); if (!getACK(0x06, 0x01)) { - DEBUG_MSG("WARNING: Unable to disable NMEA VTG.\n"); + LOG_WARN("Unable to disable NMEA VTG.\n"); return true; } @@ -246,7 +246,7 @@ if (!config.position.tx_gpio) byte _message_RMC[] = {0xB5, 0x62, 0x06, 0x01, 0x08, 0x00, 0xF0, 0x04, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x09, 0x54}; _serial_gps->write(_message_RMC, sizeof(_message_RMC)); if (!getACK(0x06, 0x01)) { - DEBUG_MSG("WARNING: Unable to enable NMEA RMC.\n"); + LOG_WARN("Unable to enable NMEA RMC.\n"); return true; } @@ -254,7 +254,7 @@ if (!config.position.tx_gpio) byte _message_GGA[] = {0xB5, 0x62, 0x06, 0x01, 0x08, 0x00, 0xF0, 0x00, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x05, 0x38}; _serial_gps->write(_message_GGA, sizeof(_message_GGA)); if (!getACK(0x06, 0x01)) { - DEBUG_MSG("WARNING: Unable to enable NMEA GGA.\n"); + LOG_WARN("Unable to enable NMEA GGA.\n"); } } } @@ -361,12 +361,12 @@ void GPS::setNumSatellites(uint8_t n) void GPS::setAwake(bool on) { if (!wakeAllowed && on) { - DEBUG_MSG("Inhibiting because !wakeAllowed\n"); + LOG_DEBUG("Inhibiting because !wakeAllowed\n"); on = false; } if (isAwake != on) { - DEBUG_MSG("WANT GPS=%d\n", on); + LOG_DEBUG("WANT GPS=%d\n", on); if (on) { lastWakeStartMsec = millis(); wake(); @@ -412,7 +412,7 @@ void GPS::publishUpdate() shouldPublish = false; // In debug logs, identify position by @timestamp:stage (stage 2 = publish) - DEBUG_MSG("publishing pos@%x:2, hasVal=%d, GPSlock=%d\n", p.timestamp, hasValidLocation, hasLock()); + LOG_DEBUG("publishing pos@%x:2, hasVal=%d, GPSlock=%d\n", p.timestamp, hasValidLocation, hasLock()); // Notify any status instances that are observing us const meshtastic::GPSStatus status = meshtastic::GPSStatus(hasValidLocation, isConnected(), isPowerSaving(), p); @@ -429,7 +429,7 @@ int32_t GPS::runOnce() if((config.position.gps_enabled == 1) && (gnssModel == GNSS_MODEL_UBLOX)){ // reset the GPS on next bootup if(devicestate.did_gps_reset && (millis() > 60000) && !hasFlow()) { - DEBUG_MSG("GPS is not communicating, trying factory reset on next bootup.\n"); + LOG_DEBUG("GPS is not communicating, trying factory reset on next bootup.\n"); devicestate.did_gps_reset = false; nodeDB.saveDeviceStateToDisk(); } @@ -447,7 +447,7 @@ int32_t GPS::runOnce() // While we are awake if (isAwake) { - // DEBUG_MSG("looking for location\n"); + // LOG_DEBUG("looking for location\n"); if ((now - lastWhileActiveMsec) > 5000) { lastWhileActiveMsec = now; whileActive(); @@ -462,7 +462,7 @@ int32_t GPS::runOnce() bool gotLoc = lookForLocation(); if (gotLoc && !hasValidLocation) { // declare that we have location ASAP - DEBUG_MSG("hasValidLocation RISING EDGE\n"); + LOG_DEBUG("hasValidLocation RISING EDGE\n"); hasValidLocation = true; shouldPublish = true; } @@ -473,13 +473,13 @@ int32_t GPS::runOnce() bool tooLong = wakeTime != UINT32_MAX && (now - lastWakeStartMsec) > wakeTime; // Once we get a location we no longer desperately want an update - // DEBUG_MSG("gotLoc %d, tooLong %d, gotTime %d\n", gotLoc, tooLong, gotTime); + // LOG_DEBUG("gotLoc %d, tooLong %d, gotTime %d\n", gotLoc, tooLong, gotTime); if ((gotLoc && gotTime) || tooLong) { if (tooLong) { // we didn't get a location during this ack window, therefore declare loss of lock if (hasValidLocation) { - DEBUG_MSG("hasValidLocation FALLING EDGE (last read: %d)\n", gotLoc); + LOG_DEBUG("hasValidLocation FALLING EDGE (last read: %d)\n", gotLoc); } p = Position_init_default; hasValidLocation = false; @@ -501,7 +501,7 @@ int32_t GPS::runOnce() void GPS::forceWake(bool on) { if (on) { - DEBUG_MSG("Allowing GPS lock\n"); + LOG_DEBUG("Allowing GPS lock\n"); // lastSleepStartMsec = 0; // Force an update ASAP wakeAllowed = true; } else { @@ -516,7 +516,7 @@ void GPS::forceWake(bool on) /// Prepare the GPS for the cpu entering deep or light sleep, expect to be gone for at least 100s of msecs int GPS::prepareSleep(void *unused) { - DEBUG_MSG("GPS prepare sleep!\n"); + LOG_DEBUG("GPS prepare sleep!\n"); forceWake(false); return 0; @@ -525,7 +525,7 @@ int GPS::prepareSleep(void *unused) /// Prepare the GPS for the cpu entering deep or light sleep, expect to be gone for at least 100s of msecs int GPS::prepareDeepSleep(void *unused) { - DEBUG_MSG("GPS deep sleep!\n"); + LOG_DEBUG("GPS deep sleep!\n"); // For deep sleep we also want abandon any lock attempts (because we want minimum power) getSleepTime(); @@ -568,7 +568,7 @@ GnssModel_t GPS::probe() if(index != -1){ ver = ver.substring(index); if (ver.startsWith("$GPTXT,01,01,02")) { - DEBUG_MSG("L76K GNSS init succeeded, using L76K GNSS Module\n"); + LOG_DEBUG("L76K GNSS init succeeded, using L76K GNSS Module\n"); return GNSS_MODEL_MTK; } } @@ -580,7 +580,7 @@ GnssModel_t GPS::probe() _serial_gps->write(cfg_rate, sizeof(cfg_rate)); // Check that the returned response class and message ID are correct if (!getAck(buffer, 256, 0x06, 0x08)) { - DEBUG_MSG("Warning: Failed to find UBlox & MTK GNSS Module\n"); + LOG_WARN("Failed to find UBlox & MTK GNSS Module\n"); return GNSS_MODEL_UNKONW; } @@ -611,12 +611,12 @@ GnssModel_t GPS::probe() break; } - DEBUG_MSG("Module Info : \n"); - DEBUG_MSG("Soft version: %s\n",info.swVersion); - DEBUG_MSG("Hard version: %s\n",info.hwVersion); - DEBUG_MSG("Extensions:%d\n",info.extensionNo); + LOG_DEBUG("Module Info : \n"); + LOG_DEBUG("Soft version: %s\n",info.swVersion); + LOG_DEBUG("Hard version: %s\n",info.hwVersion); + LOG_DEBUG("Extensions:%d\n",info.extensionNo); for (int i = 0; i < info.extensionNo; i++) { - DEBUG_MSG(" %s\n",info.extension[i]); + LOG_DEBUG(" %s\n",info.extension[i]); } memset(buffer,0,sizeof(buffer)); @@ -625,15 +625,15 @@ GnssModel_t GPS::probe() for (int i = 0; i < info.extensionNo; ++i) { if (!strncmp(info.extension[i], "OD=", 3)) { strcpy((char *)buffer, &(info.extension[i][3])); - DEBUG_MSG("GetModel:%s\n",(char *)buffer); + LOG_DEBUG("GetModel:%s\n",(char *)buffer); } } } if (strlen((char*)buffer)) { - DEBUG_MSG("UBlox GNSS init succeeded, using UBlox %s GNSS Module\n" , buffer); + LOG_DEBUG("UBlox GNSS init succeeded, using UBlox %s GNSS Module\n" , buffer); }else{ - DEBUG_MSG("UBlox GNSS init succeeded, using UBlox GNSS Module\n"); + LOG_DEBUG("UBlox GNSS init succeeded, using UBlox GNSS Module\n"); } return GNSS_MODEL_UBLOX; @@ -652,9 +652,9 @@ GPS *createGps() #else if (config.position.gps_enabled) { #ifdef GPS_ALTITUDE_HAE - DEBUG_MSG("Using HAE altitude model\n"); + LOG_DEBUG("Using HAE altitude model\n"); #else - DEBUG_MSG("Using MSL altitude model\n"); + LOG_DEBUG("Using MSL altitude model\n"); #endif if (GPS::_serial_gps) { // Some boards might have only the TX line from the GPS connected, in that case, we can't configure it at all. Just diff --git a/src/gps/NMEAGPS.cpp b/src/gps/NMEAGPS.cpp index 0ff302baba..a99b558732 100644 --- a/src/gps/NMEAGPS.cpp +++ b/src/gps/NMEAGPS.cpp @@ -53,9 +53,9 @@ bool NMEAGPS::setupGPS() // see NMEAGPS.h gsafixtype.begin(reader, NMEA_MSG_GXGSA, 2); gsapdop.begin(reader, NMEA_MSG_GXGSA, 15); - DEBUG_MSG("Using " NMEA_MSG_GXGSA " for 3DFIX and PDOP\n"); + LOG_DEBUG("Using " NMEA_MSG_GXGSA " for 3DFIX and PDOP\n"); #else - DEBUG_MSG("GxGSA NOT available\n"); + LOG_DEBUG("GxGSA NOT available\n"); #endif return true; @@ -85,7 +85,7 @@ The Unix epoch (or Unix time or POSIX time or Unix timestamp) is the number of s t.tm_year = d.year() - 1900; t.tm_isdst = false; if (t.tm_mon > -1){ - DEBUG_MSG("NMEA GPS time %02d-%02d-%02d %02d:%02d:%02d\n", d.year(), d.month(), t.tm_mday, t.tm_hour, t.tm_min, t.tm_sec); + LOG_DEBUG("NMEA GPS time %02d-%02d-%02d %02d:%02d:%02d\n", d.year(), d.month(), t.tm_mday, t.tm_hour, t.tm_min, t.tm_sec); perhapsSetRTC(RTCQualityGPS, t); return true; } else @@ -109,7 +109,7 @@ bool NMEAGPS::lookForLocation() #ifndef TINYGPS_OPTION_NO_CUSTOM_FIELDS fixType = atoi(gsafixtype.value()); // will set to zero if no data - // DEBUG_MSG("FIX QUAL=%d, TYPE=%d\n", fixQual, fixType); + // LOG_DEBUG("FIX QUAL=%d, TYPE=%d\n", fixQual, fixType); #endif // check if GPS has an acceptable lock @@ -117,7 +117,7 @@ bool NMEAGPS::lookForLocation() return false; #ifdef GPS_EXTRAVERBOSE - DEBUG_MSG("AGE: LOC=%d FIX=%d DATE=%d TIME=%d\n", + LOG_DEBUG("AGE: LOC=%d FIX=%d DATE=%d TIME=%d\n", reader.location.age(), #ifndef TINYGPS_OPTION_NO_CUSTOM_FIELDS gsafixtype.age(), @@ -137,7 +137,7 @@ bool NMEAGPS::lookForLocation() (reader.time.age() < GPS_SOL_EXPIRY_MS) && (reader.date.age() < GPS_SOL_EXPIRY_MS))) { - DEBUG_MSG("SOME data is TOO OLD: LOC %u, TIME %u, DATE %u\n", reader.location.age(), reader.time.age(), reader.date.age()); + LOG_DEBUG("SOME data is TOO OLD: LOC %u, TIME %u, DATE %u\n", reader.location.age(), reader.time.age(), reader.date.age()); return false; } @@ -151,13 +151,13 @@ bool NMEAGPS::lookForLocation() // Bail out EARLY to avoid overwriting previous good data (like #857) if (toDegInt(loc.lat) > 900000000) { #ifdef GPS_EXTRAVERBOSE - DEBUG_MSG("Bail out EARLY on LAT %i\n",toDegInt(loc.lat)); + LOG_DEBUG("Bail out EARLY on LAT %i\n",toDegInt(loc.lat)); #endif return false; } if (toDegInt(loc.lng) > 1800000000) { #ifdef GPS_EXTRAVERBOSE - DEBUG_MSG("Bail out EARLY on LNG %i\n",toDegInt(loc.lng)); + LOG_DEBUG("Bail out EARLY on LNG %i\n",toDegInt(loc.lng)); #endif return false; } @@ -168,7 +168,7 @@ bool NMEAGPS::lookForLocation() #ifndef TINYGPS_OPTION_NO_CUSTOM_FIELDS p.HDOP = reader.hdop.value(); p.PDOP = TinyGPSPlus::parseDecimal(gsapdop.value()); - // DEBUG_MSG("PDOP=%d, HDOP=%d\n", p.PDOP, p.HDOP); + // LOG_DEBUG("PDOP=%d, HDOP=%d\n", p.PDOP, p.HDOP); #else // FIXME! naive PDOP emulation (assumes VDOP==HDOP) // correct formula is PDOP = SQRT(HDOP^2 + VDOP^2) @@ -212,7 +212,7 @@ bool NMEAGPS::lookForLocation() if (reader.course.value() < 36000) { // sanity check p.ground_track = reader.course.value() * 1e3; // Scale the heading (in degrees * 10^-2) to match the expected degrees * 10^-5 } else { - DEBUG_MSG("BOGUS course.value() REJECTED: %d\n", + LOG_DEBUG("BOGUS course.value() REJECTED: %d\n", reader.course.value()); } } @@ -251,7 +251,7 @@ bool NMEAGPS::whileIdle() // First consume any chars that have piled up at the receiver while (_serial_gps->available() > 0) { int c = _serial_gps->read(); - // DEBUG_MSG("%c", c); + // LOG_DEBUG("%c", c); isValid |= reader.encode(c); } diff --git a/src/gps/RTC.cpp b/src/gps/RTC.cpp index e04f903ee3..e61991917b 100644 --- a/src/gps/RTC.cpp +++ b/src/gps/RTC.cpp @@ -33,7 +33,7 @@ void readFromRTC() t.tm_sec = rtc.getSecond(); tv.tv_sec = mktime(&t); tv.tv_usec = 0; - DEBUG_MSG("Read RTC time from RV3028 as %ld\n", tv.tv_sec); + LOG_DEBUG("Read RTC time from RV3028 as %ld\n", tv.tv_sec); timeStartMsec = now; zeroOffsetSecs = tv.tv_sec; if (currentQuality == RTCQualityNone) { @@ -59,7 +59,7 @@ void readFromRTC() t.tm_sec = tc.second; tv.tv_sec = mktime(&t); tv.tv_usec = 0; - DEBUG_MSG("Read RTC time from PCF8563 as %ld\n", tv.tv_sec); + LOG_DEBUG("Read RTC time from PCF8563 as %ld\n", tv.tv_sec); timeStartMsec = now; zeroOffsetSecs = tv.tv_sec; if (currentQuality == RTCQualityNone) { @@ -69,7 +69,7 @@ void readFromRTC() #else if (!gettimeofday(&tv, NULL)) { uint32_t now = millis(); - DEBUG_MSG("Read RTC time as %ld\n", tv.tv_sec); + LOG_DEBUG("Read RTC time as %ld\n", tv.tv_sec); timeStartMsec = now; zeroOffsetSecs = tv.tv_sec; } @@ -86,11 +86,11 @@ bool perhapsSetRTC(RTCQuality q, const struct timeval *tv) if (q > currentQuality) { currentQuality = q; shouldSet = true; - DEBUG_MSG("Upgrading time to RTC %ld secs (quality %d)\n", tv->tv_sec, q); + LOG_DEBUG("Upgrading time to RTC %ld secs (quality %d)\n", tv->tv_sec, q); } else if(q == RTCQualityGPS && (now - lastSetMsec) > (12 * 60 * 60 * 1000UL)) { // Every 12 hrs we will slam in a new GPS time, to correct for local RTC clock drift shouldSet = true; - DEBUG_MSG("Reapplying external time to correct clock drift %ld secs\n", tv->tv_sec); + LOG_DEBUG("Reapplying external time to correct clock drift %ld secs\n", tv->tv_sec); } else shouldSet = false; @@ -109,7 +109,7 @@ bool perhapsSetRTC(RTCQuality q, const struct timeval *tv) rtc.initI2C(); tm *t = localtime(&tv->tv_sec); rtc.setTime(t->tm_year + 1900, t->tm_mon + 1, t->tm_wday, t->tm_mday, t->tm_hour, t->tm_min, t->tm_sec); - DEBUG_MSG("RV3028_RTC setTime %02d-%02d-%02d %02d:%02d:%02d %ld\n", t->tm_year + 1900, t->tm_mon + 1, t->tm_mday, t->tm_hour, t->tm_min, t->tm_sec, tv->tv_sec); + LOG_DEBUG("RV3028_RTC setTime %02d-%02d-%02d %02d:%02d:%02d %ld\n", t->tm_year + 1900, t->tm_mon + 1, t->tm_mday, t->tm_hour, t->tm_min, t->tm_sec, tv->tv_sec); } #elif defined(PCF8563_RTC) if(rtc_found == PCF8563_RTC) { @@ -121,7 +121,7 @@ bool perhapsSetRTC(RTCQuality q, const struct timeval *tv) #endif tm *t = localtime(&tv->tv_sec); rtc.setDateTime(t->tm_year + 1900, t->tm_mon + 1, t->tm_mday, t->tm_hour, t->tm_min, t->tm_sec); - DEBUG_MSG("PCF8563_RTC setDateTime %02d-%02d-%02d %02d:%02d:%02d %ld\n", t->tm_year + 1900, t->tm_mon + 1, t->tm_mday, t->tm_hour, t->tm_min, t->tm_sec, tv->tv_sec); + LOG_DEBUG("PCF8563_RTC setDateTime %02d-%02d-%02d %02d:%02d:%02d %ld\n", t->tm_year + 1900, t->tm_mon + 1, t->tm_mday, t->tm_hour, t->tm_min, t->tm_sec, tv->tv_sec); } #elif defined(ARCH_ESP32) settimeofday(tv, NULL); @@ -149,9 +149,9 @@ bool perhapsSetRTC(RTCQuality q, struct tm &t) tv.tv_sec = res; tv.tv_usec = 0; // time.centisecond() * (10 / 1000); - // DEBUG_MSG("Got time from GPS month=%d, year=%d, unixtime=%ld\n", t.tm_mon, t.tm_year, tv.tv_sec); + // LOG_DEBUG("Got time from GPS month=%d, year=%d, unixtime=%ld\n", t.tm_mon, t.tm_year, tv.tv_sec); if (t.tm_year < 0 || t.tm_year >= 300) { - // DEBUG_MSG("Ignoring invalid GPS month=%d, year=%d, unixtime=%ld\n", t.tm_mon, t.tm_year, tv.tv_sec); + // LOG_DEBUG("Ignoring invalid GPS month=%d, year=%d, unixtime=%ld\n", t.tm_mon, t.tm_year, tv.tv_sec); return false; } else { return perhapsSetRTC(q, &tv); diff --git a/src/graphics/EInkDisplay2.cpp b/src/graphics/EInkDisplay2.cpp index 9e08349542..a7ec5e0560 100644 --- a/src/graphics/EInkDisplay2.cpp +++ b/src/graphics/EInkDisplay2.cpp @@ -103,7 +103,7 @@ bool EInkDisplay::forceDisplay(uint32_t msecLimit) } } - DEBUG_MSG("Updating E-Paper... "); + LOG_DEBUG("Updating E-Paper... "); #if defined(TTGO_T_ECHO) // ePaper.Reset(); // wake the screen from sleep @@ -128,11 +128,11 @@ bool EInkDisplay::forceDisplay(uint32_t msecLimit) // Put screen to sleep to save power (possibly not necessary because we already did poweroff inside of display) adafruitDisplay->hibernate(); - DEBUG_MSG("done\n"); + LOG_DEBUG("done\n"); return true; } else { - // DEBUG_MSG("Skipping eink display\n"); + // LOG_DEBUG("Skipping eink display\n"); return false; } } @@ -162,7 +162,7 @@ void EInkDisplay::setDetected(uint8_t detected) // Connect to the display bool EInkDisplay::connect() { - DEBUG_MSG("Doing EInk init\n"); + LOG_DEBUG("Doing EInk init\n"); #ifdef PIN_EINK_PWR_ON digitalWrite(PIN_EINK_PWR_ON, HIGH); // If we need to assert a pin to power external peripherals diff --git a/src/graphics/Screen.cpp b/src/graphics/Screen.cpp index 02159940a1..426d5f2cd2 100644 --- a/src/graphics/Screen.cpp +++ b/src/graphics/Screen.cpp @@ -276,9 +276,9 @@ static void drawModuleFrame(OLEDDisplay *display, OLEDDisplayUiState *state, int } else { // otherwise, just display the module frame that's aligned with the current frame module_frame = state->currentFrame; - // DEBUG_MSG("Screen is not in transition. Frame: %d\n\n", module_frame); + // LOG_DEBUG("Screen is not in transition. Frame: %d\n\n", module_frame); } - // DEBUG_MSG("Drawing Module Frame %d\n\n", module_frame); + // LOG_DEBUG("Drawing Module Frame %d\n\n", module_frame); MeshModule &pi = *moduleFrames.at(module_frame); pi.drawFrame(display, state, x, y); } @@ -368,7 +368,7 @@ static void drawTextMessageFrame(OLEDDisplay *display, OLEDDisplayUiState *state MeshPacket &mp = devicestate.rx_text_message; NodeInfo *node = nodeDB.getNode(getFrom(&mp)); - // DEBUG_MSG("drawing text message from 0x%x: %s\n", mp.from, + // LOG_DEBUG("drawing text message from 0x%x: %s\n", mp.from, // mp.decoded.variant.data.decoded.bytes); // Demo for drawStringMaxWidth: @@ -882,7 +882,7 @@ static void drawNodeInfo(OLEDDisplay *display, OLEDDisplayUiState *state, int16_ if (!hasNodeHeading) { // direction to node is unknown so display question mark // Debug info for gps lock errors - // DEBUG_MSG("ourNode %d, ourPos %d, theirPos %d\n", !!ourNode, ourNode && hasPosition(ourNode), hasPosition(node)); + // LOG_DEBUG("ourNode %d, ourPos %d, theirPos %d\n", !!ourNode, ourNode && hasPosition(ourNode), hasPosition(node)); display->drawString(compassX - FONT_HEIGHT_SMALL / 4, compassY - FONT_HEIGHT_SMALL / 2, "?"); } display->drawCircle(compassX, compassY, getCompassDiam(display) / 2); @@ -936,14 +936,14 @@ void Screen::handleSetOn(bool on) if (on != screenOn) { if (on) { - DEBUG_MSG("Turning on screen\n"); + LOG_DEBUG("Turning on screen\n"); dispdev.displayOn(); dispdev.displayOn(); enabled = true; setInterval(0); // Draw ASAP runASAP = true; } else { - DEBUG_MSG("Turning off screen\n"); + LOG_DEBUG("Turning off screen\n"); dispdev.displayOff(); enabled = false; } @@ -1056,7 +1056,7 @@ int32_t Screen::runOnce() // serialSinceMsec adjusts for additional serial wait time during nRF52 bootup static bool showingBootScreen = true; if (showingBootScreen && (millis() > (logo_timeout + serialSinceMsec))) { - DEBUG_MSG("Done with boot screen...\n"); + LOG_DEBUG("Done with boot screen...\n"); stopBootScreen(); showingBootScreen = false; } @@ -1065,7 +1065,7 @@ int32_t Screen::runOnce() if (strlen(oemStore.oem_text) > 0) { static bool showingOEMBootScreen = true; if (showingOEMBootScreen && (millis() > ((logo_timeout / 2) + serialSinceMsec))) { - DEBUG_MSG("Switch to OEM screen...\n"); + LOG_DEBUG("Switch to OEM screen...\n"); // Change frames. static FrameCallback bootOEMFrames[] = {drawOEMBootScreen}; static const int bootOEMFrameCount = sizeof(bootOEMFrames) / sizeof(bootOEMFrames[0]); @@ -1127,7 +1127,7 @@ int32_t Screen::runOnce() handleRebootScreen(); break; default: - DEBUG_MSG("BUG: invalid cmd\n"); + LOG_DEBUG("BUG: invalid cmd\n"); } } @@ -1158,12 +1158,12 @@ int32_t Screen::runOnce() // standard screen loop handling here if (config.display.auto_screen_carousel_secs > 0 && (millis() - lastScreenTransition) > (config.display.auto_screen_carousel_secs * 1000)) { - DEBUG_MSG("LastScreenTransition exceeded %ums transitioning to next frame\n", (millis() - lastScreenTransition)); + LOG_DEBUG("LastScreenTransition exceeded %ums transitioning to next frame\n", (millis() - lastScreenTransition)); handleOnPress(); } } - // DEBUG_MSG("want fps %d, fixed=%d\n", targetFramerate, + // LOG_DEBUG("want fps %d, fixed=%d\n", targetFramerate, // ui.getUiState()->frameState); If we are scrolling we need to be called // soon, otherwise just 1 fps (to save CPU) We also ask to be called twice // as fast as we really need so that any rounding errors still result with @@ -1194,7 +1194,7 @@ void Screen::drawDebugInfoWiFiTrampoline(OLEDDisplay *display, OLEDDisplayUiStat void Screen::setSSLFrames() { if (address_found) { - // DEBUG_MSG("showing SSL frames\n"); + // LOG_DEBUG("showing SSL frames\n"); static FrameCallback sslFrames[] = {drawSSLScreen}; ui.setFrames(sslFrames, 1); ui.update(); @@ -1206,7 +1206,7 @@ void Screen::setSSLFrames() void Screen::setWelcomeFrames() { if (address_found) { - // DEBUG_MSG("showing Welcome frames\n"); + // LOG_DEBUG("showing Welcome frames\n"); ui.disableAllIndicators(); static FrameCallback welcomeFrames[] = {drawWelcomeScreen}; @@ -1218,13 +1218,13 @@ void Screen::setWelcomeFrames() // restore our regular frame list void Screen::setFrames() { - DEBUG_MSG("showing standard frames\n"); + LOG_DEBUG("showing standard frames\n"); showingNormalScreen = true; moduleFrames = MeshModule::GetMeshModulesWithUIFrames(); - DEBUG_MSG("Showing %d module frames\n", moduleFrames.size()); + LOG_DEBUG("Showing %d module frames\n", moduleFrames.size()); int totalFrameCount = MAX_NUM_NODES + NUM_EXTRA_FRAMES + moduleFrames.size(); - DEBUG_MSG("Total frame count: %d\n", totalFrameCount); + LOG_DEBUG("Total frame count: %d\n", totalFrameCount); // We don't show the node info our our node (if we have it yet - we should) size_t numnodes = nodeStatus->getNumTotal(); @@ -1243,7 +1243,7 @@ void Screen::setFrames() normalFrames[numframes++] = drawModuleFrame; } - DEBUG_MSG("Added modules. numframes: %d\n", numframes); + LOG_DEBUG("Added modules. numframes: %d\n", numframes); // If we have a critical fault, show it first if (myNodeInfo.error_code) @@ -1276,7 +1276,7 @@ void Screen::setFrames() } #endif - DEBUG_MSG("Finished building frames. numframes: %d\n", numframes); + LOG_DEBUG("Finished building frames. numframes: %d\n", numframes); ui.setFrames(normalFrames, numframes); ui.enableAllIndicators(); @@ -1289,7 +1289,7 @@ void Screen::setFrames() void Screen::handleStartBluetoothPinScreen(uint32_t pin) { - DEBUG_MSG("showing bluetooth screen\n"); + LOG_DEBUG("showing bluetooth screen\n"); showingNormalScreen = false; static FrameCallback btFrames[] = {drawFrameBluetooth}; @@ -1303,7 +1303,7 @@ void Screen::handleStartBluetoothPinScreen(uint32_t pin) void Screen::handleShutdownScreen() { - DEBUG_MSG("showing shutdown screen\n"); + LOG_DEBUG("showing shutdown screen\n"); showingNormalScreen = false; static FrameCallback shutdownFrames[] = {drawFrameShutdown}; @@ -1315,7 +1315,7 @@ void Screen::handleShutdownScreen() void Screen::handleRebootScreen() { - DEBUG_MSG("showing reboot screen\n"); + LOG_DEBUG("showing reboot screen\n"); showingNormalScreen = false; static FrameCallback rebootFrames[] = {drawFrameReboot}; @@ -1327,7 +1327,7 @@ void Screen::handleRebootScreen() void Screen::handleStartFirmwareUpdateScreen() { - DEBUG_MSG("showing firmware screen\n"); + LOG_DEBUG("showing firmware screen\n"); showingNormalScreen = false; static FrameCallback btFrames[] = {drawFrameFirmware}; @@ -1358,7 +1358,7 @@ void Screen::handlePrint(const char *text) { // the string passed into us probably has a newline, but that would confuse the logging system // so strip it - DEBUG_MSG("Screen: %.*s\n", strlen(text) - 1, text); + LOG_DEBUG("Screen: %.*s\n", strlen(text) - 1, text); if (!useDisplay || !showingNormalScreen) return; @@ -1778,7 +1778,7 @@ void Screen::adjustBrightness() int Screen::handleStatusUpdate(const meshtastic::Status *arg) { - // DEBUG_MSG("Screen got status update %d\n", arg->getStatusType()); + // LOG_DEBUG("Screen got status update %d\n", arg->getStatusType()); switch (arg->getStatusType()) { case STATUS_TYPE_NODE: if (showingNormalScreen && nodeStatus->getLastNumTotal() != nodeStatus->getNumTotal()) { diff --git a/src/graphics/TFTDisplay.cpp b/src/graphics/TFTDisplay.cpp index 1d5f43cd1e..083ee273c7 100644 --- a/src/graphics/TFTDisplay.cpp +++ b/src/graphics/TFTDisplay.cpp @@ -59,7 +59,7 @@ void TFTDisplay::setDetected(uint8_t detected) bool TFTDisplay::connect() { concurrency::LockGuard g(spiLock); - DEBUG_MSG("Doing TFT init\n"); + LOG_DEBUG("Doing TFT init\n"); #ifdef TFT_BL digitalWrite(TFT_BL, HIGH); diff --git a/src/input/RotaryEncoderInterruptBase.cpp b/src/input/RotaryEncoderInterruptBase.cpp index 6914824fdb..0f75c3a5af 100644 --- a/src/input/RotaryEncoderInterruptBase.cpp +++ b/src/input/RotaryEncoderInterruptBase.cpp @@ -28,7 +28,7 @@ void RotaryEncoderInterruptBase::init( this->rotaryLevelA = digitalRead(this->_pinA); this->rotaryLevelB = digitalRead(this->_pinB); - DEBUG_MSG("Rotary initialized (%d, %d, %d)\n", this->_pinA, this->_pinB, pinPress); + LOG_DEBUG("Rotary initialized (%d, %d, %d)\n", this->_pinA, this->_pinB, pinPress); } int32_t RotaryEncoderInterruptBase::runOnce() @@ -38,13 +38,13 @@ int32_t RotaryEncoderInterruptBase::runOnce() e.source = this->_originName; if (this->action == ROTARY_ACTION_PRESSED) { - DEBUG_MSG("Rotary event Press\n"); + LOG_DEBUG("Rotary event Press\n"); e.inputEvent = this->_eventPressed; } else if (this->action == ROTARY_ACTION_CW) { - DEBUG_MSG("Rotary event CW\n"); + LOG_DEBUG("Rotary event CW\n"); e.inputEvent = this->_eventCw; } else if (this->action == ROTARY_ACTION_CCW) { - DEBUG_MSG("Rotary event CCW\n"); + LOG_DEBUG("Rotary event CCW\n"); e.inputEvent = this->_eventCcw; } @@ -104,7 +104,7 @@ RotaryEncoderInterruptBaseStateType RotaryEncoderInterruptBase::intHandler(bool newState = ROTARY_EVENT_OCCURRED; if ((this->action != ROTARY_ACTION_PRESSED) && (this->action != action)) { this->action = action; - DEBUG_MSG("Rotary action\n"); + LOG_DEBUG("Rotary action\n"); } } } else if (!actualPinRaising && (otherPinLevel == HIGH)) { diff --git a/src/input/UpDownInterruptBase.cpp b/src/input/UpDownInterruptBase.cpp index 31edc848b2..5a0f251583 100644 --- a/src/input/UpDownInterruptBase.cpp +++ b/src/input/UpDownInterruptBase.cpp @@ -26,7 +26,7 @@ void UpDownInterruptBase::init( attachInterrupt(this->_pinDown, onIntDown, RISING); attachInterrupt(this->_pinUp, onIntUp, RISING); - DEBUG_MSG("GPIO initialized (%d, %d, %d)\n", + LOG_DEBUG("GPIO initialized (%d, %d, %d)\n", this->_pinDown, this->_pinUp, pinPress); } @@ -34,7 +34,7 @@ void UpDownInterruptBase::intPressHandler() { InputEvent e; e.source = this->_originName; - DEBUG_MSG("GPIO event Press\n"); + LOG_DEBUG("GPIO event Press\n"); e.inputEvent = this->_eventPressed; this->notifyObservers(&e); } @@ -43,7 +43,7 @@ void UpDownInterruptBase::intDownHandler() { InputEvent e; e.source = this->_originName; - DEBUG_MSG("GPIO event Down\n"); + LOG_DEBUG("GPIO event Down\n"); e.inputEvent = this->_eventDown; this->notifyObservers(&e); } @@ -52,7 +52,7 @@ void UpDownInterruptBase::intUpHandler() { InputEvent e; e.source = this->_originName; - DEBUG_MSG("GPIO event Up\n"); + LOG_DEBUG("GPIO event Up\n"); e.inputEvent = this->_eventUp; this->notifyObservers(&e); } diff --git a/src/input/kbI2cBase.cpp b/src/input/kbI2cBase.cpp index 332dfde0d0..a857bae77b 100644 --- a/src/input/kbI2cBase.cpp +++ b/src/input/kbI2cBase.cpp @@ -56,7 +56,7 @@ int32_t KbI2cBase::runOnce() } } if (PrintDataBuf != 0) { - DEBUG_MSG("RAK14004 key 0x%x pressed\n", PrintDataBuf); + LOG_DEBUG("RAK14004 key 0x%x pressed\n", PrintDataBuf); InputEvent e; e.inputEvent = MATRIXKEY; e.source = this->_originName; diff --git a/src/main.cpp b/src/main.cpp index f999ac708c..6f25ac1f7e 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -174,7 +174,7 @@ void setup() serialSinceMsec = millis(); - DEBUG_MSG("\n\n//\\ E S H T /\\ S T / C\n\n"); + LOG_INFO("\n\n//\\ E S H T /\\ S T / C\n\n"); initDeepSleep(); @@ -256,7 +256,7 @@ void setup() Wire1.beginTransmission(PCF8563_RTC); if (Wire1.endTransmission() == 0){ rtc_found = PCF8563_RTC; - DEBUG_MSG("PCF8563 RTC found\n"); + LOG_DEBUG("PCF8563 RTC found\n"); } #endif @@ -282,7 +282,7 @@ void setup() #endif // Hello - DEBUG_MSG("Meshtastic hwvendor=%d, swver=%s\n", HW_VENDOR, optstr(APP_VERSION)); + LOG_INFO("Meshtastic hwvendor=%d, swver=%s\n", HW_VENDOR, optstr(APP_VERSION)); #ifdef ARCH_ESP32 // Don't init display if we don't have one or we are waking headless due to a timer event @@ -325,7 +325,7 @@ void setup() if (gps) gpsStatus->observe(&gps->newStatus); else - DEBUG_MSG("Warning: No GPS found - running without GPS\n"); + LOG_WARN("No GPS found - running without GPS\n"); nodeStatus->observe(&nodeDB.newStatus); @@ -355,7 +355,7 @@ void setup() // ONCE we will factory reset the GPS for bug #327 if (gps && !devicestate.did_gps_reset) { - DEBUG_MSG("GPS FactoryReset requested\n"); + LOG_WARN("GPS FactoryReset requested\n"); if (gps->factoryReset()) { // If we don't succeed try again next time devicestate.did_gps_reset = true; nodeDB.saveToDisk(SEGMENT_DEVICESTATE); @@ -374,11 +374,11 @@ void setup() if (!rIf) { rIf = new RF95Interface(RF95_NSS, RF95_IRQ, RF95_RESET, SPI); if (!rIf->init()) { - DEBUG_MSG("Warning: Failed to find RF95 radio\n"); + LOG_WARN("Failed to find RF95 radio\n"); delete rIf; rIf = NULL; } else { - DEBUG_MSG("RF95 Radio init succeeded, using RF95 radio\n"); + LOG_DEBUG("RF95 Radio init succeeded, using RF95 radio\n"); } } #endif @@ -387,11 +387,11 @@ void setup() if (!rIf) { rIf = new SX1280Interface(SX128X_CS, SX128X_DIO1, SX128X_RESET, SX128X_BUSY, SPI); if (!rIf->init()) { - DEBUG_MSG("Warning: Failed to find SX1280 radio\n"); + LOG_WARN("Failed to find SX1280 radio\n"); delete rIf; rIf = NULL; } else { - DEBUG_MSG("SX1280 Radio init succeeded, using SX1280 radio\n"); + LOG_DEBUG("SX1280 Radio init succeeded, using SX1280 radio\n"); } } #endif @@ -400,11 +400,11 @@ void setup() if (!rIf) { rIf = new SX1262Interface(SX126X_CS, SX126X_DIO1, SX126X_RESET, SX126X_BUSY, SPI); if (!rIf->init()) { - DEBUG_MSG("Warning: Failed to find SX1262 radio\n"); + LOG_WARN("Failed to find SX1262 radio\n"); delete rIf; rIf = NULL; } else { - DEBUG_MSG("SX1262 Radio init succeeded, using SX1262 radio\n"); + LOG_DEBUG("SX1262 Radio init succeeded, using SX1262 radio\n"); } } #endif @@ -413,11 +413,11 @@ void setup() if (!rIf) { rIf = new SX1268Interface(SX126X_CS, SX126X_DIO1, SX126X_RESET, SX126X_BUSY, SPI); if (!rIf->init()) { - DEBUG_MSG("Warning: Failed to find SX1268 radio\n"); + LOG_WARN("Failed to find SX1268 radio\n"); delete rIf; rIf = NULL; } else { - DEBUG_MSG("SX1268 Radio init succeeded, using SX1268 radio\n"); + LOG_DEBUG("SX1268 Radio init succeeded, using SX1268 radio\n"); } } #endif @@ -426,11 +426,11 @@ void setup() if (!rIf) { rIf = new LLCC68Interface(SX126X_CS, SX126X_DIO1, SX126X_RESET, SX126X_BUSY, SPI); if (!rIf->init()) { - DEBUG_MSG("Warning: Failed to find LLCC68 radio\n"); + LOG_WARN("Failed to find LLCC68 radio\n"); delete rIf; rIf = NULL; } else { - DEBUG_MSG("LLCC68 Radio init succeeded, using LLCC68 radio\n"); + LOG_DEBUG("LLCC68 Radio init succeeded, using LLCC68 radio\n"); } } #endif @@ -439,11 +439,11 @@ void setup() if (!rIf) { rIf = new SimRadio; if (!rIf->init()) { - DEBUG_MSG("Warning: Failed to find simulated radio\n"); + LOG_WARN("Failed to find simulated radio\n"); delete rIf; rIf = NULL; } else { - DEBUG_MSG("Using SIMULATED radio!\n"); + LOG_DEBUG("Using SIMULATED radio!\n"); } } #endif @@ -451,11 +451,11 @@ void setup() // check if the radio chip matches the selected region if((config.lora.region == Config_LoRaConfig_RegionCode_LORA_24) && (!rIf->wideLora())){ - DEBUG_MSG("Warning: Radio chip does not support 2.4GHz LoRa. Reverting to unset.\n"); + LOG_WARN("Radio chip does not support 2.4GHz LoRa. Reverting to unset.\n"); config.lora.region = Config_LoRaConfig_RegionCode_UNSET; nodeDB.saveToDisk(SEGMENT_CONFIG); if(!rIf->reconfigure()) { - DEBUG_MSG("Reconfigure failed, rebooting\n"); + LOG_WARN("Reconfigure failed, rebooting\n"); screen->startRebootScreen(); rebootAtMsec = millis() + 5000; } @@ -493,7 +493,7 @@ if((config.lora.region == Config_LoRaConfig_RegionCode_LORA_24) && (!rIf->wideLo // Calculate and save the bit rate to myNodeInfo // TODO: This needs to be added what ever method changes the channel from the phone. myNodeInfo.bitrate = (float(Constants_DATA_PAYLOAD_LEN) / (float(rIf->getPacketTime(Constants_DATA_PAYLOAD_LEN)))) * 1000; - DEBUG_MSG("myNodeInfo.bitrate = %f bytes / sec\n", myNodeInfo.bitrate); + LOG_DEBUG("myNodeInfo.bitrate = %f bytes / sec\n", myNodeInfo.bitrate); } // This must be _after_ service.init because we need our preferences loaded from flash to have proper timeout values @@ -546,13 +546,13 @@ void loop() long delayMsec = mainController.runOrDelay(); /* if (mainController.nextThread && delayMsec) - DEBUG_MSG("Next %s in %ld\n", mainController.nextThread->ThreadName.c_str(), + LOG_DEBUG("Next %s in %ld\n", mainController.nextThread->ThreadName.c_str(), mainController.nextThread->tillRun(millis())); */ // We want to sleep as long as possible here - because it saves power if (!runASAP && loopCanSleep()) { - // if(delayMsec > 100) DEBUG_MSG("sleeping %ld\n", delayMsec); + // if(delayMsec > 100) LOG_DEBUG("sleeping %ld\n", delayMsec); mainDelay.delay(delayMsec); } - // if (didWake) DEBUG_MSG("wake!\n"); + // if (didWake) LOG_DEBUG("wake!\n"); } diff --git a/src/memtest.cpp b/src/memtest.cpp index d5d0739985..f5fe3d7d28 100644 --- a/src/memtest.cpp +++ b/src/memtest.cpp @@ -255,10 +255,10 @@ static int mem_test(uint32_t *_start, size_t len, bool doRead = true, bool doWri int rcode = 0; incr = 1; - //DEBUG_MSG("memtest read=%d, write=%d\n", doRead, doWrite); + //LOG_DEBUG("memtest read=%d, write=%d\n", doRead, doWrite); if (doWrite) { - //DEBUG_MSG("writing\n"); + //LOG_DEBUG("writing\n"); for (addr = start, val = pattern; addr < end; addr++) { *addr = val; val += incr; @@ -266,11 +266,11 @@ static int mem_test(uint32_t *_start, size_t len, bool doRead = true, bool doWri } if (doRead) { - //DEBUG_MSG("reading\n"); + //LOG_DEBUG("reading\n"); for (addr = start, val = pattern; addr < end; addr++) { readback = *addr; if (readback != val) { - DEBUG_MSG("Mem error @ 0x%08X: " + LOG_DEBUG("Mem error @ 0x%08X: " "found 0x%08lX, expected 0x%08lX\n", addr, readback, val); rcode++; diff --git a/src/mesh/Channels.cpp b/src/mesh/Channels.cpp index e7f1cb3ede..97f2c14483 100644 --- a/src/mesh/Channels.cpp +++ b/src/mesh/Channels.cpp @@ -106,30 +106,30 @@ CryptoKey Channels::getKey(ChannelIndex chIndex) k.length = channelSettings.psk.size; if (k.length == 0) { if (ch.role == Channel_Role_SECONDARY) { - DEBUG_MSG("Unset PSK for secondary channel %s. using primary key\n", ch.settings.name); + LOG_DEBUG("Unset PSK for secondary channel %s. using primary key\n", ch.settings.name); k = getKey(primaryIndex); } else - DEBUG_MSG("Warning: User disabled encryption\n"); + LOG_WARN("User disabled encryption\n"); } else if (k.length == 1) { // Convert the short single byte variants of psk into variant that can be used more generally uint8_t pskIndex = k.bytes[0]; - DEBUG_MSG("Expanding short PSK #%d\n", pskIndex); + LOG_DEBUG("Expanding short PSK #%d\n", pskIndex); if (pskIndex == 0) k.length = 0; // Turn off encryption else if (oemStore.oem_aes_key.size > 1) { // Use the OEM key - DEBUG_MSG("Using OEM Key with %d bytes\n", oemStore.oem_aes_key.size); + LOG_DEBUG("Using OEM Key with %d bytes\n", oemStore.oem_aes_key.size); memcpy(k.bytes, oemStore.oem_aes_key.bytes , oemStore.oem_aes_key.size); k.length = oemStore.oem_aes_key.size; // Bump up the last byte of PSK as needed uint8_t *last = k.bytes + oemStore.oem_aes_key.size - 1; *last = *last + pskIndex - 1; // index of 1 means no change vs defaultPSK if (k.length < 16) { - DEBUG_MSG("Warning: OEM provided a too short AES128 key - padding\n"); + LOG_WARN("OEM provided a too short AES128 key - padding\n"); k.length = 16; } else if (k.length < 32 && k.length != 16) { - DEBUG_MSG("Warning: OEM provided a too short AES256 key - padding\n"); + LOG_WARN("OEM provided a too short AES256 key - padding\n"); k.length = 32; } } else { @@ -142,12 +142,12 @@ CryptoKey Channels::getKey(ChannelIndex chIndex) } else if (k.length < 16) { // Error! The user specified only the first few bits of an AES128 key. So by convention we just pad the rest of the // key with zeros - DEBUG_MSG("Warning: User provided a too short AES128 key - padding\n"); + LOG_WARN("User provided a too short AES128 key - padding\n"); k.length = 16; } else if (k.length < 32 && k.length != 16) { // Error! The user specified only the first few bits of an AES256 key. So by convention we just pad the rest of the // key with zeros - DEBUG_MSG("Warning: User provided a too short AES256 key - padding\n"); + LOG_WARN("User provided a too short AES256 key - padding\n"); k.length = 32; } } @@ -308,11 +308,11 @@ const char *Channels::getPrimaryName() bool Channels::decryptForHash(ChannelIndex chIndex, ChannelHash channelHash) { if (chIndex > getNumChannels() || getHash(chIndex) != channelHash) { - // DEBUG_MSG("Skipping channel %d (hash %x) due to invalid hash/index, want=%x\n", chIndex, getHash(chIndex), + // LOG_DEBUG("Skipping channel %d (hash %x) due to invalid hash/index, want=%x\n", chIndex, getHash(chIndex), // channelHash); return false; } else { - DEBUG_MSG("Using channel %d (hash 0x%x)\n", chIndex, channelHash); + LOG_DEBUG("Using channel %d (hash 0x%x)\n", chIndex, channelHash); setCrypto(chIndex); return true; } diff --git a/src/mesh/CryptoEngine.cpp b/src/mesh/CryptoEngine.cpp index 5e73e39217..55535a0a8f 100644 --- a/src/mesh/CryptoEngine.cpp +++ b/src/mesh/CryptoEngine.cpp @@ -3,7 +3,7 @@ void CryptoEngine::setKey(const CryptoKey &k) { - DEBUG_MSG("Using AES%d key!\n", k.length * 8); + LOG_DEBUG("Using AES%d key!\n", k.length * 8); key = k; } @@ -14,12 +14,12 @@ void CryptoEngine::setKey(const CryptoKey &k) */ void CryptoEngine::encrypt(uint32_t fromNode, uint64_t packetId, size_t numBytes, uint8_t *bytes) { - DEBUG_MSG("WARNING: noop encryption!\n"); + LOG_WARN("noop encryption!\n"); } void CryptoEngine::decrypt(uint32_t fromNode, uint64_t packetId, size_t numBytes, uint8_t *bytes) { - DEBUG_MSG("WARNING: noop decryption!\n"); + LOG_WARN("noop decryption!\n"); } /** diff --git a/src/mesh/FloodingRouter.cpp b/src/mesh/FloodingRouter.cpp index e218203056..568af182de 100644 --- a/src/mesh/FloodingRouter.cpp +++ b/src/mesh/FloodingRouter.cpp @@ -32,7 +32,7 @@ void FloodingRouter::sniffReceived(const MeshPacket *p, const Routing *c) bool isAck = ((c && c->error_reason == Routing_Error_NONE)); // consider only ROUTING_APP message without error as ACK if (isAck && p->to != getNodeNum()) { // do not flood direct message that is ACKed - DEBUG_MSG("Receiving an ACK not for me, but don't need to rebroadcast this direct message anymore.\n"); + LOG_DEBUG("Receiving an ACK not for me, but don't need to rebroadcast this direct message anymore.\n"); Router::cancelSending(p->to, p->decoded.request_id); // cancel rebroadcast for this DM } if ((p->to != getNodeNum()) && (p->hop_limit > 0) && (getFrom(p) != getNodeNum())) { @@ -53,11 +53,11 @@ void FloodingRouter::sniffReceived(const MeshPacket *p, const Routing *c) Router::send(tosend); } else { - DEBUG_MSG("Not rebroadcasting. Role = Role_ClientMute\n"); + LOG_DEBUG("Not rebroadcasting. Role = Role_ClientMute\n"); } } else { - DEBUG_MSG("Ignoring a simple (0 id) broadcast\n"); + LOG_DEBUG("Ignoring a simple (0 id) broadcast\n"); } } diff --git a/src/mesh/MeshModule.cpp b/src/mesh/MeshModule.cpp index 8019cda1e5..fe5e3d81ea 100644 --- a/src/mesh/MeshModule.cpp +++ b/src/mesh/MeshModule.cpp @@ -52,7 +52,7 @@ MeshPacket *MeshModule::allocAckNak(Routing_Error err, NodeNum to, PacketId idFr p->to = to; p->decoded.request_id = idFrom; p->channel = chIndex; - DEBUG_MSG("Alloc an err=%d,to=0x%x,idFrom=0x%x,id=0x%x\n", err, to, idFrom, p->id); + LOG_DEBUG("Alloc an err=%d,to=0x%x,idFrom=0x%x,id=0x%x\n", err, to, idFrom, p->id); return p; } @@ -68,7 +68,7 @@ MeshPacket *MeshModule::allocErrorResponse(Routing_Error err, const MeshPacket * void MeshModule::callPlugins(const MeshPacket &mp, RxSource src) { - // DEBUG_MSG("In call modules\n"); + // LOG_DEBUG("In call modules\n"); bool moduleFound = false; // We now allow **encrypted** packets to pass through the modules @@ -96,7 +96,7 @@ void MeshModule::callPlugins(const MeshPacket &mp, RxSource src) assert(!pi.myReply); // If it is !null it means we have a bug, because it should have been sent the previous time if (wantsPacket) { - DEBUG_MSG("Module '%s' wantsPacket=%d\n", pi.name, wantsPacket); + LOG_DEBUG("Module '%s' wantsPacket=%d\n", pi.name, wantsPacket); moduleFound = true; @@ -134,20 +134,20 @@ void MeshModule::callPlugins(const MeshPacket &mp, RxSource src) // any other node. if (mp.decoded.want_response && toUs && (getFrom(&mp) != ourNodeNum || mp.to == ourNodeNum) && !currentReply) { pi.sendResponse(mp); - DEBUG_MSG("Module '%s' sent a response\n", pi.name); + LOG_DEBUG("Module '%s' sent a response\n", pi.name); } else { - DEBUG_MSG("Module '%s' considered\n", pi.name); + LOG_DEBUG("Module '%s' considered\n", pi.name); } // If the requester didn't ask for a response we might need to discard unused replies to prevent memory leaks if (pi.myReply) { - DEBUG_MSG("Discarding an unneeded response\n"); + LOG_DEBUG("Discarding an unneeded response\n"); packetPool.release(pi.myReply); pi.myReply = NULL; } if (handled == ProcessMessage::STOP) { - DEBUG_MSG("Module '%s' handled and skipped other processing\n", pi.name); + LOG_DEBUG("Module '%s' handled and skipped other processing\n", pi.name); break; } } @@ -165,7 +165,7 @@ void MeshModule::callPlugins(const MeshPacket &mp, RxSource src) // Note: if the message started with the local node we don't want to send a no response reply // No one wanted to reply to this requst, tell the requster that happened - DEBUG_MSG("No one responded, send a nak\n"); + LOG_DEBUG("No one responded, send a nak\n"); // SECURITY NOTE! I considered sending back a different error code if we didn't find the psk (i.e. !isDecoded) // but opted NOT TO. Because it is not a good idea to let remote nodes 'probe' to find out which PSKs were "good" vs @@ -175,7 +175,7 @@ void MeshModule::callPlugins(const MeshPacket &mp, RxSource src) } if (!moduleFound) - DEBUG_MSG("No modules interested in portnum=%d, src=%s\n", + LOG_DEBUG("No modules interested in portnum=%d, src=%s\n", mp.decoded.portnum, (src == RX_SRC_LOCAL) ? "LOCAL":"REMOTE"); } @@ -199,7 +199,7 @@ void MeshModule::sendResponse(const MeshPacket &req) currentReply = r; } else { // Ignore - this is now expected behavior for routing module (because it ignores some replies) - // DEBUG_MSG("WARNING: Client requested response but this module did not provide\n"); + // LOG_WARN("Client requested response but this module did not provide\n"); } } @@ -227,7 +227,7 @@ std::vector MeshModule::GetMeshModulesWithUIFrames() for (auto i = modules->begin(); i != modules->end(); ++i) { auto &pi = **i; if (pi.wantUIFrame()) { - DEBUG_MSG("Module wants a UI Frame\n"); + LOG_DEBUG("Module wants a UI Frame\n"); modulesWithUIFrames.push_back(&pi); } } @@ -244,7 +244,7 @@ void MeshModule::observeUIEvents( Observable *observable = pi.getUIFrameObservable(); if (observable != NULL) { - DEBUG_MSG("Module wants a UI Frame\n"); + LOG_DEBUG("Module wants a UI Frame\n"); observer->observe(observable); } } @@ -261,7 +261,7 @@ AdminMessageHandleResult MeshModule::handleAdminMessageForAllPlugins(const MeshP if (h == AdminMessageHandleResult::HANDLED_WITH_RESPONSE) { // In case we have a response it always has priority. - DEBUG_MSG("Reply prepared by module '%s' of variant: %d\n", + LOG_DEBUG("Reply prepared by module '%s' of variant: %d\n", pi.name, response->which_payload_variant); handled = h; diff --git a/src/mesh/MeshService.cpp b/src/mesh/MeshService.cpp index b4a4a171f6..6ac7321dac 100644 --- a/src/mesh/MeshService.cpp +++ b/src/mesh/MeshService.cpp @@ -106,7 +106,7 @@ bool MeshService::reloadConfig(int saveWhat) /// The owner User record just got updated, update our node DB and broadcast the info into the mesh void MeshService::reloadOwner(bool shouldSave) { - // DEBUG_MSG("reloadOwner()\n"); + // LOG_DEBUG("reloadOwner()\n"); // update our local data directly nodeDB.updateUser(nodeDB.getNodeNum(), owner); assert(nodeInfoModule); @@ -140,7 +140,7 @@ void MeshService::handleToRadio(MeshPacket &p) // Switch the port from PortNum_SIMULATOR_APP back to the original PortNum p.decoded.portnum = decoded->portnum; } else - DEBUG_MSG("Error decoding protobuf for simulator message!\n"); + LOG_DEBUG("Error decoding protobuf for simulator message!\n"); } // Let SimRadio receive as if it did via its LoRa chip SimRadio::instance->startReceive(&p); @@ -148,7 +148,7 @@ void MeshService::handleToRadio(MeshPacket &p) } #endif if (p.from != 0) { // We don't let phones assign nodenums to their sent messages - DEBUG_MSG("Warning: phone tried to pick a nodenum, we don't allow that.\n"); + LOG_WARN("phone tried to pick a nodenum, we don't allow that.\n"); p.from = 0; } else { // p.from = nodeDB.getNodeNum(); @@ -198,12 +198,12 @@ void MeshService::sendNetworkPing(NodeNum dest, bool wantReplies) if (node->has_position && (node->position.latitude_i != 0 || node->position.longitude_i != 0)) { if (positionModule) { - DEBUG_MSG("Sending position ping to 0x%x, wantReplies=%d\n", dest, wantReplies); + LOG_DEBUG("Sending position ping to 0x%x, wantReplies=%d\n", dest, wantReplies); positionModule->sendOurPosition(dest, wantReplies); } } else { if (nodeInfoModule) { - DEBUG_MSG("Sending nodeinfo ping to 0x%x, wantReplies=%d\n", dest, wantReplies); + LOG_DEBUG("Sending nodeinfo ping to 0x%x, wantReplies=%d\n", dest, wantReplies); nodeInfoModule->sendOurNodeInfo(dest, wantReplies); } } @@ -212,7 +212,7 @@ void MeshService::sendNetworkPing(NodeNum dest, bool wantReplies) void MeshService::sendToPhone(MeshPacket *p) { if (toPhoneQueue.numFree() == 0) { - DEBUG_MSG("NOTE: tophone queue is full, discarding oldest\n"); + LOG_DEBUG("NOTE: tophone queue is full, discarding oldest\n"); MeshPacket *d = toPhoneQueue.dequeuePtr(0); if (d) releaseToPool(d); @@ -262,10 +262,10 @@ int MeshService::onGPSChanged(const meshtastic::GPSStatus *newStatus) // The GPS has lost lock, if we are fixed position we should just keep using // the old position #ifdef GPS_EXTRAVERBOSE - DEBUG_MSG("onGPSchanged() - lost validLocation\n"); + LOG_DEBUG("onGPSchanged() - lost validLocation\n"); #endif if (config.position.fixed_position) { - DEBUG_MSG("WARNING: Using fixed position\n"); + LOG_WARN("Using fixed position\n"); pos = node->position; } } @@ -276,7 +276,7 @@ int MeshService::onGPSChanged(const meshtastic::GPSStatus *newStatus) pos.time = getValidTime(RTCQualityGPS); // In debug logs, identify position by @timestamp:stage (stage 4 = nodeDB) - DEBUG_MSG("onGPSChanged() pos@%x, time=%u, lat=%d, lon=%d, alt=%d\n", pos.timestamp, pos.time, pos.latitude_i, + LOG_DEBUG("onGPSChanged() pos@%x, time=%u, lat=%d, lon=%d, alt=%d\n", pos.timestamp, pos.time, pos.latitude_i, pos.longitude_i, pos.altitude); // Update our current position in the local DB diff --git a/src/mesh/NodeDB.cpp b/src/mesh/NodeDB.cpp index f2139b82b2..57d462da21 100644 --- a/src/mesh/NodeDB.cpp +++ b/src/mesh/NodeDB.cpp @@ -86,7 +86,7 @@ bool NodeDB::resetRadioConfig(bool factory_reset) } if (channelFile.channels_count != MAX_NUM_CHANNELS) { - DEBUG_MSG("Setting default channel and radio preferences!\n"); + LOG_DEBUG("Setting default channel and radio preferences!\n"); channels.initDefaults(); } @@ -96,7 +96,7 @@ bool NodeDB::resetRadioConfig(bool factory_reset) // temp hack for quicker testing // devicestate.no_save = true; if (devicestate.no_save) { - DEBUG_MSG("***** DEVELOPMENT MODE - DO NOT RELEASE *****\n"); + LOG_DEBUG("***** DEVELOPMENT MODE - DO NOT RELEASE *****\n"); // Sleep quite frequently to stress test the BLE comms, broadcast position every 6 mins config.display.screen_on_secs = 10; @@ -114,7 +114,7 @@ bool NodeDB::resetRadioConfig(bool factory_reset) initRegion(); if (didFactoryReset) { - DEBUG_MSG("Rebooting due to factory reset"); + LOG_DEBUG("Rebooting due to factory reset"); screen->startRebootScreen(); rebootAtMsec = millis() + (5 * 1000); } @@ -124,7 +124,7 @@ bool NodeDB::resetRadioConfig(bool factory_reset) bool NodeDB::factoryReset() { - DEBUG_MSG("Performing factory reset!\n"); + LOG_DEBUG("Performing factory reset!\n"); // first, remove the "/prefs" (this removes most prefs) rmDir("/prefs"); // second, install default state (this will deal with the duplicate mac address issue) @@ -140,7 +140,7 @@ bool NodeDB::factoryReset() #endif #ifdef ARCH_NRF52 Bluefruit.begin(); - DEBUG_MSG("Clearing bluetooth bonds!\n"); + LOG_DEBUG("Clearing bluetooth bonds!\n"); bond_print_list(BLE_GAP_ROLE_PERIPH); bond_print_list(BLE_GAP_ROLE_CENTRAL); Bluefruit.Periph.clearBonds(); @@ -151,7 +151,7 @@ bool NodeDB::factoryReset() void NodeDB::installDefaultConfig() { - DEBUG_MSG("Installing default LocalConfig\n"); + LOG_DEBUG("Installing default LocalConfig\n"); memset(&config, 0, sizeof(LocalConfig)); config.version = DEVICESTATE_CUR_VER; config.has_device = true; @@ -203,7 +203,7 @@ void NodeDB::initConfigIntervals() void NodeDB::installDefaultModuleConfig() { - DEBUG_MSG("Installing default ModuleConfig\n"); + LOG_DEBUG("Installing default ModuleConfig\n"); memset(&moduleConfig, 0, sizeof(ModuleConfig)); moduleConfig.version = DEVICESTATE_CUR_VER; @@ -230,7 +230,7 @@ void NodeDB::initModuleConfigIntervals() void NodeDB::installDefaultChannels() { - DEBUG_MSG("Installing default ChannelFile\n"); + LOG_DEBUG("Installing default ChannelFile\n"); memset(&channelFile, 0, sizeof(ChannelFile)); channelFile.version = DEVICESTATE_CUR_VER; } @@ -244,7 +244,7 @@ void NodeDB::resetNodes() void NodeDB::installDefaultDeviceState() { - DEBUG_MSG("Installing default DeviceState\n"); + LOG_DEBUG("Installing default DeviceState\n"); memset(&devicestate, 0, sizeof(DeviceState)); *numNodes = 0; @@ -275,7 +275,7 @@ void NodeDB::installDefaultDeviceState() void NodeDB::init() { - DEBUG_MSG("Initializing NodeDB\n"); + LOG_DEBUG("Initializing NodeDB\n"); loadFromDisk(); uint32_t devicestateCRC = crc32Buffer(&devicestate, sizeof(devicestate)); @@ -311,7 +311,7 @@ void NodeDB::init() preferences.begin("meshtastic", false); myNodeInfo.reboot_count = preferences.getUInt("rebootCounter", 0); preferences.end(); - DEBUG_MSG("Number of Device Reboots: %d\n", myNodeInfo.reboot_count); + LOG_DEBUG("Number of Device Reboots: %d\n", myNodeInfo.reboot_count); /* The ESP32 has a wifi radio. This will need to be modified at some point so * the test isn't so simplistic. @@ -320,7 +320,7 @@ void NodeDB::init() #endif resetRadioConfig(); // If bogus settings got saved, then fix them - DEBUG_MSG("region=%d, NODENUM=0x%x, dbsize=%d\n", config.lora.region, myNodeInfo.my_node_num, *numNodes); + LOG_DEBUG("region=%d, NODENUM=0x%x, dbsize=%d\n", config.lora.region, myNodeInfo.my_node_num, *numNodes); if (devicestateCRC != crc32Buffer(&devicestate, sizeof(devicestate))) saveWhat |= SEGMENT_DEVICESTATE; @@ -352,7 +352,7 @@ void NodeDB::pickNewNodeNum() NodeInfo *found; while ((found = getNode(r)) && memcmp(found->user.macaddr, owner.macaddr, sizeof(owner.macaddr))) { NodeNum n = random(NUM_RESERVED, NODENUM_BROADCAST); // try a new random choice - DEBUG_MSG("NOTE! Our desired nodenum 0x%x is in use, so trying for 0x%x\n", r, n); + LOG_DEBUG("NOTE! Our desired nodenum 0x%x is in use, so trying for 0x%x\n", r, n); r = n; } @@ -376,24 +376,24 @@ bool NodeDB::loadProto(const char *filename, size_t protoSize, size_t objSize, c auto f = FSCom.open(filename, FILE_O_READ); if (f) { - DEBUG_MSG("Loading %s\n", filename); + LOG_DEBUG("Loading %s\n", filename); pb_istream_t stream = {&readcb, &f, protoSize}; - // DEBUG_MSG("Preload channel name=%s\n", channelSettings.name); + // LOG_DEBUG("Preload channel name=%s\n", channelSettings.name); memset(dest_struct, 0, objSize); if (!pb_decode(&stream, fields, dest_struct)) { - DEBUG_MSG("Error: can't decode protobuf %s\n", PB_GET_ERROR(&stream)); + LOG_DEBUG("Error: can't decode protobuf %s\n", PB_GET_ERROR(&stream)); } else { okay = true; } f.close(); } else { - DEBUG_MSG("No %s preferences found\n", filename); + LOG_DEBUG("No %s preferences found\n", filename); } #else - DEBUG_MSG("ERROR: Filesystem not implemented\n"); + LOG_DEBUG("ERROR: Filesystem not implemented\n"); #endif return okay; } @@ -405,10 +405,10 @@ void NodeDB::loadFromDisk() installDefaultDeviceState(); // Our in RAM copy might now be corrupt } else { if (devicestate.version < DEVICESTATE_MIN_VER) { - DEBUG_MSG("Warn: devicestate %d is old, discarding\n", devicestate.version); + LOG_DEBUG("Warn: devicestate %d is old, discarding\n", devicestate.version); factoryReset(); } else { - DEBUG_MSG("Loaded saved devicestate version %d\n", devicestate.version); + LOG_DEBUG("Loaded saved devicestate version %d\n", devicestate.version); } } @@ -416,10 +416,10 @@ void NodeDB::loadFromDisk() installDefaultConfig(); // Our in RAM copy might now be corrupt } else { if (config.version < DEVICESTATE_MIN_VER) { - DEBUG_MSG("Warn: config %d is old, discarding\n", config.version); + LOG_DEBUG("Warn: config %d is old, discarding\n", config.version); installDefaultConfig(); } else { - DEBUG_MSG("Loaded saved config version %d\n", config.version); + LOG_DEBUG("Loaded saved config version %d\n", config.version); } } @@ -427,10 +427,10 @@ void NodeDB::loadFromDisk() installDefaultModuleConfig(); // Our in RAM copy might now be corrupt } else { if (moduleConfig.version < DEVICESTATE_MIN_VER) { - DEBUG_MSG("Warn: moduleConfig %d is old, discarding\n", moduleConfig.version); + LOG_DEBUG("Warn: moduleConfig %d is old, discarding\n", moduleConfig.version); installDefaultModuleConfig(); } else { - DEBUG_MSG("Loaded saved moduleConfig version %d\n", moduleConfig.version); + LOG_DEBUG("Loaded saved moduleConfig version %d\n", moduleConfig.version); } } @@ -438,15 +438,15 @@ void NodeDB::loadFromDisk() installDefaultChannels(); // Our in RAM copy might now be corrupt } else { if (channelFile.version < DEVICESTATE_MIN_VER) { - DEBUG_MSG("Warn: channelFile %d is old, discarding\n", channelFile.version); + LOG_DEBUG("Warn: channelFile %d is old, discarding\n", channelFile.version); installDefaultChannels(); } else { - DEBUG_MSG("Loaded saved channelFile version %d\n", channelFile.version); + LOG_DEBUG("Loaded saved channelFile version %d\n", channelFile.version); } } if (loadProto(oemConfigFile, OEMStore_size, sizeof(OEMStore), &OEMStore_msg, &oemStore)) - DEBUG_MSG("Loaded OEMStore\n"); + LOG_DEBUG("Loaded OEMStore\n"); } /** Save a protobuf from a file, return true for success */ @@ -459,11 +459,11 @@ bool NodeDB::saveProto(const char *filename, size_t protoSize, const pb_msgdesc_ filenameTmp += ".tmp"; auto f = FSCom.open(filenameTmp.c_str(), FILE_O_WRITE); if (f) { - DEBUG_MSG("Saving %s\n", filename); + LOG_DEBUG("Saving %s\n", filename); pb_ostream_t stream = {&writecb, &f, protoSize}; if (!pb_encode(&stream, fields, dest_struct)) { - DEBUG_MSG("Error: can't encode protobuf %s\n", PB_GET_ERROR(&stream)); + LOG_DEBUG("Error: can't encode protobuf %s\n", PB_GET_ERROR(&stream)); } else { okay = true; } @@ -471,11 +471,11 @@ bool NodeDB::saveProto(const char *filename, size_t protoSize, const pb_msgdesc_ // brief window of risk here ;-) if (FSCom.exists(filename) && !FSCom.remove(filename)) - DEBUG_MSG("Warning: Can't remove old pref file\n"); + LOG_WARN("Can't remove old pref file\n"); if (!renameFile(filenameTmp.c_str(), filename)) - DEBUG_MSG("Error: can't rename new pref file\n"); + LOG_DEBUG("Error: can't rename new pref file\n"); } else { - DEBUG_MSG("Can't write prefs\n"); + LOG_DEBUG("Can't write prefs\n"); #ifdef ARCH_NRF52 static uint8_t failedCounter = 0; failedCounter++; @@ -487,7 +487,7 @@ bool NodeDB::saveProto(const char *filename, size_t protoSize, const pb_msgdesc_ #endif } #else - DEBUG_MSG("ERROR: Filesystem not implemented\n"); + LOG_DEBUG("ERROR: Filesystem not implemented\n"); #endif return okay; } @@ -548,7 +548,7 @@ void NodeDB::saveToDisk(int saveWhat) saveChannelsToDisk(); } } else { - DEBUG_MSG("***** DEVELOPMENT MODE - DO NOT RELEASE - not saving to flash *****\n"); + LOG_DEBUG("***** DEVELOPMENT MODE - DO NOT RELEASE - not saving to flash *****\n"); } } @@ -599,14 +599,14 @@ void NodeDB::updatePosition(uint32_t nodeId, const Position &p, RxSource src) if (src == RX_SRC_LOCAL) { // Local packet, fully authoritative - DEBUG_MSG("updatePosition LOCAL pos@%x, time=%u, latI=%d, lonI=%d, alt=%d\n", p.timestamp, p.time, p.latitude_i, + LOG_DEBUG("updatePosition LOCAL pos@%x, time=%u, latI=%d, lonI=%d, alt=%d\n", p.timestamp, p.time, p.latitude_i, p.longitude_i, p.altitude); info->position = p; } else if ((p.time > 0) && !p.latitude_i && !p.longitude_i && !p.timestamp && !p.location_source) { // FIXME SPECIAL TIME SETTING PACKET FROM EUD TO RADIO // (stop-gap fix for issue #900) - DEBUG_MSG("updatePosition SPECIAL time setting time=%u\n", p.time); + LOG_DEBUG("updatePosition SPECIAL time setting time=%u\n", p.time); info->position.time = p.time; } else { @@ -615,7 +615,7 @@ void NodeDB::updatePosition(uint32_t nodeId, const Position &p, RxSource src) // recorded based on the packet rxTime // // FIXME perhaps handle RX_SRC_USER separately? - DEBUG_MSG("updatePosition REMOTE node=0x%x time=%u, latI=%d, lonI=%d\n", nodeId, p.time, p.latitude_i, p.longitude_i); + LOG_DEBUG("updatePosition REMOTE node=0x%x time=%u, latI=%d, lonI=%d\n", nodeId, p.time, p.latitude_i, p.longitude_i); // First, back up fields that we want to protect from overwrite uint32_t tmp_time = info->position.time; @@ -645,9 +645,9 @@ void NodeDB::updateTelemetry(uint32_t nodeId, const Telemetry &t, RxSource src) if (src == RX_SRC_LOCAL) { // Local packet, fully authoritative - DEBUG_MSG("updateTelemetry LOCAL\n"); + LOG_DEBUG("updateTelemetry LOCAL\n"); } else { - DEBUG_MSG("updateTelemetry REMOTE node=0x%x \n", nodeId); + LOG_DEBUG("updateTelemetry REMOTE node=0x%x \n", nodeId); } info->device_metrics = t.variant.device_metrics; info->has_device_metrics = true; @@ -664,13 +664,13 @@ void NodeDB::updateUser(uint32_t nodeId, const User &p) return; } - DEBUG_MSG("old user %s/%s/%s\n", info->user.id, info->user.long_name, info->user.short_name); + LOG_DEBUG("old user %s/%s/%s\n", info->user.id, info->user.long_name, info->user.short_name); bool changed = memcmp(&info->user, &p, sizeof(info->user)); // Both of these blocks start as filled with zero so I think this is okay info->user = p; - DEBUG_MSG("updating changed=%d user %s/%s/%s\n", changed, info->user.id, info->user.long_name, info->user.short_name); + LOG_DEBUG("updating changed=%d user %s/%s/%s\n", changed, info->user.id, info->user.long_name, info->user.short_name); info->has_user = true; if (changed) { @@ -689,7 +689,7 @@ void NodeDB::updateUser(uint32_t nodeId, const User &p) void NodeDB::updateFrom(const MeshPacket &mp) { if (mp.which_payload_variant == MeshPacket_decoded_tag && mp.from) { - DEBUG_MSG("Update DB node 0x%x, rx_time=%u\n", mp.from, mp.rx_time); + LOG_DEBUG("Update DB node 0x%x, rx_time=%u\n", mp.from, mp.rx_time); NodeInfo *info = getOrCreateNode(getFrom(&mp)); if (!info) { @@ -756,9 +756,9 @@ void recordCriticalError(CriticalErrorCode code, uint32_t address, const char *f String lcd = String("Critical error ") + code + "!\n"; screen->print(lcd.c_str()); if (filename) - DEBUG_MSG("NOTE! Recording critical error %d at %s:%lu\n", code, filename, address); + LOG_DEBUG("NOTE! Recording critical error %d at %s:%lu\n", code, filename, address); else - DEBUG_MSG("NOTE! Recording critical error %d, address=0x%lx\n", code, address); + LOG_DEBUG("NOTE! Recording critical error %d, address=0x%lx\n", code, address); // Record error to DB myNodeInfo.error_code = code; @@ -767,7 +767,7 @@ void recordCriticalError(CriticalErrorCode code, uint32_t address, const char *f // Currently portuino is mostly used for simulation. Make sue the user notices something really bad happend #ifdef ARCH_PORTDUINO - DEBUG_MSG("A critical failure occurred, portduino is exiting..."); + LOG_DEBUG("A critical failure occurred, portduino is exiting..."); exit(2); #endif } diff --git a/src/mesh/PacketHistory.cpp b/src/mesh/PacketHistory.cpp index c8008689d3..e46adfc9ee 100644 --- a/src/mesh/PacketHistory.cpp +++ b/src/mesh/PacketHistory.cpp @@ -14,7 +14,7 @@ PacketHistory::PacketHistory() bool PacketHistory::wasSeenRecently(const MeshPacket *p, bool withUpdate) { if (p->id == 0) { - DEBUG_MSG("Ignoring message with zero id\n"); + LOG_DEBUG("Ignoring message with zero id\n"); return false; // Not a floodable message ID, so we don't care } @@ -35,7 +35,7 @@ bool PacketHistory::wasSeenRecently(const MeshPacket *p, bool withUpdate) } if (seenRecently) { - DEBUG_MSG("Found existing packet record for fr=0x%x,to=0x%x,id=0x%x\n", p->from, p->to, p->id); + LOG_DEBUG("Found existing packet record for fr=0x%x,to=0x%x,id=0x%x\n", p->from, p->to, p->id); } if (withUpdate) { @@ -61,7 +61,7 @@ bool PacketHistory::wasSeenRecently(const MeshPacket *p, bool withUpdate) void PacketHistory::clearExpiredRecentPackets() { uint32_t now = millis(); - DEBUG_MSG("recentPackets size=%ld\n", recentPackets.size()); + LOG_DEBUG("recentPackets size=%ld\n", recentPackets.size()); for (auto it = recentPackets.begin(); it != recentPackets.end(); ) { if ((now - it->rxTimeMsec) >= FLOOD_EXPIRE_TIME) { @@ -71,5 +71,5 @@ void PacketHistory::clearExpiredRecentPackets() { } } - DEBUG_MSG("recentPackets size=%ld (after clearing expired packets)\n", recentPackets.size()); + LOG_DEBUG("recentPackets size=%ld (after clearing expired packets)\n", recentPackets.size()); } \ No newline at end of file diff --git a/src/mesh/PhoneAPI.cpp b/src/mesh/PhoneAPI.cpp index ac134f3525..75805c11c5 100644 --- a/src/mesh/PhoneAPI.cpp +++ b/src/mesh/PhoneAPI.cpp @@ -37,7 +37,7 @@ void PhoneAPI::handleStartConfig() // even if we were already connected - restart our state machine state = STATE_SEND_MY_INFO; - DEBUG_MSG("Starting API client config\n"); + LOG_DEBUG("Starting API client config\n"); nodeInfoForPhone = NULL; // Don't keep returning old nodeinfos nodeDB.resetReadPointer(); // FIXME, this read pointer should be moved out of nodeDB and into this class - because // this will break once we have multiple instances of PhoneAPI running independently @@ -60,7 +60,7 @@ void PhoneAPI::checkConnectionTimeout() if (isConnected()) { bool newContact = checkIsConnected(); if (!newContact) { - DEBUG_MSG("Lost phone connection\n"); + LOG_DEBUG("Lost phone connection\n"); close(); } } @@ -83,20 +83,20 @@ bool PhoneAPI::handleToRadio(const uint8_t *buf, size_t bufLength) return handleToRadioPacket(toRadioScratch.packet); case ToRadio_want_config_id_tag: config_nonce = toRadioScratch.want_config_id; - DEBUG_MSG("Client wants config, nonce=%u\n", config_nonce); + LOG_DEBUG("Client wants config, nonce=%u\n", config_nonce); handleStartConfig(); break; case ToRadio_disconnect_tag: - DEBUG_MSG("Disconnecting from phone\n"); + LOG_DEBUG("Disconnecting from phone\n"); close(); break; default: // Ignore nop messages - // DEBUG_MSG("Error: unexpected ToRadio variant\n"); + // LOG_DEBUG("Error: unexpected ToRadio variant\n"); break; } } else { - DEBUG_MSG("Error: ignoring malformed toradio\n"); + LOG_DEBUG("Error: ignoring malformed toradio\n"); } return false; @@ -119,7 +119,7 @@ bool PhoneAPI::handleToRadio(const uint8_t *buf, size_t bufLength) size_t PhoneAPI::getFromRadio(uint8_t *buf) { if (!available()) { - // DEBUG_MSG("getFromRadio=not available\n"); + // LOG_DEBUG("getFromRadio=not available\n"); return 0; } // In case we send a FromRadio packet @@ -128,11 +128,11 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) // Advance states as needed switch (state) { case STATE_SEND_NOTHING: - DEBUG_MSG("getFromRadio=STATE_SEND_NOTHING\n"); + LOG_DEBUG("getFromRadio=STATE_SEND_NOTHING\n"); break; case STATE_SEND_MY_INFO: - DEBUG_MSG("getFromRadio=STATE_SEND_MY_INFO\n"); + LOG_DEBUG("getFromRadio=STATE_SEND_MY_INFO\n"); // If the user has specified they don't want our node to share its location, make sure to tell the phone // app not to send locations on our behalf. myNodeInfo.has_gps = gps && gps->isConnected(); // Update with latest GPS connect info @@ -144,18 +144,18 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) break; case STATE_SEND_NODEINFO: { - DEBUG_MSG("getFromRadio=STATE_SEND_NODEINFO\n"); + LOG_DEBUG("getFromRadio=STATE_SEND_NODEINFO\n"); const NodeInfo *info = nodeInfoForPhone; nodeInfoForPhone = NULL; // We just consumed a nodeinfo, will need a new one next time if (info) { - DEBUG_MSG("Sending nodeinfo: num=0x%x, lastseen=%u, id=%s, name=%s\n", info->num, info->last_heard, info->user.id, + LOG_DEBUG("Sending nodeinfo: num=0x%x, lastseen=%u, id=%s, name=%s\n", info->num, info->last_heard, info->user.id, info->user.long_name); fromRadioScratch.which_payload_variant = FromRadio_node_info_tag; fromRadioScratch.node_info = *info; // Stay in current state until done sending nodeinfos } else { - DEBUG_MSG("Done sending nodeinfos\n"); + LOG_DEBUG("Done sending nodeinfos\n"); state = STATE_SEND_CHANNELS; // Go ahead and send that ID right now return getFromRadio(buf); @@ -164,7 +164,7 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) } case STATE_SEND_CHANNELS: - DEBUG_MSG("getFromRadio=STATE_SEND_CHANNELS\n"); + LOG_DEBUG("getFromRadio=STATE_SEND_CHANNELS\n"); fromRadioScratch.which_payload_variant = FromRadio_channel_tag; fromRadioScratch.channel = channels.getByIndex(config_state); config_state++; @@ -176,7 +176,7 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) break; case STATE_SEND_CONFIG: - DEBUG_MSG("getFromRadio=STATE_SEND_CONFIG\n"); + LOG_DEBUG("getFromRadio=STATE_SEND_CONFIG\n"); fromRadioScratch.which_payload_variant = FromRadio_config_tag; switch (config_state) { case Config_device_tag: @@ -222,7 +222,7 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) break; case STATE_SEND_MODULECONFIG: - DEBUG_MSG("getFromRadio=STATE_SEND_MODULECONFIG\n"); + LOG_DEBUG("getFromRadio=STATE_SEND_MODULECONFIG\n"); fromRadioScratch.which_payload_variant = FromRadio_moduleConfig_tag; switch (config_state) { case ModuleConfig_mqtt_tag: @@ -272,7 +272,7 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) break; case STATE_SEND_COMPLETE_ID: - DEBUG_MSG("getFromRadio=STATE_SEND_COMPLETE_ID\n"); + LOG_DEBUG("getFromRadio=STATE_SEND_COMPLETE_ID\n"); fromRadioScratch.which_payload_variant = FromRadio_config_complete_id_tag; fromRadioScratch.config_complete_id = config_nonce; config_nonce = 0; @@ -281,7 +281,7 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) case STATE_SEND_PACKETS: // Do we have a message from the mesh? - DEBUG_MSG("getFromRadio=STATE_SEND_PACKETS\n"); + LOG_DEBUG("getFromRadio=STATE_SEND_PACKETS\n"); if (packetForPhone) { printPacket("phone downloaded packet", packetForPhone); @@ -301,17 +301,17 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) // Encapsulate as a FromRadio packet size_t numbytes = pb_encode_to_bytes(buf, FromRadio_size, &FromRadio_msg, &fromRadioScratch); - DEBUG_MSG("encoding toPhone packet to phone variant=%d, %d bytes\n", fromRadioScratch.which_payload_variant, numbytes); + LOG_DEBUG("encoding toPhone packet to phone variant=%d, %d bytes\n", fromRadioScratch.which_payload_variant, numbytes); return numbytes; } - DEBUG_MSG("no FromRadio packet available\n"); + LOG_DEBUG("no FromRadio packet available\n"); return 0; } void PhoneAPI::handleDisconnect() { - DEBUG_MSG("PhoneAPI disconnect\n"); + LOG_DEBUG("PhoneAPI disconnect\n"); } void PhoneAPI::releasePhonePacket() @@ -345,7 +345,7 @@ bool PhoneAPI::available() if (!packetForPhone) packetForPhone = service.getForPhone(); bool hasPacket = !!packetForPhone; - // DEBUG_MSG("available hasPacket=%d\n", hasPacket); + // LOG_DEBUG("available hasPacket=%d\n", hasPacket); return hasPacket; } default: @@ -373,10 +373,10 @@ int PhoneAPI::onNotify(uint32_t newValue) // from idle) if (state == STATE_SEND_PACKETS) { - DEBUG_MSG("Telling client we have new packets %u\n", newValue); + LOG_DEBUG("Telling client we have new packets %u\n", newValue); onNowHasData(newValue); } else - DEBUG_MSG("(Client not yet interested in packets)\n"); + LOG_DEBUG("(Client not yet interested in packets)\n"); return 0; } diff --git a/src/mesh/ProtobufModule.h b/src/mesh/ProtobufModule.h index 9905d2250b..bac38b7861 100644 --- a/src/mesh/ProtobufModule.h +++ b/src/mesh/ProtobufModule.h @@ -44,7 +44,7 @@ template class ProtobufModule : protected SinglePortModule p->decoded.payload.size = pb_encode_to_bytes(p->decoded.payload.bytes, sizeof(p->decoded.payload.bytes), fields, &payload); - // DEBUG_MSG("did encode\n"); + // LOG_DEBUG("did encode\n"); return p; } @@ -70,7 +70,7 @@ template class ProtobufModule : protected SinglePortModule // it would be better to update even if the message was destined to others. auto &p = mp.decoded; - DEBUG_MSG("Received %s from=0x%0x, id=0x%x, portnum=%d, payloadlen=%d\n", name, mp.from, mp.id, p.portnum, + LOG_DEBUG("Received %s from=0x%0x, id=0x%x, portnum=%d, payloadlen=%d\n", name, mp.from, mp.id, p.portnum, p.payload.size); T scratch; @@ -80,7 +80,7 @@ template class ProtobufModule : protected SinglePortModule if (pb_decode_from_bytes(p.payload.bytes, p.payload.size, fields, &scratch)) { decoded = &scratch; } else { - DEBUG_MSG("Error decoding protobuf module!\n"); + LOG_DEBUG("Error decoding protobuf module!\n"); // if we can't decode it, nobody can process it! return ProcessMessage::STOP; } diff --git a/src/mesh/RF95Interface.cpp b/src/mesh/RF95Interface.cpp index 5b88d45edc..e679775c3c 100644 --- a/src/mesh/RF95Interface.cpp +++ b/src/mesh/RF95Interface.cpp @@ -68,17 +68,17 @@ bool RF95Interface::init() setTransmitEnable(false); int res = lora->begin(getFreq(), bw, sf, cr, syncWord, power, currentLimit, preambleLength); - DEBUG_MSG("RF95 init result %d\n", res); + LOG_DEBUG("RF95 init result %d\n", res); - DEBUG_MSG("Frequency set to %f\n", getFreq()); - DEBUG_MSG("Bandwidth set to %f\n", bw); - DEBUG_MSG("Power output set to %d\n", power); + LOG_DEBUG("Frequency set to %f\n", getFreq()); + LOG_DEBUG("Bandwidth set to %f\n", bw); + LOG_DEBUG("Power output set to %d\n", power); // current limit was removed from module' ctor // override default value (60 mA) res = lora->setCurrentLimit(currentLimit); - DEBUG_MSG("Current limit set to %f\n", currentLimit); - DEBUG_MSG("Current limit set result %d\n", res); + LOG_DEBUG("Current limit set to %f\n", currentLimit); + LOG_DEBUG("Current limit set result %d\n", res); if (res == RADIOLIB_ERR_NONE) res = lora->setCRC(RADIOLIB_SX126X_LORA_CRC_ON); @@ -190,12 +190,12 @@ bool RF95Interface::isChannelActive() result = lora->scanChannel(); if (result == RADIOLIB_PREAMBLE_DETECTED) { - // DEBUG_MSG("Channel is busy!\n"); + // LOG_DEBUG("Channel is busy!\n"); return true; } assert(result != RADIOLIB_ERR_WRONG_MODEM); - // DEBUG_MSG("Channel is free!\n"); + // LOG_DEBUG("Channel is free!\n"); return false; } diff --git a/src/mesh/RadioInterface.cpp b/src/mesh/RadioInterface.cpp index 222e5d14bc..f3971ddb02 100644 --- a/src/mesh/RadioInterface.cpp +++ b/src/mesh/RadioInterface.cpp @@ -117,7 +117,7 @@ void initRegion() for (; r->code != Config_LoRaConfig_RegionCode_UNSET && r->code != config.lora.region; r++) ; myRegion = r; - DEBUG_MSG("Wanted region %d, using %s\n", config.lora.region, r->name); + LOG_DEBUG("Wanted region %d, using %s\n", config.lora.region, r->name); } /** @@ -157,7 +157,7 @@ uint32_t RadioInterface::getPacketTime(uint32_t pl) uint32_t msecs = tPacket * 1000; - DEBUG_MSG("(bw=%d, sf=%d, cr=4/%d) packet symLen=%d ms, payloadSize=%u, time %d ms\n", (int)bw, sf, cr, (int)(tSym * 1000), + LOG_DEBUG("(bw=%d, sf=%d, cr=4/%d) packet symLen=%d ms, payloadSize=%u, time %d ms\n", (int)bw, sf, cr, (int)(tSym * 1000), pl, msecs); return msecs; } @@ -178,7 +178,7 @@ uint32_t RadioInterface::getRetransmissionMsec(const MeshPacket *p) size_t numbytes = pb_encode_to_bytes(bytes, sizeof(bytes), &Data_msg, &p->decoded); uint32_t packetAirtime = getPacketTime(numbytes + sizeof(PacketHeader)); // Make sure enough time has elapsed for this packet to be sent and an ACK is received. - // DEBUG_MSG("Waiting for flooding message with airtime %d and slotTime is %d\n", packetAirtime, slotTimeMsec); + // LOG_DEBUG("Waiting for flooding message with airtime %d and slotTime is %d\n", packetAirtime, slotTimeMsec); float channelUtil = airTime->channelUtilizationPercent(); uint8_t CWsize = map(channelUtil, 0, 100, CWmin, CWmax); // Assuming we pick max. of CWsize and there will be a receiver with SNR at half the range @@ -193,7 +193,7 @@ uint32_t RadioInterface::getTxDelayMsec() current channel utilization. */ float channelUtil = airTime->channelUtilizationPercent(); uint8_t CWsize = map(channelUtil, 0, 100, CWmin, CWmax); - // DEBUG_MSG("Current channel utilization is %f so setting CWsize to %d\n", channelUtil, CWsize); + // LOG_DEBUG("Current channel utilization is %f so setting CWsize to %d\n", channelUtil, CWsize); return random(0, pow(2, CWsize)) * slotTimeMsec; } @@ -210,14 +210,14 @@ uint32_t RadioInterface::getTxDelayMsecWeighted(float snr) // low SNR = small CW size (Short Delay) uint32_t delay = 0; uint8_t CWsize = map(snr, SNR_MIN, SNR_MAX, CWmin, CWmax); - // DEBUG_MSG("rx_snr of %f so setting CWsize to:%d\n", snr, CWsize); + // LOG_DEBUG("rx_snr of %f so setting CWsize to:%d\n", snr, CWsize); if (config.device.role == Config_DeviceConfig_Role_ROUTER || config.device.role == Config_DeviceConfig_Role_ROUTER_CLIENT) { delay = random(0, 2*CWsize) * slotTimeMsec; - DEBUG_MSG("rx_snr found in packet. As a router, setting tx delay:%d\n", delay); + LOG_DEBUG("rx_snr found in packet. As a router, setting tx delay:%d\n", delay); } else { delay = random(0, pow(2, CWsize)) * slotTimeMsec; - DEBUG_MSG("rx_snr found in packet. Setting tx delay:%d\n", delay); + LOG_DEBUG("rx_snr found in packet. Setting tx delay:%d\n", delay); } return delay; @@ -225,47 +225,47 @@ uint32_t RadioInterface::getTxDelayMsecWeighted(float snr) void printPacket(const char *prefix, const MeshPacket *p) { - DEBUG_MSG("%s (id=0x%08x fr=0x%02x to=0x%02x, WantAck=%d, HopLim=%d Ch=0x%x", prefix, p->id, p->from & 0xff, p->to & 0xff, + LOG_DEBUG("%s (id=0x%08x fr=0x%02x to=0x%02x, WantAck=%d, HopLim=%d Ch=0x%x", prefix, p->id, p->from & 0xff, p->to & 0xff, p->want_ack, p->hop_limit, p->channel); if (p->which_payload_variant == MeshPacket_decoded_tag) { auto &s = p->decoded; - DEBUG_MSG(" Portnum=%d", s.portnum); + LOG_DEBUG(" Portnum=%d", s.portnum); if (s.want_response) - DEBUG_MSG(" WANTRESP"); + LOG_DEBUG(" WANTRESP"); if (s.source != 0) - DEBUG_MSG(" source=%08x", s.source); + LOG_DEBUG(" source=%08x", s.source); if (s.dest != 0) - DEBUG_MSG(" dest=%08x", s.dest); + LOG_DEBUG(" dest=%08x", s.dest); if (s.request_id) - DEBUG_MSG(" requestId=%0x", s.request_id); + LOG_DEBUG(" requestId=%0x", s.request_id); /* now inside Data and therefore kinda opaque if (s.which_ackVariant == SubPacket_success_id_tag) - DEBUG_MSG(" successId=%08x", s.ackVariant.success_id); + LOG_DEBUG(" successId=%08x", s.ackVariant.success_id); else if (s.which_ackVariant == SubPacket_fail_id_tag) - DEBUG_MSG(" failId=%08x", s.ackVariant.fail_id); */ + LOG_DEBUG(" failId=%08x", s.ackVariant.fail_id); */ } else { - DEBUG_MSG(" encrypted"); + LOG_DEBUG(" encrypted"); } if (p->rx_time != 0) { - DEBUG_MSG(" rxtime=%u", p->rx_time); + LOG_DEBUG(" rxtime=%u", p->rx_time); } if (p->rx_snr != 0.0) { - DEBUG_MSG(" rxSNR=%g", p->rx_snr); + LOG_DEBUG(" rxSNR=%g", p->rx_snr); } if (p->rx_rssi != 0) { - DEBUG_MSG(" rxRSSI=%g", p->rx_rssi); + LOG_DEBUG(" rxRSSI=%g", p->rx_rssi); } if (p->priority != 0) - DEBUG_MSG(" priority=%d", p->priority); + LOG_DEBUG(" priority=%d", p->priority); - DEBUG_MSG(")\n"); + LOG_DEBUG(")\n"); } RadioInterface::RadioInterface() @@ -273,7 +273,7 @@ RadioInterface::RadioInterface() assert(sizeof(PacketHeader) == 16); // make sure the compiler did what we expected // Can't print strings this early - serial not setup yet - // DEBUG_MSG("Set meshradio defaults name=%s\n", channelSettings.name); + // LOG_DEBUG("Set meshradio defaults name=%s\n", channelSettings.name); } bool RadioInterface::reconfigure() @@ -284,7 +284,7 @@ bool RadioInterface::reconfigure() bool RadioInterface::init() { - DEBUG_MSG("Starting meshradio init...\n"); + LOG_DEBUG("Starting meshradio init...\n"); configChangedObserver.observe(&service.configChanged); preflightSleepObserver.observe(&preflightSleep); @@ -449,13 +449,13 @@ void RadioInterface::applyModemConfig() saveChannelNum(channel_num); saveFreq(freq + config.lora.frequency_offset); - DEBUG_MSG("Radio freq=%.3f, config.lora.frequency_offset=%.3f\n", freq, config.lora.frequency_offset); - DEBUG_MSG("Set radio: region=%s, name=%s, config=%u, ch=%d, power=%d\n", myRegion->name, channelName, loraConfig.modem_preset, channel_num, power); - DEBUG_MSG("Radio myRegion->freqStart -> myRegion->freqEnd: %f -> %f (%f mhz)\n", myRegion->freqStart, myRegion->freqEnd, myRegion->freqEnd - myRegion->freqStart); - DEBUG_MSG("Radio myRegion->numChannels: %d x %.3fkHz\n", numChannels, bw); - DEBUG_MSG("Radio channel_num: %d\n", channel_num); - DEBUG_MSG("Radio frequency: %f\n", getFreq()); - DEBUG_MSG("Slot time: %u msec\n", slotTimeMsec); + LOG_DEBUG("Radio freq=%.3f, config.lora.frequency_offset=%.3f\n", freq, config.lora.frequency_offset); + LOG_DEBUG("Set radio: region=%s, name=%s, config=%u, ch=%d, power=%d\n", myRegion->name, channelName, loraConfig.modem_preset, channel_num, power); + LOG_DEBUG("Radio myRegion->freqStart -> myRegion->freqEnd: %f -> %f (%f mhz)\n", myRegion->freqStart, myRegion->freqEnd, myRegion->freqEnd - myRegion->freqStart); + LOG_DEBUG("Radio myRegion->numChannels: %d x %.3fkHz\n", numChannels, bw); + LOG_DEBUG("Radio channel_num: %d\n", channel_num); + LOG_DEBUG("Radio frequency: %f\n", getFreq()); + LOG_DEBUG("Slot time: %u msec\n", slotTimeMsec); } /** @@ -470,11 +470,11 @@ void RadioInterface::limitPower() maxPower = myRegion->powerLimit; if ((power > maxPower) && !devicestate.owner.is_licensed) { - DEBUG_MSG("Lowering transmit power because of regulatory limits\n"); + LOG_DEBUG("Lowering transmit power because of regulatory limits\n"); power = maxPower; } - DEBUG_MSG("Set radio: final power level=%d\n", power); + LOG_DEBUG("Set radio: final power level=%d\n", power); } @@ -491,7 +491,7 @@ size_t RadioInterface::beginSending(MeshPacket *p) { assert(!sendingPacket); - // DEBUG_MSG("sending queued packet on mesh (txGood=%d,rxGood=%d,rxBad=%d)\n", rf95.txGood(), rf95.rxGood(), rf95.rxBad()); + // LOG_DEBUG("sending queued packet on mesh (txGood=%d,rxGood=%d,rxBad=%d)\n", rf95.txGood(), rf95.rxGood(), rf95.rxBad()); assert(p->which_payload_variant == MeshPacket_encrypted_tag); // It should have already been encoded by now lastTxStart = millis(); diff --git a/src/mesh/RadioLibInterface.cpp b/src/mesh/RadioLibInterface.cpp index 18f2ef2f1a..127a246c0b 100644 --- a/src/mesh/RadioLibInterface.cpp +++ b/src/mesh/RadioLibInterface.cpp @@ -82,17 +82,17 @@ bool RadioLibInterface::canSendImmediately() if (busyTx || busyRx) { if (busyTx) - DEBUG_MSG("Can not send yet, busyTx\n"); + LOG_DEBUG("Can not send yet, busyTx\n"); // If we've been trying to send the same packet more than one minute and we haven't gotten a // TX IRQ from the radio, the radio is probably broken. if (busyTx && (millis() - lastTxStart > 60000)) { - DEBUG_MSG("Hardware Failure! busyTx for more than 60s\n"); + LOG_DEBUG("Hardware Failure! busyTx for more than 60s\n"); RECORD_CRITICALERROR(CriticalErrorCode_TRANSMIT_FAILED); // reboot in 5 seconds when this condition occurs. rebootAtMsec = lastTxStart + 65000; } if (busyRx) - DEBUG_MSG("Can not send yet, busyRx\n"); + LOG_DEBUG("Can not send yet, busyRx\n"); return false; } else return true; @@ -111,13 +111,13 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) if (config.lora.region != Config_LoRaConfig_RegionCode_UNSET) { if (disabled || !config.lora.tx_enabled) { - DEBUG_MSG("send - !config.lora.tx_enabled\n"); + LOG_DEBUG("send - !config.lora.tx_enabled\n"); packetPool.release(p); return ERRNO_DISABLED; } } else { - DEBUG_MSG("send - lora tx disable because RegionCode_Unset\n"); + LOG_DEBUG("send - lora tx disable because RegionCode_Unset\n"); packetPool.release(p); return ERRNO_DISABLED; } @@ -127,7 +127,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) #else if (disabled || !config.lora.tx_enabled) { - DEBUG_MSG("send - !config.lora.tx_enabled\n"); + LOG_DEBUG("send - !config.lora.tx_enabled\n"); packetPool.release(p); return ERRNO_DISABLED; } @@ -138,7 +138,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) #ifndef LORA_DISABLE_SENDING printPacket("enqueuing for send", p); - DEBUG_MSG("txGood=%d,rxGood=%d,rxBad=%d\n", txGood, rxGood, rxBad); + LOG_DEBUG("txGood=%d,rxGood=%d,rxBad=%d\n", txGood, rxGood, rxBad); ErrorCode res = txQueue.enqueue(p) ? ERRNO_OK : ERRNO_UNKNOWN; if (res != ERRNO_OK) { // we weren't able to queue it, so we must drop it to prevent leaks @@ -148,7 +148,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) // set (random) transmit delay to let others reconfigure their radio, // to avoid collisions and implement timing-based flooding - // DEBUG_MSG("Set random delay before transmitting.\n"); + // LOG_DEBUG("Set random delay before transmitting.\n"); setTransmitDelay(); return res; @@ -162,7 +162,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) { bool res = txQueue.empty(); if (!res) // only print debug messages if we are vetoing sleep - DEBUG_MSG("radio wait to sleep, txEmpty=%d\n", res); + LOG_DEBUG("radio wait to sleep, txEmpty=%d\n", res); return res; } @@ -175,7 +175,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) packetPool.release(p); // free the packet we just removed bool result = (p != NULL); - DEBUG_MSG("cancelSending id=0x%x, removed=%d\n", id, result); + LOG_DEBUG("cancelSending id=0x%x, removed=%d\n", id, result); return result; } @@ -192,27 +192,27 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) case ISR_TX: handleTransmitInterrupt(); startReceive(); - // DEBUG_MSG("tx complete - starting timer\n"); + // LOG_DEBUG("tx complete - starting timer\n"); startTransmitTimer(); break; case ISR_RX: handleReceiveInterrupt(); startReceive(); - // DEBUG_MSG("rx complete - starting timer\n"); + // LOG_DEBUG("rx complete - starting timer\n"); startTransmitTimer(); break; case TRANSMIT_DELAY_COMPLETED: - // DEBUG_MSG("delay done\n"); + // LOG_DEBUG("delay done\n"); // If we are not currently in receive mode, then restart the random delay (this can happen if the main thread // has placed the unit into standby) FIXME, how will this work if the chipset is in sleep mode? if (!txQueue.empty()) { if (!canSendImmediately()) { - // DEBUG_MSG("Currently Rx/Tx-ing: set random delay\n"); + // LOG_DEBUG("Currently Rx/Tx-ing: set random delay\n"); setTransmitDelay(); // currently Rx/Tx-ing: reset random delay } else { if (isChannelActive()) { // check if there is currently a LoRa packet on the channel - // DEBUG_MSG("Channel is active: set random delay\n"); + // LOG_DEBUG("Channel is active: set random delay\n"); setTransmitDelay(); // reset random delay } else { // Send any outgoing packets we have ready @@ -226,7 +226,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) } } } else { - // DEBUG_MSG("done with txqueue\n"); + // LOG_DEBUG("done with txqueue\n"); } break; default: @@ -249,7 +249,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) startTransmitTimer(true); } else { // If there is a SNR, start a timer scaled based on that SNR. - DEBUG_MSG("rx_snr found. hop_limit:%d rx_snr:%f\n", p->hop_limit, p->rx_snr); + LOG_DEBUG("rx_snr found. hop_limit:%d rx_snr:%f\n", p->hop_limit, p->rx_snr); startTransmitTimerSNR(p->rx_snr); } } @@ -259,7 +259,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) // If we have work to do and the timer wasn't already scheduled, schedule it now if (!txQueue.empty()) { uint32_t delay = !withDelay ? 1 : getTxDelayMsec(); - // DEBUG_MSG("xmit timer %d\n", delay); + // LOG_DEBUG("xmit timer %d\n", delay); notifyLater(delay, TRANSMIT_DELAY_COMPLETED, false); // This will implicitly enable } } @@ -269,14 +269,14 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) // If we have work to do and the timer wasn't already scheduled, schedule it now if (!txQueue.empty()) { uint32_t delay = getTxDelayMsecWeighted(snr); - // DEBUG_MSG("xmit timer %d\n", delay); + // LOG_DEBUG("xmit timer %d\n", delay); notifyLater(delay, TRANSMIT_DELAY_COMPLETED, false); // This will implicitly enable } } void RadioLibInterface::handleTransmitInterrupt() { - // DEBUG_MSG("handling lora TX interrupt\n"); + // LOG_DEBUG("handling lora TX interrupt\n"); // This can be null if we forced the device to enter standby mode. In that case // ignore the transmit interrupt if (sendingPacket) @@ -296,7 +296,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) // We are done sending that packet, release it packetPool.release(p); - // DEBUG_MSG("Done with send\n"); + // LOG_DEBUG("Done with send\n"); } } @@ -306,7 +306,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) // when this is called, we should be in receive mode - if we are not, just jump out instead of bombing. Possible Race Condition? if (!isReceiving) { - DEBUG_MSG("*** WAS_ASSERT *** handleReceiveInterrupt called when not in receive mode\n"); + LOG_DEBUG("*** WAS_ASSERT *** handleReceiveInterrupt called when not in receive mode\n"); return; } @@ -319,7 +319,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) int state = iface->readData(radiobuf, length); if (state != RADIOLIB_ERR_NONE) { - DEBUG_MSG("ignoring received packet due to error=%d\n", state); + LOG_DEBUG("ignoring received packet due to error=%d\n", state); rxBad++; airTime->logAirtime(RX_ALL_LOG, xmitMsec); @@ -331,7 +331,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) // check for short packets if (payloadLen < 0) { - DEBUG_MSG("ignoring received packet too short\n"); + LOG_DEBUG("ignoring received packet too short\n"); rxBad++; airTime->logAirtime(RX_ALL_LOG, xmitMsec); } else { @@ -374,7 +374,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) { printPacket("Starting low level send", txp); if (disabled || !config.lora.tx_enabled) { - DEBUG_MSG("startSend is dropping tx packet because we are disabled\n"); + LOG_DEBUG("startSend is dropping tx packet because we are disabled\n"); packetPool.release(txp); } else { setStandby(); // Cancel any already in process receives @@ -385,7 +385,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) int res = iface->startTransmit(radiobuf, numbytes); if (res != RADIOLIB_ERR_NONE) { - DEBUG_MSG("startTransmit failed, error=%d\n", res); + LOG_DEBUG("startTransmit failed, error=%d\n", res); RECORD_CRITICALERROR(CriticalErrorCode_RADIO_SPI_BUG); // This send failed, but make sure to 'complete' it properly diff --git a/src/mesh/RadioLibRF95.cpp b/src/mesh/RadioLibRF95.cpp index 93f0789189..6067f59b61 100644 --- a/src/mesh/RadioLibRF95.cpp +++ b/src/mesh/RadioLibRF95.cpp @@ -22,8 +22,8 @@ int16_t RadioLibRF95::begin(float freq, float bw, uint8_t sf, uint8_t cr, uint8_ // current limit was removed from module' ctor // override default value (60 mA) state = setCurrentLimit(currentLimit); - DEBUG_MSG("Current limit set to %f\n", currentLimit); - DEBUG_MSG("Current limit set result %d\n", state); + LOG_DEBUG("Current limit set to %f\n", currentLimit); + LOG_DEBUG("Current limit set result %d\n", state); // configure settings not accessible by API state = config(); diff --git a/src/mesh/ReliableRouter.cpp b/src/mesh/ReliableRouter.cpp index 22f3692b9c..a7e80e8a11 100644 --- a/src/mesh/ReliableRouter.cpp +++ b/src/mesh/ReliableRouter.cpp @@ -42,14 +42,14 @@ bool ReliableRouter::shouldFilterReceived(const MeshPacket *p) auto key = GlobalPacketId(getFrom(p), p->id); auto old = findPendingPacket(key); if (old) { - DEBUG_MSG("generating implicit ack\n"); + LOG_DEBUG("generating implicit ack\n"); // NOTE: we do NOT check p->wantAck here because p is the INCOMING rebroadcast and that packet is not expected to be // marked as wantAck sendAckNak(Routing_Error_NONE, getFrom(p), p->id, old->packet->channel); stopRetransmission(key); } else { - DEBUG_MSG("didn't find pending packet\n"); + LOG_DEBUG("didn't find pending packet\n"); } } @@ -59,7 +59,7 @@ bool ReliableRouter::shouldFilterReceived(const MeshPacket *p) * flooding this ACK back to the original sender already adds redundancy. */ if (wasSeenRecently(p, false) && p->hop_limit == HOP_RELIABLE && !MeshModule::currentReply && p->to != nodeDB.getNodeNum()) { // retransmission on broadcast has hop_limit still equal to HOP_RELIABLE - DEBUG_MSG("Resending implicit ack for a repeated floodmsg\n"); + LOG_DEBUG("Resending implicit ack for a repeated floodmsg\n"); MeshPacket *tosend = packetPool.allocCopy(*p); tosend->hop_limit--; // bump down the hop count Router::send(tosend); @@ -87,7 +87,7 @@ void ReliableRouter::sniffReceived(const MeshPacket *p, const Routing *c) if (p->to == ourNode) { // ignore ack/nak/want_ack packets that are not address to us (we only handle 0 hop reliability) if (p->want_ack) { if (MeshModule::currentReply) - DEBUG_MSG("Some other module has replied to this message, no need for a 2nd ack\n"); + LOG_DEBUG("Some other module has replied to this message, no need for a 2nd ack\n"); else if (p->which_payload_variant == MeshPacket_decoded_tag) sendAckNak(Routing_Error_NONE, getFrom(p), p->id, p->channel); @@ -105,10 +105,10 @@ void ReliableRouter::sniffReceived(const MeshPacket *p, const Routing *c) // We intentionally don't check wasSeenRecently, because it is harmless to delete non existent retransmission records if (ackId || nakId) { if (ackId) { - DEBUG_MSG("Received an ack for 0x%x, stopping retransmissions\n", ackId); + LOG_DEBUG("Received an ack for 0x%x, stopping retransmissions\n", ackId); stopRetransmission(p->to, ackId); } else { - DEBUG_MSG("Received a nak for 0x%x, stopping retransmissions\n", nakId); + LOG_DEBUG("Received a nak for 0x%x, stopping retransmissions\n", nakId); stopRetransmission(p->to, nakId); } } @@ -190,14 +190,14 @@ int32_t ReliableRouter::doRetransmissions() // FIXME, handle 51 day rolloever here!!! if (p.nextTxMsec <= now) { if (p.numRetransmissions == 0) { - DEBUG_MSG("Reliable send failed, returning a nak for fr=0x%x,to=0x%x,id=0x%x\n", p.packet->from, p.packet->to, + LOG_DEBUG("Reliable send failed, returning a nak for fr=0x%x,to=0x%x,id=0x%x\n", p.packet->from, p.packet->to, p.packet->id); sendAckNak(Routing_Error_MAX_RETRANSMIT, getFrom(p.packet), p.packet->id, p.packet->channel); // Note: we don't stop retransmission here, instead the Nak packet gets processed in sniffReceived stopRetransmission(it->first); stillValid = false; // just deleted it } else { - DEBUG_MSG("Sending reliable retransmission fr=0x%x,to=0x%x,id=0x%x, tries left=%d\n", p.packet->from, + LOG_DEBUG("Sending reliable retransmission fr=0x%x,to=0x%x,id=0x%x, tries left=%d\n", p.packet->from, p.packet->to, p.packet->id, p.numRetransmissions); // Note: we call the superclass version because we don't want to have our version of send() add a new @@ -226,7 +226,7 @@ void ReliableRouter::setNextTx(PendingPacket *pending) assert(iface); auto d = iface->getRetransmissionMsec(pending->packet); pending->nextTxMsec = millis() + d; - DEBUG_MSG("Setting next retransmission in %u msecs: ", d); + LOG_DEBUG("Setting next retransmission in %u msecs: ", d); printPacket("", pending->packet); setReceivedMessage(); // Run ASAP, so we can figure out our correct sleep time } diff --git a/src/mesh/Router.cpp b/src/mesh/Router.cpp index 66e21d21d0..826a3f0896 100644 --- a/src/mesh/Router.cpp +++ b/src/mesh/Router.cpp @@ -48,9 +48,9 @@ Router::Router() : concurrency::OSThread("Router"), fromRadioQueue(MAX_RX_FROMRA { // This is called pre main(), don't touch anything here, the following code is not safe - /* DEBUG_MSG("Size of NodeInfo %d\n", sizeof(NodeInfo)); - DEBUG_MSG("Size of SubPacket %d\n", sizeof(SubPacket)); - DEBUG_MSG("Size of MeshPacket %d\n", sizeof(MeshPacket)); */ + /* LOG_DEBUG("Size of NodeInfo %d\n", sizeof(NodeInfo)); + LOG_DEBUG("Size of SubPacket %d\n", sizeof(SubPacket)); + LOG_DEBUG("Size of MeshPacket %d\n", sizeof(MeshPacket)); */ fromRadioQueue.setReader(this); } @@ -67,7 +67,7 @@ int32_t Router::runOnce() perhapsHandleReceived(mp); } - // DEBUG_MSG("sleeping forever!\n"); + // LOG_DEBUG("sleeping forever!\n"); return INT32_MAX; // Wait a long time - until we get woken for the message queue } @@ -103,7 +103,7 @@ PacketId generatePacketId() // pick a random initial sequence number at boot (to prevent repeated reboots always starting at 0) // Note: we mask the high order bit to ensure that we never pass a 'negative' number to random i = random(numPacketId & 0x7fffffff); - DEBUG_MSG("Initial packet id %u, numPacketId %u\n", i, numPacketId); + LOG_DEBUG("Initial packet id %u, numPacketId %u\n", i, numPacketId); } i++; @@ -136,14 +136,14 @@ void Router::sendAckNak(Routing_Error err, NodeNum to, PacketId idFrom, ChannelI void Router::abortSendAndNak(Routing_Error err, MeshPacket *p) { - DEBUG_MSG("Error=%d, returning NAK and dropping packet.\n", err); + LOG_DEBUG("Error=%d, returning NAK and dropping packet.\n", err); sendAckNak(Routing_Error_NO_INTERFACE, getFrom(p), p->id, p->channel); packetPool.release(p); } void Router::setReceivedMessage() { - // DEBUG_MSG("set interval to ASAP\n"); + // LOG_DEBUG("set interval to ASAP\n"); setInterval(0); // Run ASAP, so we can figure out our correct sleep time runASAP = true; } @@ -173,10 +173,10 @@ ErrorCode Router::sendLocal(MeshPacket *p, RxSource src) void printBytes(const char *label, const uint8_t *p, size_t numbytes) { - DEBUG_MSG("%s: ", label); + LOG_DEBUG("%s: ", label); for (size_t i = 0; i < numbytes; i++) - DEBUG_MSG("%02x ", p[i]); - DEBUG_MSG("\n"); + LOG_DEBUG("%02x ", p[i]); + LOG_DEBUG("\n"); } /** @@ -193,7 +193,7 @@ ErrorCode Router::send(MeshPacket *p) float hourlyTxPercent = airTime->utilizationTXPercent(); if (hourlyTxPercent > myRegion->dutyCycle) { uint8_t silentMinutes = airTime->getSilentMinutes(hourlyTxPercent, myRegion->dutyCycle); - DEBUG_MSG("WARNING: Duty cycle limit exceeded. Aborting send for now, you can send again in %d minutes.\n", silentMinutes); + LOG_WARN("Duty cycle limit exceeded. Aborting send for now, you can send again in %d minutes.\n", silentMinutes); Routing_Error err = Routing_Error_DUTY_CYCLE_LIMIT; abortSendAndNak(err, p); return err; @@ -239,7 +239,7 @@ ErrorCode Router::send(MeshPacket *p) shouldActuallyEncrypt = false; } - DEBUG_MSG("Should encrypt MQTT?: %d\n", shouldActuallyEncrypt); + LOG_DEBUG("Should encrypt MQTT?: %d\n", shouldActuallyEncrypt); // the packet is currently in a decrypted state. send it now if they want decrypted packets if (mqtt && !shouldActuallyEncrypt) @@ -276,14 +276,14 @@ bool Router::cancelSending(NodeNum from, PacketId id) */ void Router::sniffReceived(const MeshPacket *p, const Routing *c) { - DEBUG_MSG("FIXME-update-db Sniffing packet\n"); + LOG_DEBUG("FIXME-update-db Sniffing packet\n"); // FIXME, update nodedb here for any packet that passes through us } bool perhapsDecode(MeshPacket *p) { - // DEBUG_MSG("\n\n** perhapsDecode payloadVariant - %d\n\n", p->which_payloadVariant); + // LOG_DEBUG("\n\n** perhapsDecode payloadVariant - %d\n\n", p->which_payloadVariant); if (p->which_payload_variant == MeshPacket_decoded_tag) return true; // If packet was already decoded just return @@ -307,9 +307,9 @@ bool perhapsDecode(MeshPacket *p) // Take those raw bytes and convert them back into a well structured protobuf we can understand memset(&p->decoded, 0, sizeof(p->decoded)); if (!pb_decode_from_bytes(bytes, rawSize, &Data_msg, &p->decoded)) { - DEBUG_MSG("Invalid protobufs in received mesh packet (bad psk?)!\n"); + LOG_DEBUG("Invalid protobufs in received mesh packet (bad psk?)!\n"); } else if (p->decoded.portnum == PortNum_UNKNOWN_APP) { - DEBUG_MSG("Invalid portnum (bad psk?)!\n"); + LOG_DEBUG("Invalid portnum (bad psk?)!\n"); } else { // parsing was successful p->which_payload_variant = MeshPacket_decoded_tag; // change type to decoded @@ -317,9 +317,9 @@ bool perhapsDecode(MeshPacket *p) /* if (p->decoded.portnum == PortNum_TEXT_MESSAGE_APP) { - DEBUG_MSG("\n\n** TEXT_MESSAGE_APP\n"); + LOG_DEBUG("\n\n** TEXT_MESSAGE_APP\n"); } else if (p->decoded.portnum == PortNum_TEXT_MESSAGE_COMPRESSED_APP) { - DEBUG_MSG("\n\n** PortNum_TEXT_MESSAGE_COMPRESSED_APP\n"); + LOG_DEBUG("\n\n** PortNum_TEXT_MESSAGE_COMPRESSED_APP\n"); } */ @@ -334,7 +334,7 @@ bool perhapsDecode(MeshPacket *p) decompressed_len = unishox2_decompress_simple(compressed_in, p->decoded.payload.size, decompressed_out); - // DEBUG_MSG("\n\n**\n\nDecompressed length - %d \n", decompressed_len); + // LOG_DEBUG("\n\n**\n\nDecompressed length - %d \n", decompressed_len); memcpy(p->decoded.payload.bytes, decompressed_out, decompressed_len); @@ -348,7 +348,7 @@ bool perhapsDecode(MeshPacket *p) } } - DEBUG_MSG("No suitable channel found for decoding, hash was 0x%x!\n", p->channel); + LOG_DEBUG("No suitable channel found for decoding, hash was 0x%x!\n", p->channel); return false; } @@ -374,20 +374,20 @@ Routing_Error perhapsEncode(MeshPacket *p) int compressed_len; compressed_len = unishox2_compress_simple(original_payload, p->decoded.payload.size, compressed_out); - DEBUG_MSG("Original length - %d \n", p->decoded.payload.size); - DEBUG_MSG("Compressed length - %d \n", compressed_len); - DEBUG_MSG("Original message - %s \n", p->decoded.payload.bytes); + LOG_DEBUG("Original length - %d \n", p->decoded.payload.size); + LOG_DEBUG("Compressed length - %d \n", compressed_len); + LOG_DEBUG("Original message - %s \n", p->decoded.payload.bytes); // If the compressed length is greater than or equal to the original size, don't use the compressed form if (compressed_len >= p->decoded.payload.size) { - DEBUG_MSG("Not using compressing message.\n"); + LOG_DEBUG("Not using compressing message.\n"); // Set the uncompressed payload varient anyway. Shouldn't hurt? // p->decoded.which_payloadVariant = Data_payload_tag; // Otherwise we use the compressor } else { - DEBUG_MSG("Using compressed message.\n"); + LOG_DEBUG("Using compressed message.\n"); // Copy the compressed data into the meshpacket p->decoded.payload.size = compressed_len; @@ -459,9 +459,9 @@ void Router::perhapsHandleReceived(MeshPacket *p) bool ignore = is_in_repeated(config.lora.ignore_incoming, p->from); if (ignore) - DEBUG_MSG("Ignoring incoming message, 0x%x is in our ignore list\n", p->from); + LOG_DEBUG("Ignoring incoming message, 0x%x is in our ignore list\n", p->from); else if (ignore |= shouldFilterReceived(p)) { - DEBUG_MSG("Incoming message was filtered 0x%x\n", p->from); + LOG_DEBUG("Incoming message was filtered 0x%x\n", p->from); } // Note: we avoid calling shouldFilterReceived if we are supposed to ignore certain nodes - because some overrides might diff --git a/src/mesh/SX126xInterface.cpp b/src/mesh/SX126xInterface.cpp index ea7600dfc3..1caf8c9d88 100644 --- a/src/mesh/SX126xInterface.cpp +++ b/src/mesh/SX126xInterface.cpp @@ -12,7 +12,7 @@ SX126xInterface::SX126xInterface(RADIOLIB_PIN_TYPE cs, RADIOLIB_PIN_TYPE irq, SPIClass &spi) : RadioLibInterface(cs, irq, rst, busy, spi, &lora), lora(&module) { - DEBUG_MSG("SX126xInterface(cs=%d, irq=%d, rst=%d, busy=%d)\n", cs, irq, rst, busy); + LOG_DEBUG("SX126xInterface(cs=%d, irq=%d, rst=%d, busy=%d)\n", cs, irq, rst, busy); } /// Initialise the Driver transport hardware and software. @@ -55,17 +55,17 @@ bool SX126xInterface::init() int res = lora.begin(getFreq(), bw, sf, cr, syncWord, power, preambleLength, tcxoVoltage, useRegulatorLDO); // \todo Display actual typename of the adapter, not just `SX126x` - DEBUG_MSG("SX126x init result %d\n", res); + LOG_DEBUG("SX126x init result %d\n", res); - DEBUG_MSG("Frequency set to %f\n", getFreq()); - DEBUG_MSG("Bandwidth set to %f\n", bw); - DEBUG_MSG("Power output set to %d\n", power); + LOG_DEBUG("Frequency set to %f\n", getFreq()); + LOG_DEBUG("Bandwidth set to %f\n", bw); + LOG_DEBUG("Power output set to %d\n", power); // current limit was removed from module' ctor // override default value (60 mA) res = lora.setCurrentLimit(currentLimit); - DEBUG_MSG("Current limit set to %f\n", currentLimit); - DEBUG_MSG("Current limit set result %d\n", res); + LOG_DEBUG("Current limit set to %f\n", currentLimit); + LOG_DEBUG("Current limit set result %d\n", res); #if defined(SX126X_TXEN) && (SX126X_TXEN != RADIOLIB_NC) // lora.begin sets Dio2 as RF switch control, which is not true if we are manually controlling RX and TX @@ -170,7 +170,7 @@ void SX126xInterface::setStandby() int err = lora.standby(); if (err != RADIOLIB_ERR_NONE) - DEBUG_MSG("SX126x standby failed with error %d\n", err); + LOG_DEBUG("SX126x standby failed with error %d\n", err); assert(err == RADIOLIB_ERR_NONE); @@ -192,7 +192,7 @@ void SX126xInterface::setStandby() template void SX126xInterface::addReceiveMetadata(MeshPacket *mp) { - // DEBUG_MSG("PacketStatus %x\n", lora.getPacketStatus()); + // LOG_DEBUG("PacketStatus %x\n", lora.getPacketStatus()); mp->rx_snr = lora.getSNR(); mp->rx_rssi = lround(lora.getRSSI()); } @@ -275,7 +275,7 @@ bool SX126xInterface::isActivelyReceiving() // this is not correct - often always true - need to add an extra conditional // size_t bytesPending = lora.getPacketLength(); - // if (hasPreamble) DEBUG_MSG("rx hasPreamble\n"); + // if (hasPreamble) LOG_DEBUG("rx hasPreamble\n"); return hasPreamble; } @@ -284,7 +284,7 @@ bool SX126xInterface::sleep() { // Not keeping config is busted - next time nrf52 board boots lora sending fails tcxo related? - see datasheet // \todo Display actual typename of the adapter, not just `SX126x` - DEBUG_MSG("sx126x entering sleep mode (FIXME, don't keep config)\n"); + LOG_DEBUG("sx126x entering sleep mode (FIXME, don't keep config)\n"); setStandby(); // Stop any pending operations // turn off TCXO if it was powered diff --git a/src/mesh/SX128xInterface.cpp b/src/mesh/SX128xInterface.cpp index d056ab8ddf..b96801794d 100644 --- a/src/mesh/SX128xInterface.cpp +++ b/src/mesh/SX128xInterface.cpp @@ -49,10 +49,10 @@ bool SX128xInterface::init() int res = lora.begin(getFreq(), bw, sf, cr, syncWord, power, preambleLength); // \todo Display actual typename of the adapter, not just `SX128x` - DEBUG_MSG("SX128x init result %d\n", res); + LOG_DEBUG("SX128x init result %d\n", res); if((config.lora.region != Config_LoRaConfig_RegionCode_LORA_24) && (res == RADIOLIB_ERR_INVALID_FREQUENCY)) { - DEBUG_MSG("Warning: Radio chip only supports 2.4GHz LoRa. Adjusting Region and rebooting.\n"); + LOG_WARN("Radio chip only supports 2.4GHz LoRa. Adjusting Region and rebooting.\n"); config.lora.region = Config_LoRaConfig_RegionCode_LORA_24; nodeDB.saveToDisk(SEGMENT_CONFIG); delay(2000); @@ -61,13 +61,13 @@ bool SX128xInterface::init() #elif defined(ARCH_NRF52) NVIC_SystemReset(); #else - DEBUG_MSG("FIXME implement reboot for this platform. Skipping for now.\n"); + LOG_DEBUG("FIXME implement reboot for this platform. Skipping for now.\n"); #endif } - DEBUG_MSG("Frequency set to %f\n", getFreq()); - DEBUG_MSG("Bandwidth set to %f\n", bw); - DEBUG_MSG("Power output set to %d\n", power); + LOG_DEBUG("Frequency set to %f\n", getFreq()); + LOG_DEBUG("Bandwidth set to %f\n", bw); + LOG_DEBUG("Power output set to %d\n", power); if (res == RADIOLIB_ERR_NONE) res = lora.setCRC(2); @@ -145,7 +145,7 @@ void SX128xInterface::setStandby() int err = lora.standby(); if (err != RADIOLIB_ERR_NONE) - DEBUG_MSG("SX128x standby failed with error %d\n", err); + LOG_DEBUG("SX128x standby failed with error %d\n", err); assert(err == RADIOLIB_ERR_NONE); @@ -167,7 +167,7 @@ void SX128xInterface::setStandby() template void SX128xInterface::addReceiveMetadata(MeshPacket *mp) { - // DEBUG_MSG("PacketStatus %x\n", lora.getPacketStatus()); + // LOG_DEBUG("PacketStatus %x\n", lora.getPacketStatus()); mp->rx_snr = lora.getSNR(); mp->rx_rssi = lround(lora.getRSSI()); } @@ -248,7 +248,7 @@ bool SX128xInterface::sleep() { // Not keeping config is busted - next time nrf52 board boots lora sending fails tcxo related? - see datasheet // \todo Display actual typename of the adapter, not just `SX128x` - DEBUG_MSG("SX128x entering sleep mode (FIXME, don't keep config)\n"); + LOG_DEBUG("SX128x entering sleep mode (FIXME, don't keep config)\n"); setStandby(); // Stop any pending operations // turn off TCXO if it was powered diff --git a/src/mesh/StreamAPI.cpp b/src/mesh/StreamAPI.cpp index 57911cf77e..9be24cac99 100644 --- a/src/mesh/StreamAPI.cpp +++ b/src/mesh/StreamAPI.cpp @@ -95,7 +95,7 @@ void StreamAPI::writeStream() void StreamAPI::emitTxBuffer(size_t len) { if (len != 0) { - // DEBUG_MSG("emit tx %d\n", len); + // LOG_DEBUG("emit tx %d\n", len); txBuf[0] = START1; txBuf[1] = START2; txBuf[2] = (len >> 8) & 0xff; @@ -114,7 +114,7 @@ void StreamAPI::emitRebooted() fromRadioScratch.which_payload_variant = FromRadio_rebooted_tag; fromRadioScratch.rebooted = true; - // DEBUG_MSG("Emitting reboot packet for serial shell\n"); + // LOG_DEBUG("Emitting reboot packet for serial shell\n"); emitTxBuffer(pb_encode_to_bytes(txBuf + HEADER_LEN, FromRadio_size, &FromRadio_msg, &fromRadioScratch)); } diff --git a/src/mesh/eth/ethClient.cpp b/src/mesh/eth/ethClient.cpp index 793a861252..57decacdc1 100644 --- a/src/mesh/eth/ethClient.cpp +++ b/src/mesh/eth/ethClient.cpp @@ -29,10 +29,10 @@ static int32_t reconnectETH() Ethernet.maintain(); if (!ethStartupComplete) { // Start web server - DEBUG_MSG("... Starting network services\n"); + LOG_DEBUG("... Starting network services\n"); #ifndef DISABLE_NTP - DEBUG_MSG("Starting NTP time client\n"); + LOG_DEBUG("Starting NTP time client\n"); timeClient.begin(); timeClient.setUpdateInterval(60 * 60); // Update once an hour #endif @@ -51,9 +51,9 @@ static int32_t reconnectETH() #ifndef DISABLE_NTP if (isEthernetAvailable() && (ntp_renew < millis())) { - DEBUG_MSG("Updating NTP time from %s\n", config.network.ntp_server); + LOG_DEBUG("Updating NTP time from %s\n", config.network.ntp_server); if (timeClient.update()) { - DEBUG_MSG("NTP Request Success - Setting RTCQualityNTP if needed\n"); + LOG_DEBUG("NTP Request Success - Setting RTCQualityNTP if needed\n"); struct timeval tv; tv.tv_sec = timeClient.getEpochTime(); @@ -64,7 +64,7 @@ static int32_t reconnectETH() ntp_renew = millis() + 43200 * 1000; // success, refresh every 12 hours } else { - DEBUG_MSG("NTP Update failed\n"); + LOG_DEBUG("NTP Update failed\n"); ntp_renew = millis() + 300 * 1000; // failure, retry every 5 minutes } } @@ -96,32 +96,32 @@ bool initEthernet() getMacAddr(mac); // FIXME use the BLE MAC for now... if (config.network.eth_mode == Config_NetworkConfig_EthMode_DHCP) { - DEBUG_MSG("starting Ethernet DHCP\n"); + LOG_DEBUG("starting Ethernet DHCP\n"); status = Ethernet.begin(mac); } else if (config.network.eth_mode == Config_NetworkConfig_EthMode_STATIC) { - DEBUG_MSG("starting Ethernet Static\n"); + LOG_DEBUG("starting Ethernet Static\n"); Ethernet.begin(mac, config.network.ipv4_config.ip, config.network.ipv4_config.dns, config.network.ipv4_config.subnet); } else { - DEBUG_MSG("Ethernet Disabled\n"); + LOG_DEBUG("Ethernet Disabled\n"); return false; } if (status == 0) { if (Ethernet.hardwareStatus() == EthernetNoHardware) { - DEBUG_MSG("Ethernet shield was not found.\n"); + LOG_DEBUG("Ethernet shield was not found.\n"); return false; } else if (Ethernet.linkStatus() == LinkOFF) { - DEBUG_MSG("Ethernet cable is not connected.\n"); + LOG_DEBUG("Ethernet cable is not connected.\n"); return false; } else{ - DEBUG_MSG("Unknown Ethernet error.\n"); + LOG_DEBUG("Unknown Ethernet error.\n"); return false; } } else { - DEBUG_MSG("Local IP %u.%u.%u.%u\n",Ethernet.localIP()[0], Ethernet.localIP()[1], Ethernet.localIP()[2], Ethernet.localIP()[3]); - DEBUG_MSG("Subnet Mask %u.%u.%u.%u\n",Ethernet.subnetMask()[0], Ethernet.subnetMask()[1], Ethernet.subnetMask()[2], Ethernet.subnetMask()[3]); - DEBUG_MSG("Gateway IP %u.%u.%u.%u\n",Ethernet.gatewayIP()[0], Ethernet.gatewayIP()[1], Ethernet.gatewayIP()[2], Ethernet.gatewayIP()[3]); - DEBUG_MSG("DNS Server IP %u.%u.%u.%u\n",Ethernet.dnsServerIP()[0], Ethernet.dnsServerIP()[1], Ethernet.dnsServerIP()[2], Ethernet.dnsServerIP()[3]); + LOG_DEBUG("Local IP %u.%u.%u.%u\n",Ethernet.localIP()[0], Ethernet.localIP()[1], Ethernet.localIP()[2], Ethernet.localIP()[3]); + LOG_DEBUG("Subnet Mask %u.%u.%u.%u\n",Ethernet.subnetMask()[0], Ethernet.subnetMask()[1], Ethernet.subnetMask()[2], Ethernet.subnetMask()[3]); + LOG_DEBUG("Gateway IP %u.%u.%u.%u\n",Ethernet.gatewayIP()[0], Ethernet.gatewayIP()[1], Ethernet.gatewayIP()[2], Ethernet.gatewayIP()[3]); + LOG_DEBUG("DNS Server IP %u.%u.%u.%u\n",Ethernet.dnsServerIP()[0], Ethernet.dnsServerIP()[1], Ethernet.dnsServerIP()[2], Ethernet.dnsServerIP()[3]); } ethEvent = new Periodic("ethConnect", reconnectETH); @@ -129,7 +129,7 @@ bool initEthernet() return true; } else { - DEBUG_MSG("Not using Ethernet\n"); + LOG_DEBUG("Not using Ethernet\n"); return false; } } diff --git a/src/mesh/eth/ethServerAPI.cpp b/src/mesh/eth/ethServerAPI.cpp index 3b3b6bbc82..4159d285aa 100644 --- a/src/mesh/eth/ethServerAPI.cpp +++ b/src/mesh/eth/ethServerAPI.cpp @@ -9,14 +9,14 @@ void initApiServer(int port) // Start API server on port 4403 if (!apiPort) { apiPort = new ethServerPort(port); - DEBUG_MSG("API server listening on TCP port %d\n", port); + LOG_DEBUG("API server listening on TCP port %d\n", port); apiPort->init(); } } ethServerAPI::ethServerAPI(EthernetClient &_client) : StreamAPI(&client), concurrency::OSThread("ethServerAPI"), client(_client) { - DEBUG_MSG("Incoming ethernet connection\n"); + LOG_DEBUG("Incoming ethernet connection\n"); } ethServerAPI::~ethServerAPI() @@ -44,7 +44,7 @@ int32_t ethServerAPI::runOnce() if (client.connected()) { return StreamAPI::runOncePart(); } else { - DEBUG_MSG("Client dropped connection, suspending API service\n"); + LOG_DEBUG("Client dropped connection, suspending API service\n"); enabled = false; // we no longer need to run return 0; } @@ -71,7 +71,7 @@ int32_t ethServerPort::runOnce() if (client) { // Close any previous connection (see FIXME in header file) if (openAPI) { - DEBUG_MSG("Force closing previous TCP connection\n"); + LOG_DEBUG("Force closing previous TCP connection\n"); delete openAPI; } diff --git a/src/mesh/http/ContentHandler.cpp b/src/mesh/http/ContentHandler.cpp index d01f3c4a5d..22d97a2b62 100644 --- a/src/mesh/http/ContentHandler.cpp +++ b/src/mesh/http/ContentHandler.cpp @@ -140,7 +140,7 @@ void registerHandlers(HTTPServer *insecureServer, HTTPSServer *secureServer) void handleAPIv1FromRadio(HTTPRequest *req, HTTPResponse *res) { - DEBUG_MSG("webAPI handleAPIv1FromRadio\n"); + LOG_DEBUG("webAPI handleAPIv1FromRadio\n"); /* For documentation, see: @@ -185,12 +185,12 @@ void handleAPIv1FromRadio(HTTPRequest *req, HTTPResponse *res) res->write(txBuf, len); } - DEBUG_MSG("webAPI handleAPIv1FromRadio, len %d\n", len); + LOG_DEBUG("webAPI handleAPIv1FromRadio, len %d\n", len); } void handleAPIv1ToRadio(HTTPRequest *req, HTTPResponse *res) { - DEBUG_MSG("webAPI handleAPIv1ToRadio\n"); + LOG_DEBUG("webAPI handleAPIv1ToRadio\n"); /* For documentation, see: @@ -213,11 +213,11 @@ void handleAPIv1ToRadio(HTTPRequest *req, HTTPResponse *res) byte buffer[MAX_TO_FROM_RADIO_SIZE]; size_t s = req->readBytes(buffer, MAX_TO_FROM_RADIO_SIZE); - DEBUG_MSG("Received %d bytes from PUT request\n", s); + LOG_DEBUG("Received %d bytes from PUT request\n", s); webAPI.handleToRadio(buffer, s); res->write(buffer, s); - DEBUG_MSG("webAPI handleAPIv1ToRadio\n"); + LOG_DEBUG("webAPI handleAPIv1ToRadio\n"); } void htmlDeleteDir(const char *dirname) @@ -238,7 +238,7 @@ void htmlDeleteDir(const char *dirname) } else { String fileName = String(file.name()); file.close(); - DEBUG_MSG(" %s\n", fileName.c_str()); + LOG_DEBUG(" %s\n", fileName.c_str()); FSCom.remove(fileName); } file = root.openNextFile(); @@ -379,13 +379,13 @@ void handleStatic(HTTPRequest *req, HTTPResponse *res) if (FSCom.exists(filename.c_str())) { file = FSCom.open(filename.c_str()); if (!file.available()) { - DEBUG_MSG("File not available - %s\n", filename.c_str()); + LOG_DEBUG("File not available - %s\n", filename.c_str()); } } else if (FSCom.exists(filenameGzip.c_str())) { file = FSCom.open(filenameGzip.c_str()); res->setHeader("Content-Encoding", "gzip"); if (!file.available()) { - DEBUG_MSG("File not available - %s\n", filenameGzip.c_str()); + LOG_DEBUG("File not available - %s\n", filenameGzip.c_str()); } } else { has_set_content_type = true; @@ -393,7 +393,7 @@ void handleStatic(HTTPRequest *req, HTTPResponse *res) file = FSCom.open(filenameGzip.c_str()); res->setHeader("Content-Type", "text/html"); if (!file.available()) { - DEBUG_MSG("File not available - %s\n", filenameGzip.c_str()); + LOG_DEBUG("File not available - %s\n", filenameGzip.c_str()); res->println("Web server is running.

The content you are looking for can't be found. Please see: FAQ.

admin"); @@ -437,7 +437,7 @@ void handleStatic(HTTPRequest *req, HTTPResponse *res) return; } else { - DEBUG_MSG("ERROR: This should not have happened...\n"); + LOG_DEBUG("ERROR: This should not have happened...\n"); res->println("ERROR: This should not have happened..."); } } @@ -445,7 +445,7 @@ void handleStatic(HTTPRequest *req, HTTPResponse *res) void handleFormUpload(HTTPRequest *req, HTTPResponse *res) { - DEBUG_MSG("Form Upload - Disabling keep-alive\n"); + LOG_DEBUG("Form Upload - Disabling keep-alive\n"); res->setHeader("Connection", "close"); // First, we need to check the encoding of the form that we have received. @@ -453,7 +453,7 @@ void handleFormUpload(HTTPRequest *req, HTTPResponse *res) // Then we select the body parser based on the encoding. // Actually we do this only for documentary purposes, we know the form is going // to be multipart/form-data. - DEBUG_MSG("Form Upload - Creating body parser reference\n"); + LOG_DEBUG("Form Upload - Creating body parser reference\n"); HTTPBodyParser *parser; std::string contentType = req->getHeader("Content-Type"); @@ -469,7 +469,7 @@ void handleFormUpload(HTTPRequest *req, HTTPResponse *res) // Now, we can decide based on the content type: if (contentType == "multipart/form-data") { - DEBUG_MSG("Form Upload - multipart/form-data\n"); + LOG_DEBUG("Form Upload - multipart/form-data\n"); parser = new HTTPMultipartBodyParser(req); } else { Serial.printf("Unknown POST Content-Type: %s\n", contentType.c_str()); @@ -499,19 +499,19 @@ void handleFormUpload(HTTPRequest *req, HTTPResponse *res) std::string filename = parser->getFieldFilename(); std::string mimeType = parser->getFieldMimeType(); // We log all three values, so that you can observe the upload on the serial monitor: - DEBUG_MSG("handleFormUpload: field name='%s', filename='%s', mimetype='%s'\n", name.c_str(), filename.c_str(), + LOG_DEBUG("handleFormUpload: field name='%s', filename='%s', mimetype='%s'\n", name.c_str(), filename.c_str(), mimeType.c_str()); // Double check that it is what we expect if (name != "file") { - DEBUG_MSG("Skipping unexpected field\n"); + LOG_DEBUG("Skipping unexpected field\n"); res->println("

No file found.

"); return; } // Double check that it is what we expect if (filename == "") { - DEBUG_MSG("Skipping unexpected field\n"); + LOG_DEBUG("Skipping unexpected field\n"); res->println("

No file found.

"); return; } @@ -532,7 +532,7 @@ void handleFormUpload(HTTPRequest *req, HTTPResponse *res) byte buf[512]; size_t readLength = parser->read(buf, 512); - // DEBUG_MSG("\n\nreadLength - %i\n", readLength); + // LOG_DEBUG("\n\nreadLength - %i\n", readLength); // Abort the transfer if there is less than 50k space left on the filesystem. if (FSCom.totalBytes() - FSCom.usedBytes() < 51200) { @@ -548,7 +548,7 @@ void handleFormUpload(HTTPRequest *req, HTTPResponse *res) // if (readLength) { file.write(buf, readLength); fileLength += readLength; - DEBUG_MSG("File Length %i\n", fileLength); + LOG_DEBUG("File Length %i\n", fileLength); //} } // enableLoopWDT(); @@ -671,7 +671,7 @@ void handleReport(HTTPRequest *req, HTTPResponse *res) */ void handleHotspot(HTTPRequest *req, HTTPResponse *res) { - DEBUG_MSG("Hotspot Request\n"); + LOG_DEBUG("Hotspot Request\n"); /* If we don't do a redirect, be sure to return a "Success" message @@ -697,7 +697,7 @@ void handleDeleteFsContent(HTTPRequest *req, HTTPResponse *res) res->println("

Meshtastic

\n"); res->println("Deleting Content in /static/*"); - DEBUG_MSG("Deleting files from /static/* : \n"); + LOG_DEBUG("Deleting files from /static/* : \n"); htmlDeleteDir("/static"); @@ -771,7 +771,7 @@ void handleRestart(HTTPRequest *req, HTTPResponse *res) res->println("

Meshtastic

\n"); res->println("Restarting"); - DEBUG_MSG("***** Restarted on HTTP(s) Request *****\n"); + LOG_DEBUG("***** Restarted on HTTP(s) Request *****\n"); webServerThread->requestRestart = (millis() / 1000) + 5; } diff --git a/src/mesh/http/WebServer.cpp b/src/mesh/http/WebServer.cpp index c1844b0cb4..10f8067f66 100644 --- a/src/mesh/http/WebServer.cpp +++ b/src/mesh/http/WebServer.cpp @@ -68,19 +68,19 @@ static void taskCreateCert(void *parameter) #if 0 // Delete the saved certs (used in debugging) - DEBUG_MSG("Deleting any saved SSL keys ...\n"); + LOG_DEBUG("Deleting any saved SSL keys ...\n"); // prefs.clear(); prefs.remove("PK"); prefs.remove("cert"); #endif - DEBUG_MSG("Checking if we have a previously saved SSL Certificate.\n"); + LOG_DEBUG("Checking if we have a previously saved SSL Certificate.\n"); size_t pkLen = prefs.getBytesLength("PK"); size_t certLen = prefs.getBytesLength("cert"); if (pkLen && certLen) { - DEBUG_MSG("Existing SSL Certificate found!\n"); + LOG_DEBUG("Existing SSL Certificate found!\n"); uint8_t *pkBuffer = new uint8_t[pkLen]; prefs.getBytes("PK", pkBuffer, pkLen); @@ -90,12 +90,12 @@ static void taskCreateCert(void *parameter) cert = new SSLCert(certBuffer, certLen, pkBuffer, pkLen); - DEBUG_MSG("Retrieved Private Key: %d Bytes\n", cert->getPKLength()); - DEBUG_MSG("Retrieved Certificate: %d Bytes\n", cert->getCertLength()); + LOG_DEBUG("Retrieved Private Key: %d Bytes\n", cert->getPKLength()); + LOG_DEBUG("Retrieved Certificate: %d Bytes\n", cert->getCertLength()); } else { - DEBUG_MSG("Creating the certificate. This may take a while. Please wait...\n"); + LOG_DEBUG("Creating the certificate. This may take a while. Please wait...\n"); yield(); cert = new SSLCert(); yield(); @@ -104,14 +104,14 @@ static void taskCreateCert(void *parameter) yield(); if (createCertResult != 0) { - DEBUG_MSG("Creating the certificate failed\n"); + LOG_DEBUG("Creating the certificate failed\n"); } else { - DEBUG_MSG("Creating the certificate was successful\n"); + LOG_DEBUG("Creating the certificate was successful\n"); - DEBUG_MSG("Created Private Key: %d Bytes\n", cert->getPKLength()); + LOG_DEBUG("Created Private Key: %d Bytes\n", cert->getPKLength()); - DEBUG_MSG("Created Certificate: %d Bytes\n", cert->getCertLength()); + LOG_DEBUG("Created Certificate: %d Bytes\n", cert->getCertLength()); prefs.putBytes("PK", (uint8_t *)cert->getPKData(), cert->getPKLength()); prefs.putBytes("cert", (uint8_t *)cert->getCertData(), cert->getCertLength()); @@ -140,11 +140,11 @@ void createSSLCert() 16, /* Priority of the task. */ NULL); /* Task handle. */ - DEBUG_MSG("Waiting for SSL Cert to be generated.\n"); + LOG_DEBUG("Waiting for SSL Cert to be generated.\n"); while (!isCertReady) { if ((millis() / 500) % 2) { if (runLoop) { - DEBUG_MSG("."); + LOG_DEBUG("."); yield(); esp_task_wdt_reset(); @@ -159,7 +159,7 @@ void createSSLCert() runLoop = true; } } - DEBUG_MSG("SSL Cert Ready!\n"); + LOG_DEBUG("SSL Cert Ready!\n"); } } @@ -169,7 +169,7 @@ WebServerThread::WebServerThread() : concurrency::OSThread("WebServerThread") {} int32_t WebServerThread::runOnce() { - // DEBUG_MSG("WebServerThread::runOnce()\n"); + // LOG_DEBUG("WebServerThread::runOnce()\n"); handleWebResponse(); if (requestRestart && (millis() / 1000) > requestRestart) { @@ -182,7 +182,7 @@ int32_t WebServerThread::runOnce() void initWebServer() { - DEBUG_MSG("Initializing Web Server ...\n"); + LOG_DEBUG("Initializing Web Server ...\n"); // We can now use the new certificate to setup our server as usual. secureServer = new HTTPSServer(cert); @@ -191,15 +191,15 @@ void initWebServer() registerHandlers(insecureServer, secureServer); if (secureServer) { - DEBUG_MSG("Starting Secure Web Server...\n"); + LOG_DEBUG("Starting Secure Web Server...\n"); secureServer->start(); } - DEBUG_MSG("Starting Insecure Web Server...\n"); + LOG_DEBUG("Starting Insecure Web Server...\n"); insecureServer->start(); if (insecureServer->isRunning()) { - DEBUG_MSG("Web Servers Ready! :-) \n"); + LOG_DEBUG("Web Servers Ready! :-) \n"); isWebServerReady = true; } else { - DEBUG_MSG("Web Servers Failed! ;-( \n"); + LOG_DEBUG("Web Servers Failed! ;-( \n"); } } diff --git a/src/mesh/http/WiFiAPClient.cpp b/src/mesh/http/WiFiAPClient.cpp index 731197e602..13e1277566 100644 --- a/src/mesh/http/WiFiAPClient.cpp +++ b/src/mesh/http/WiFiAPClient.cpp @@ -56,7 +56,7 @@ static int32_t reconnectWiFi() // Make sure we clear old connection credentials WiFi.disconnect(false, true); - DEBUG_MSG("Reconnecting to WiFi access point %s\n",wifiName); + LOG_DEBUG("Reconnecting to WiFi access point %s\n",wifiName); WiFi.mode(WIFI_MODE_STA); WiFi.begin(wifiName, wifiPsw); @@ -64,9 +64,9 @@ static int32_t reconnectWiFi() #ifndef DISABLE_NTP if (WiFi.isConnected() && (((millis() - lastrun_ntp) > 43200000) || (lastrun_ntp == 0))) { // every 12 hours - DEBUG_MSG("Updating NTP time from %s\n",config.network.ntp_server); + LOG_DEBUG("Updating NTP time from %s\n",config.network.ntp_server); if (timeClient.update()) { - DEBUG_MSG("NTP Request Success - Setting RTCQualityNTP if needed\n"); + LOG_DEBUG("NTP Request Success - Setting RTCQualityNTP if needed\n"); struct timeval tv; tv.tv_sec = timeClient.getEpochTime(); @@ -76,7 +76,7 @@ static int32_t reconnectWiFi() lastrun_ntp = millis(); } else { - DEBUG_MSG("NTP Update failed\n"); + LOG_DEBUG("NTP Update failed\n"); } } #endif @@ -101,12 +101,12 @@ bool isWifiAvailable() // Disable WiFi void deinitWifi() { - DEBUG_MSG("WiFi deinit\n"); + LOG_DEBUG("WiFi deinit\n"); if (isWifiAvailable()) { WiFi.disconnect(true); WiFi.mode(WIFI_MODE_NULL); - DEBUG_MSG("WiFi Turned Off\n"); + LOG_DEBUG("WiFi Turned Off\n"); // WiFi.printDiag(Serial); } } @@ -115,20 +115,20 @@ static void onNetworkConnected() { if (!APStartupComplete) { // Start web server - DEBUG_MSG("Starting network services\n"); + LOG_DEBUG("Starting network services\n"); // start mdns if (!MDNS.begin("Meshtastic")) { - DEBUG_MSG("Error setting up MDNS responder!\n"); + LOG_DEBUG("Error setting up MDNS responder!\n"); } else { - DEBUG_MSG("mDNS responder started\n"); - DEBUG_MSG("mDNS Host: Meshtastic.local\n"); + LOG_DEBUG("mDNS responder started\n"); + LOG_DEBUG("mDNS Host: Meshtastic.local\n"); MDNS.addService("http", "tcp", 80); MDNS.addService("https", "tcp", 443); } #ifndef DISABLE_NTP - DEBUG_MSG("Starting NTP time client\n"); + LOG_DEBUG("Starting NTP time client\n"); timeClient.begin(); timeClient.setUpdateInterval(60 * 60); // Update once an hour #endif @@ -196,12 +196,12 @@ bool initWifi() }, WiFiEvent_t::ARDUINO_EVENT_WIFI_STA_DISCONNECTED); - DEBUG_MSG("JOINING WIFI soon: ssid=%s\n", wifiName); + LOG_DEBUG("JOINING WIFI soon: ssid=%s\n", wifiName); wifiReconnect = new Periodic("WifiConnect", reconnectWiFi); } return true; } else { - DEBUG_MSG("Not using WIFI\n"); + LOG_DEBUG("Not using WIFI\n"); return false; } } @@ -209,137 +209,137 @@ bool initWifi() // Called by the Espressif SDK to static void WiFiEvent(WiFiEvent_t event) { - DEBUG_MSG("WiFi-Event %d: ", event); + LOG_DEBUG("WiFi-Event %d: ", event); switch (event) { case ARDUINO_EVENT_WIFI_READY: - DEBUG_MSG("WiFi interface ready\n"); + LOG_DEBUG("WiFi interface ready\n"); break; case ARDUINO_EVENT_WIFI_SCAN_DONE: - DEBUG_MSG("Completed scan for access points\n"); + LOG_DEBUG("Completed scan for access points\n"); break; case ARDUINO_EVENT_WIFI_STA_START: - DEBUG_MSG("WiFi station started\n"); + LOG_DEBUG("WiFi station started\n"); break; case ARDUINO_EVENT_WIFI_STA_STOP: - DEBUG_MSG("WiFi station stopped\n"); + LOG_DEBUG("WiFi station stopped\n"); break; case ARDUINO_EVENT_WIFI_STA_CONNECTED: - DEBUG_MSG("Connected to access point\n"); + LOG_DEBUG("Connected to access point\n"); break; case ARDUINO_EVENT_WIFI_STA_DISCONNECTED: - DEBUG_MSG("Disconnected from WiFi access point\n"); + LOG_DEBUG("Disconnected from WiFi access point\n"); WiFi.disconnect(false, true); needReconnect = true; wifiReconnect->setIntervalFromNow(1000); break; case ARDUINO_EVENT_WIFI_STA_AUTHMODE_CHANGE: - DEBUG_MSG("Authentication mode of access point has changed\n"); + LOG_DEBUG("Authentication mode of access point has changed\n"); break; case ARDUINO_EVENT_WIFI_STA_GOT_IP: - DEBUG_MSG("Obtained IP address: "); + LOG_DEBUG("Obtained IP address: "); Serial.println(WiFi.localIP()); onNetworkConnected(); break; case ARDUINO_EVENT_WIFI_STA_GOT_IP6: - DEBUG_MSG("Obtained IP6 address: "); + LOG_DEBUG("Obtained IP6 address: "); Serial.println(WiFi.localIPv6()); break; case ARDUINO_EVENT_WIFI_STA_LOST_IP: - DEBUG_MSG("Lost IP address and IP address is reset to 0\n"); + LOG_DEBUG("Lost IP address and IP address is reset to 0\n"); WiFi.disconnect(false, true); needReconnect = true; wifiReconnect->setIntervalFromNow(1000); break; case ARDUINO_EVENT_WPS_ER_SUCCESS: - DEBUG_MSG("WiFi Protected Setup (WPS): succeeded in enrollee mode\n"); + LOG_DEBUG("WiFi Protected Setup (WPS): succeeded in enrollee mode\n"); break; case ARDUINO_EVENT_WPS_ER_FAILED: - DEBUG_MSG("WiFi Protected Setup (WPS): failed in enrollee mode\n"); + LOG_DEBUG("WiFi Protected Setup (WPS): failed in enrollee mode\n"); break; case ARDUINO_EVENT_WPS_ER_TIMEOUT: - DEBUG_MSG("WiFi Protected Setup (WPS): timeout in enrollee mode\n"); + LOG_DEBUG("WiFi Protected Setup (WPS): timeout in enrollee mode\n"); break; case ARDUINO_EVENT_WPS_ER_PIN: - DEBUG_MSG("WiFi Protected Setup (WPS): pin code in enrollee mode\n"); + LOG_DEBUG("WiFi Protected Setup (WPS): pin code in enrollee mode\n"); break; case ARDUINO_EVENT_WPS_ER_PBC_OVERLAP: - DEBUG_MSG("WiFi Protected Setup (WPS): push button overlap in enrollee mode\n"); + LOG_DEBUG("WiFi Protected Setup (WPS): push button overlap in enrollee mode\n"); break; case ARDUINO_EVENT_WIFI_AP_START: - DEBUG_MSG("WiFi access point started\n"); + LOG_DEBUG("WiFi access point started\n"); break; case ARDUINO_EVENT_WIFI_AP_STOP: - DEBUG_MSG("WiFi access point stopped\n"); + LOG_DEBUG("WiFi access point stopped\n"); break; case ARDUINO_EVENT_WIFI_AP_STACONNECTED: - DEBUG_MSG("Client connected\n"); + LOG_DEBUG("Client connected\n"); break; case ARDUINO_EVENT_WIFI_AP_STADISCONNECTED: - DEBUG_MSG("Client disconnected\n"); + LOG_DEBUG("Client disconnected\n"); break; case ARDUINO_EVENT_WIFI_AP_STAIPASSIGNED: - DEBUG_MSG("Assigned IP address to client\n"); + LOG_DEBUG("Assigned IP address to client\n"); break; case ARDUINO_EVENT_WIFI_AP_PROBEREQRECVED: - DEBUG_MSG("Received probe request\n"); + LOG_DEBUG("Received probe request\n"); break; case ARDUINO_EVENT_WIFI_AP_GOT_IP6: - DEBUG_MSG("IPv6 is preferred\n"); + LOG_DEBUG("IPv6 is preferred\n"); break; case ARDUINO_EVENT_WIFI_FTM_REPORT: - DEBUG_MSG("Fast Transition Management report\n"); + LOG_DEBUG("Fast Transition Management report\n"); break; case ARDUINO_EVENT_ETH_START: - DEBUG_MSG("Ethernet started\n"); + LOG_DEBUG("Ethernet started\n"); break; case ARDUINO_EVENT_ETH_STOP: - DEBUG_MSG("Ethernet stopped\n"); + LOG_DEBUG("Ethernet stopped\n"); break; case ARDUINO_EVENT_ETH_CONNECTED: - DEBUG_MSG("Ethernet connected\n"); + LOG_DEBUG("Ethernet connected\n"); break; case ARDUINO_EVENT_ETH_DISCONNECTED: - DEBUG_MSG("Ethernet disconnected\n"); + LOG_DEBUG("Ethernet disconnected\n"); break; case ARDUINO_EVENT_ETH_GOT_IP: - DEBUG_MSG("Obtained IP address (ARDUINO_EVENT_ETH_GOT_IP)\n"); + LOG_DEBUG("Obtained IP address (ARDUINO_EVENT_ETH_GOT_IP)\n"); break; case ARDUINO_EVENT_ETH_GOT_IP6: - DEBUG_MSG("Obtained IP6 address (ARDUINO_EVENT_ETH_GOT_IP6)\n"); + LOG_DEBUG("Obtained IP6 address (ARDUINO_EVENT_ETH_GOT_IP6)\n"); break; case ARDUINO_EVENT_SC_SCAN_DONE: - DEBUG_MSG("SmartConfig: Scan done\n"); + LOG_DEBUG("SmartConfig: Scan done\n"); break; case ARDUINO_EVENT_SC_FOUND_CHANNEL: - DEBUG_MSG("SmartConfig: Found channel\n"); + LOG_DEBUG("SmartConfig: Found channel\n"); break; case ARDUINO_EVENT_SC_GOT_SSID_PSWD: - DEBUG_MSG("SmartConfig: Got SSID and password\n"); + LOG_DEBUG("SmartConfig: Got SSID and password\n"); break; case ARDUINO_EVENT_SC_SEND_ACK_DONE: - DEBUG_MSG("SmartConfig: Send ACK done\n"); + LOG_DEBUG("SmartConfig: Send ACK done\n"); break; case ARDUINO_EVENT_PROV_INIT: - DEBUG_MSG("Provisioning: Init\n"); + LOG_DEBUG("Provisioning: Init\n"); break; case ARDUINO_EVENT_PROV_DEINIT: - DEBUG_MSG("Provisioning: Stopped\n"); + LOG_DEBUG("Provisioning: Stopped\n"); break; case ARDUINO_EVENT_PROV_START: - DEBUG_MSG("Provisioning: Started\n"); + LOG_DEBUG("Provisioning: Started\n"); break; case ARDUINO_EVENT_PROV_END: - DEBUG_MSG("Provisioning: End\n"); + LOG_DEBUG("Provisioning: End\n"); break; case ARDUINO_EVENT_PROV_CRED_RECV: - DEBUG_MSG("Provisioning: Credentials received\n"); + LOG_DEBUG("Provisioning: Credentials received\n"); break; case ARDUINO_EVENT_PROV_CRED_FAIL: - DEBUG_MSG("Provisioning: Credentials failed\n"); + LOG_DEBUG("Provisioning: Credentials failed\n"); break; case ARDUINO_EVENT_PROV_CRED_SUCCESS: - DEBUG_MSG("Provisioning: Credentials success\n"); + LOG_DEBUG("Provisioning: Credentials success\n"); break; default: break; diff --git a/src/mesh/mesh-pb-constants.cpp b/src/mesh/mesh-pb-constants.cpp index b2b99644cc..cbf4c76d3f 100644 --- a/src/mesh/mesh-pb-constants.cpp +++ b/src/mesh/mesh-pb-constants.cpp @@ -12,7 +12,7 @@ size_t pb_encode_to_bytes(uint8_t *destbuf, size_t destbufsize, const pb_msgdesc { pb_ostream_t stream = pb_ostream_from_buffer(destbuf, destbufsize); if (!pb_encode(&stream, fields, src_struct)) { - DEBUG_MSG("Panic: can't encode protobuf reason='%s'\n", PB_GET_ERROR(&stream)); + LOG_DEBUG("Panic: can't encode protobuf reason='%s'\n", PB_GET_ERROR(&stream)); assert(0); // If this asser fails it probably means you made a field too large for the max limits specified in mesh.options } else { return stream.bytes_written; @@ -24,7 +24,7 @@ bool pb_decode_from_bytes(const uint8_t *srcbuf, size_t srcbufsize, const pb_msg { pb_istream_t stream = pb_istream_from_buffer(srcbuf, srcbufsize); if (!pb_decode(&stream, fields, dest_struct)) { - DEBUG_MSG("Error: can't decode protobuf reason='%s', pb_msgdesc 0x%p\n", PB_GET_ERROR(&stream), fields); + LOG_DEBUG("Error: can't decode protobuf reason='%s', pb_msgdesc 0x%p\n", PB_GET_ERROR(&stream), fields); return false; } else { return true; @@ -56,7 +56,7 @@ bool readcb(pb_istream_t *stream, uint8_t *buf, size_t count) bool writecb(pb_ostream_t *stream, const uint8_t *buf, size_t count) { File *file = (File *)stream->state; - // DEBUG_MSG("writing %d bytes to protobuf file\n", count); + // LOG_DEBUG("writing %d bytes to protobuf file\n", count); return file->write(buf, count) == count; } #endif diff --git a/src/mesh/wifi/WiFiServerAPI.cpp b/src/mesh/wifi/WiFiServerAPI.cpp index 78936176b1..98e38f9260 100644 --- a/src/mesh/wifi/WiFiServerAPI.cpp +++ b/src/mesh/wifi/WiFiServerAPI.cpp @@ -9,14 +9,14 @@ void initApiServer(int port) // Start API server on port 4403 if (!apiPort) { apiPort = new WiFiServerPort(port); - DEBUG_MSG("API server listening on TCP port %d\n", port); + LOG_DEBUG("API server listening on TCP port %d\n", port); apiPort->init(); } } WiFiServerAPI::WiFiServerAPI(WiFiClient &_client) : StreamAPI(&client), concurrency::OSThread("WiFiServerAPI"), client(_client) { - DEBUG_MSG("Incoming wifi connection\n"); + LOG_DEBUG("Incoming wifi connection\n"); } WiFiServerAPI::~WiFiServerAPI() @@ -44,7 +44,7 @@ int32_t WiFiServerAPI::runOnce() if (client.connected()) { return StreamAPI::runOncePart(); } else { - DEBUG_MSG("Client dropped connection, suspending API service\n"); + LOG_DEBUG("Client dropped connection, suspending API service\n"); enabled = false; // we no longer need to run return 0; } @@ -71,7 +71,7 @@ int32_t WiFiServerPort::runOnce() if (client) { // Close any previous connection (see FIXME in header file) if (openAPI) { - DEBUG_MSG("Force closing previous TCP connection\n"); + LOG_DEBUG("Force closing previous TCP connection\n"); delete openAPI; } diff --git a/src/modules/AdminModule.cpp b/src/modules/AdminModule.cpp index 023cf73961..30bff79b6a 100644 --- a/src/modules/AdminModule.cpp +++ b/src/modules/AdminModule.cpp @@ -50,23 +50,23 @@ bool AdminModule::handleReceivedProtobuf(const MeshPacket &mp, AdminMessage *r) * Getters */ case AdminMessage_get_owner_request_tag: - DEBUG_MSG("Client is getting owner\n"); + LOG_DEBUG("Client is getting owner\n"); handleGetOwner(mp); break; case AdminMessage_get_config_request_tag: - DEBUG_MSG("Client is getting config\n"); + LOG_DEBUG("Client is getting config\n"); handleGetConfig(mp, r->get_config_request); break; case AdminMessage_get_module_config_request_tag: - DEBUG_MSG("Client is getting module config\n"); + LOG_DEBUG("Client is getting module config\n"); handleGetModuleConfig(mp, r->get_module_config_request); break; case AdminMessage_get_channel_request_tag: { uint32_t i = r->get_channel_request - 1; - DEBUG_MSG("Client is getting channel %u\n", i); + LOG_DEBUG("Client is getting channel %u\n", i); if (i >= MAX_NUM_CHANNELS) myReply = allocErrorResponse(Routing_Error_BAD_REQUEST, &mp); else @@ -78,22 +78,22 @@ bool AdminModule::handleReceivedProtobuf(const MeshPacket &mp, AdminMessage *r) * Setters */ case AdminMessage_set_owner_tag: - DEBUG_MSG("Client is setting owner\n"); + LOG_DEBUG("Client is setting owner\n"); handleSetOwner(r->set_owner); break; case AdminMessage_set_config_tag: - DEBUG_MSG("Client is setting the config\n"); + LOG_DEBUG("Client is setting the config\n"); handleSetConfig(r->set_config); break; case AdminMessage_set_module_config_tag: - DEBUG_MSG("Client is setting the module config\n"); + LOG_DEBUG("Client is setting the module config\n"); handleSetModuleConfig(r->set_module_config); break; case AdminMessage_set_channel_tag: - DEBUG_MSG("Client is setting channel %d\n", r->set_channel.index); + LOG_DEBUG("Client is setting channel %d\n", r->set_channel.index); if (r->set_channel.index < 0 || r->set_channel.index >= (int)MAX_NUM_CHANNELS) myReply = allocErrorResponse(Routing_Error_BAD_REQUEST, &mp); else @@ -111,15 +111,15 @@ bool AdminModule::handleReceivedProtobuf(const MeshPacket &mp, AdminMessage *r) int32_t s = r->reboot_ota_seconds; #ifdef ARCH_ESP32 if (BleOta::getOtaAppVersion().isEmpty()) { - DEBUG_MSG("No OTA firmware available, scheduling regular reboot in %d seconds\n", s); + LOG_DEBUG("No OTA firmware available, scheduling regular reboot in %d seconds\n", s); screen->startRebootScreen(); }else{ screen->startFirmwareUpdateScreen(); BleOta::switchToOtaApp(); - DEBUG_MSG("Rebooting to OTA in %d seconds\n", s); + LOG_DEBUG("Rebooting to OTA in %d seconds\n", s); } #else - DEBUG_MSG("Not on ESP32, scheduling regular reboot in %d seconds\n", s); + LOG_DEBUG("Not on ESP32, scheduling regular reboot in %d seconds\n", s); screen->startRebootScreen(); #endif rebootAtMsec = (s < 0) ? 0 : (millis() + s * 1000); @@ -127,40 +127,40 @@ bool AdminModule::handleReceivedProtobuf(const MeshPacket &mp, AdminMessage *r) } case AdminMessage_shutdown_seconds_tag: { int32_t s = r->shutdown_seconds; - DEBUG_MSG("Shutdown in %d seconds\n", s); + LOG_DEBUG("Shutdown in %d seconds\n", s); shutdownAtMsec = (s < 0) ? 0 : (millis() + s * 1000); break; } case AdminMessage_get_device_metadata_request_tag: { - DEBUG_MSG("Client is getting device metadata\n"); + LOG_DEBUG("Client is getting device metadata\n"); handleGetDeviceMetadata(mp); break; } case AdminMessage_factory_reset_tag: { - DEBUG_MSG("Initiating factory reset\n"); + LOG_DEBUG("Initiating factory reset\n"); nodeDB.factoryReset(); reboot(DEFAULT_REBOOT_SECONDS); break; } case AdminMessage_nodedb_reset_tag: { - DEBUG_MSG("Initiating node-db reset\n"); + LOG_DEBUG("Initiating node-db reset\n"); nodeDB.resetNodes(); reboot(DEFAULT_REBOOT_SECONDS); break; } case AdminMessage_begin_edit_settings_tag: { - DEBUG_MSG("Beginning transaction for editing settings\n"); + LOG_DEBUG("Beginning transaction for editing settings\n"); hasOpenEditTransaction = true; break; } case AdminMessage_commit_edit_settings_tag: { - DEBUG_MSG("Committing transaction for edited settings\n"); + LOG_DEBUG("Committing transaction for edited settings\n"); hasOpenEditTransaction = false; saveChanges(SEGMENT_CONFIG | SEGMENT_MODULECONFIG | SEGMENT_DEVICESTATE | SEGMENT_CHANNELS); break; } #ifdef ARCH_PORTDUINO case AdminMessage_exit_simulator_tag: - DEBUG_MSG("Exiting simulator\n"); + LOG_DEBUG("Exiting simulator\n"); _exit(0); break; #endif @@ -172,10 +172,10 @@ bool AdminModule::handleReceivedProtobuf(const MeshPacket &mp, AdminMessage *r) if (handleResult == AdminMessageHandleResult::HANDLED_WITH_RESPONSE) { myReply = allocDataProtobuf(res); } else if (mp.decoded.want_response) { - DEBUG_MSG("We did not responded to a request that wanted a respond. req.variant=%d\n", r->which_payload_variant); + LOG_DEBUG("We did not responded to a request that wanted a respond. req.variant=%d\n", r->which_payload_variant); } else if (handleResult != AdminMessageHandleResult::HANDLED) { // Probably a message sent by us or sent to our local node. FIXME, we should avoid scanning these messages - DEBUG_MSG("Ignoring nonrelevant admin %d\n", r->which_payload_variant); + LOG_DEBUG("Ignoring nonrelevant admin %d\n", r->which_payload_variant); } break; } @@ -229,7 +229,7 @@ void AdminModule::handleSetConfig(const Config &c) switch (c.which_payload_variant) { case Config_device_tag: - DEBUG_MSG("Setting config: Device\n"); + LOG_DEBUG("Setting config: Device\n"); config.has_device = true; config.device = c.payload_variant.device; // If we're setting router role for the first time, install its intervals @@ -240,29 +240,29 @@ void AdminModule::handleSetConfig(const Config &c) } break; case Config_position_tag: - DEBUG_MSG("Setting config: Position\n"); + LOG_DEBUG("Setting config: Position\n"); config.has_position = true; config.position = c.payload_variant.position; // Save nodedb as well in case we got a fixed position packet saveChanges(SEGMENT_DEVICESTATE, false); break; case Config_power_tag: - DEBUG_MSG("Setting config: Power\n"); + LOG_DEBUG("Setting config: Power\n"); config.has_power = true; config.power = c.payload_variant.power; break; case Config_network_tag: - DEBUG_MSG("Setting config: WiFi\n"); + LOG_DEBUG("Setting config: WiFi\n"); config.has_network = true; config.network = c.payload_variant.network; break; case Config_display_tag: - DEBUG_MSG("Setting config: Display\n"); + LOG_DEBUG("Setting config: Display\n"); config.has_display = true; config.display = c.payload_variant.display; break; case Config_lora_tag: - DEBUG_MSG("Setting config: LoRa\n"); + LOG_DEBUG("Setting config: LoRa\n"); config.has_lora = true; config.lora = c.payload_variant.lora; if (isRegionUnset && @@ -271,7 +271,7 @@ void AdminModule::handleSetConfig(const Config &c) } break; case Config_bluetooth_tag: - DEBUG_MSG("Setting config: Bluetooth\n"); + LOG_DEBUG("Setting config: Bluetooth\n"); config.has_bluetooth = true; config.bluetooth = c.payload_variant.bluetooth; break; @@ -284,47 +284,47 @@ void AdminModule::handleSetModuleConfig(const ModuleConfig &c) { switch (c.which_payload_variant) { case ModuleConfig_mqtt_tag: - DEBUG_MSG("Setting module config: MQTT\n"); + LOG_DEBUG("Setting module config: MQTT\n"); moduleConfig.has_mqtt = true; moduleConfig.mqtt = c.payload_variant.mqtt; break; case ModuleConfig_serial_tag: - DEBUG_MSG("Setting module config: Serial\n"); + LOG_DEBUG("Setting module config: Serial\n"); moduleConfig.has_serial = true; moduleConfig.serial = c.payload_variant.serial; break; case ModuleConfig_external_notification_tag: - DEBUG_MSG("Setting module config: External Notification\n"); + LOG_DEBUG("Setting module config: External Notification\n"); moduleConfig.has_external_notification = true; moduleConfig.external_notification = c.payload_variant.external_notification; break; case ModuleConfig_store_forward_tag: - DEBUG_MSG("Setting module config: Store & Forward\n"); + LOG_DEBUG("Setting module config: Store & Forward\n"); moduleConfig.has_store_forward = true; moduleConfig.store_forward = c.payload_variant.store_forward; break; case ModuleConfig_range_test_tag: - DEBUG_MSG("Setting module config: Range Test\n"); + LOG_DEBUG("Setting module config: Range Test\n"); moduleConfig.has_range_test = true; moduleConfig.range_test = c.payload_variant.range_test; break; case ModuleConfig_telemetry_tag: - DEBUG_MSG("Setting module config: Telemetry\n"); + LOG_DEBUG("Setting module config: Telemetry\n"); moduleConfig.has_telemetry = true; moduleConfig.telemetry = c.payload_variant.telemetry; break; case ModuleConfig_canned_message_tag: - DEBUG_MSG("Setting module config: Canned Message\n"); + LOG_DEBUG("Setting module config: Canned Message\n"); moduleConfig.has_canned_message = true; moduleConfig.canned_message = c.payload_variant.canned_message; break; case ModuleConfig_audio_tag: - DEBUG_MSG("Setting module config: Audio\n"); + LOG_DEBUG("Setting module config: Audio\n"); moduleConfig.has_audio = true; moduleConfig.audio = c.payload_variant.audio; break; case ModuleConfig_remote_hardware_tag: - DEBUG_MSG("Setting module config: Remote Hardware\n"); + LOG_DEBUG("Setting module config: Remote Hardware\n"); moduleConfig.has_remote_hardware = true; moduleConfig.remote_hardware = c.payload_variant.remote_hardware; break; @@ -363,38 +363,38 @@ void AdminModule::handleGetConfig(const MeshPacket &req, const uint32_t configTy if (req.decoded.want_response) { switch (configType) { case AdminMessage_ConfigType_DEVICE_CONFIG: - DEBUG_MSG("Getting config: Device\n"); + LOG_DEBUG("Getting config: Device\n"); res.get_config_response.which_payload_variant = Config_device_tag; res.get_config_response.payload_variant.device = config.device; break; case AdminMessage_ConfigType_POSITION_CONFIG: - DEBUG_MSG("Getting config: Position\n"); + LOG_DEBUG("Getting config: Position\n"); res.get_config_response.which_payload_variant = Config_position_tag; res.get_config_response.payload_variant.position = config.position; break; case AdminMessage_ConfigType_POWER_CONFIG: - DEBUG_MSG("Getting config: Power\n"); + LOG_DEBUG("Getting config: Power\n"); res.get_config_response.which_payload_variant = Config_power_tag; res.get_config_response.payload_variant.power = config.power; break; case AdminMessage_ConfigType_NETWORK_CONFIG: - DEBUG_MSG("Getting config: Network\n"); + LOG_DEBUG("Getting config: Network\n"); res.get_config_response.which_payload_variant = Config_network_tag; res.get_config_response.payload_variant.network = config.network; writeSecret(res.get_config_response.payload_variant.network.wifi_psk, config.network.wifi_psk); break; case AdminMessage_ConfigType_DISPLAY_CONFIG: - DEBUG_MSG("Getting config: Display\n"); + LOG_DEBUG("Getting config: Display\n"); res.get_config_response.which_payload_variant = Config_display_tag; res.get_config_response.payload_variant.display = config.display; break; case AdminMessage_ConfigType_LORA_CONFIG: - DEBUG_MSG("Getting config: LoRa\n"); + LOG_DEBUG("Getting config: LoRa\n"); res.get_config_response.which_payload_variant = Config_lora_tag; res.get_config_response.payload_variant.lora = config.lora; break; case AdminMessage_ConfigType_BLUETOOTH_CONFIG: - DEBUG_MSG("Getting config: Bluetooth\n"); + LOG_DEBUG("Getting config: Bluetooth\n"); res.get_config_response.which_payload_variant = Config_bluetooth_tag; res.get_config_response.payload_variant.bluetooth = config.bluetooth; break; @@ -418,48 +418,48 @@ void AdminModule::handleGetModuleConfig(const MeshPacket &req, const uint32_t co if (req.decoded.want_response) { switch (configType) { case AdminMessage_ModuleConfigType_MQTT_CONFIG: - DEBUG_MSG("Getting module config: MQTT\n"); + LOG_DEBUG("Getting module config: MQTT\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_mqtt_tag; res.get_module_config_response.payload_variant.mqtt = moduleConfig.mqtt; break; case AdminMessage_ModuleConfigType_SERIAL_CONFIG: - DEBUG_MSG("Getting module config: Serial\n"); + LOG_DEBUG("Getting module config: Serial\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_serial_tag; res.get_module_config_response.payload_variant.serial = moduleConfig.serial; break; case AdminMessage_ModuleConfigType_EXTNOTIF_CONFIG: - DEBUG_MSG("Getting module config: External Notification\n"); + LOG_DEBUG("Getting module config: External Notification\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_external_notification_tag; res.get_module_config_response.payload_variant.external_notification = moduleConfig.external_notification; break; case AdminMessage_ModuleConfigType_STOREFORWARD_CONFIG: - DEBUG_MSG("Getting module config: Store & Forward\n"); + LOG_DEBUG("Getting module config: Store & Forward\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_store_forward_tag; res.get_module_config_response.payload_variant.store_forward = moduleConfig.store_forward; break; case AdminMessage_ModuleConfigType_RANGETEST_CONFIG: - DEBUG_MSG("Getting module config: Range Test\n"); + LOG_DEBUG("Getting module config: Range Test\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_range_test_tag; res.get_module_config_response.payload_variant.range_test = moduleConfig.range_test; break; case AdminMessage_ModuleConfigType_TELEMETRY_CONFIG: - DEBUG_MSG("Getting module config: Telemetry\n"); + LOG_DEBUG("Getting module config: Telemetry\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_telemetry_tag; res.get_module_config_response.payload_variant.telemetry = moduleConfig.telemetry; break; case AdminMessage_ModuleConfigType_CANNEDMSG_CONFIG: - DEBUG_MSG("Getting module config: Canned Message\n"); + LOG_DEBUG("Getting module config: Canned Message\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_canned_message_tag; res.get_module_config_response.payload_variant.canned_message = moduleConfig.canned_message; break; case AdminMessage_ModuleConfigType_AUDIO_CONFIG: - DEBUG_MSG("Getting module config: Audio\n"); + LOG_DEBUG("Getting module config: Audio\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_audio_tag; res.get_module_config_response.payload_variant.audio = moduleConfig.audio; break; case AdminMessage_ModuleConfigType_REMOTEHARDWARE_CONFIG: - DEBUG_MSG("Getting module config: Remote Hardware\n"); + LOG_DEBUG("Getting module config: Remote Hardware\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_remote_hardware_tag; res.get_module_config_response.payload_variant.remote_hardware = moduleConfig.remote_hardware; break; @@ -506,7 +506,7 @@ void AdminModule::handleGetChannel(const MeshPacket &req, uint32_t channelIndex) void AdminModule::reboot(int32_t seconds) { - DEBUG_MSG("Rebooting in %d seconds\n", seconds); + LOG_DEBUG("Rebooting in %d seconds\n", seconds); screen->startRebootScreen(); rebootAtMsec = (seconds < 0) ? 0 : (millis() + seconds * 1000); } @@ -514,10 +514,10 @@ void AdminModule::reboot(int32_t seconds) void AdminModule::saveChanges(int saveWhat, bool shouldReboot) { if (!hasOpenEditTransaction) { - DEBUG_MSG("Saving changes to disk\n"); + LOG_DEBUG("Saving changes to disk\n"); service.reloadConfig(saveWhat); // Calls saveToDisk among other things } else { - DEBUG_MSG("Delaying save of changes to disk until the open transaction is committed\n"); + LOG_DEBUG("Delaying save of changes to disk until the open transaction is committed\n"); } if (shouldReboot) { diff --git a/src/modules/CannedMessageModule.cpp b/src/modules/CannedMessageModule.cpp index c0563f6669..f1a9e099ff 100644 --- a/src/modules/CannedMessageModule.cpp +++ b/src/modules/CannedMessageModule.cpp @@ -49,10 +49,10 @@ CannedMessageModule::CannedMessageModule() if (moduleConfig.canned_message.enabled) { this->loadProtoForModule(); if ((this->splitConfiguredMessages() <= 0) && (cardkb_found != CARDKB_ADDR)) { - DEBUG_MSG("CannedMessageModule: No messages are configured. Module is disabled\n"); + LOG_DEBUG("CannedMessageModule: No messages are configured. Module is disabled\n"); this->runState = CANNED_MESSAGE_RUN_STATE_DISABLED; } else { - DEBUG_MSG("CannedMessageModule is enabled\n"); + LOG_DEBUG("CannedMessageModule is enabled\n"); this->inputObserver.observe(inputBroker); } } @@ -81,7 +81,7 @@ int CannedMessageModule::splitConfiguredMessages() if (this->messageStore[i] == '|') { // Message ending found, replace it with string-end character. this->messageStore[i] = '\0'; - DEBUG_MSG("CannedMessage %d is: '%s'\n", messageIndex - 1, this->messages[messageIndex - 1]); + LOG_DEBUG("CannedMessage %d is: '%s'\n", messageIndex - 1, this->messages[messageIndex - 1]); // hit our max messages, bail if (messageIndex >= CANNED_MESSAGE_MODULE_MESSAGE_MAX_COUNT) { @@ -96,7 +96,7 @@ int CannedMessageModule::splitConfiguredMessages() } if (strlen(this->messages[messageIndex - 1]) > 0) { // We have a last message. - DEBUG_MSG("CannedMessage %d is: '%s'\n", messageIndex - 1, this->messages[messageIndex - 1]); + LOG_DEBUG("CannedMessage %d is: '%s'\n", messageIndex - 1, this->messages[messageIndex - 1]); this->messagesCount = messageIndex; } else { this->messagesCount = messageIndex - 1; @@ -119,17 +119,17 @@ int CannedMessageModule::handleInputEvent(const InputEvent *event) bool validEvent = false; if (event->inputEvent == static_cast(ModuleConfig_CannedMessageConfig_InputEventChar_UP)) { - DEBUG_MSG("Canned message event UP\n"); + LOG_DEBUG("Canned message event UP\n"); this->runState = CANNED_MESSAGE_RUN_STATE_ACTION_UP; validEvent = true; } if (event->inputEvent == static_cast(ModuleConfig_CannedMessageConfig_InputEventChar_DOWN)) { - DEBUG_MSG("Canned message event DOWN\n"); + LOG_DEBUG("Canned message event DOWN\n"); this->runState = CANNED_MESSAGE_RUN_STATE_ACTION_DOWN; validEvent = true; } if (event->inputEvent == static_cast(ModuleConfig_CannedMessageConfig_InputEventChar_SELECT)) { - DEBUG_MSG("Canned message event Select\n"); + LOG_DEBUG("Canned message event Select\n"); // when inactive, call the onebutton shortpress instead. Activate Module only on up/down if ((this->runState == CANNED_MESSAGE_RUN_STATE_INACTIVE) || (this->runState == CANNED_MESSAGE_RUN_STATE_DISABLED)) { powerFSM.trigger(EVENT_PRESS); @@ -140,7 +140,7 @@ int CannedMessageModule::handleInputEvent(const InputEvent *event) } } if (event->inputEvent == static_cast(ModuleConfig_CannedMessageConfig_InputEventChar_CANCEL)) { - DEBUG_MSG("Canned message event Cancel\n"); + LOG_DEBUG("Canned message event Cancel\n"); // emulate a timeout. Same result this->lastTouchMillis = 0; validEvent = true; @@ -148,7 +148,7 @@ int CannedMessageModule::handleInputEvent(const InputEvent *event) if ((event->inputEvent == static_cast(ModuleConfig_CannedMessageConfig_InputEventChar_BACK)) || (event->inputEvent == static_cast(ModuleConfig_CannedMessageConfig_InputEventChar_LEFT)) || (event->inputEvent == static_cast(ModuleConfig_CannedMessageConfig_InputEventChar_RIGHT))) { - DEBUG_MSG("Canned message event (%x)\n",event->kbchar); + LOG_DEBUG("Canned message event (%x)\n",event->kbchar); if (this->runState == CANNED_MESSAGE_RUN_STATE_FREETEXT) { // pass the pressed key this->payload = event->kbchar; @@ -157,7 +157,7 @@ int CannedMessageModule::handleInputEvent(const InputEvent *event) } } if (event->inputEvent == static_cast(ANYKEY)) { - DEBUG_MSG("Canned message event any key pressed\n"); + LOG_DEBUG("Canned message event any key pressed\n"); // when inactive, this will switch to the freetext mode if ((this->runState == CANNED_MESSAGE_RUN_STATE_INACTIVE) || (this->runState == CANNED_MESSAGE_RUN_STATE_ACTIVE) || (this->runState == CANNED_MESSAGE_RUN_STATE_DISABLED)) { this->runState = CANNED_MESSAGE_RUN_STATE_FREETEXT; @@ -168,7 +168,7 @@ int CannedMessageModule::handleInputEvent(const InputEvent *event) validEvent = true; } if (event->inputEvent == static_cast(MATRIXKEY)) { - DEBUG_MSG("Canned message event Matrix key pressed\n"); + LOG_DEBUG("Canned message event Matrix key pressed\n"); // this will send the text immediately on matrix press this->runState = CANNED_MESSAGE_RUN_STATE_ACTION_SELECT; this->payload = MATRIXKEY; @@ -198,7 +198,7 @@ void CannedMessageModule::sendText(NodeNum dest, const char *message, bool wantR p->decoded.payload.size++; } - DEBUG_MSG("Sending message id=%d, dest=%x, msg=%.*s\n", p->id, p->to, p->decoded.payload.size, p->decoded.payload.bytes); + LOG_DEBUG("Sending message id=%d, dest=%x, msg=%.*s\n", p->id, p->to, p->decoded.payload.size, p->decoded.payload.bytes); service.sendToMesh(p); } @@ -209,7 +209,7 @@ int32_t CannedMessageModule::runOnce() (this->runState == CANNED_MESSAGE_RUN_STATE_INACTIVE)) { return INT32_MAX; } - DEBUG_MSG("Check status\n"); + LOG_DEBUG("Check status\n"); UIFrameEvent e = {false, true}; if (this->runState == CANNED_MESSAGE_RUN_STATE_SENDING_ACTIVE) { // TODO: might have some feedback of sendig state @@ -222,7 +222,7 @@ int32_t CannedMessageModule::runOnce() this->notifyObservers(&e); } else if (((this->runState == CANNED_MESSAGE_RUN_STATE_ACTIVE) || (this->runState == CANNED_MESSAGE_RUN_STATE_FREETEXT)) && ((millis() - this->lastTouchMillis) > INACTIVATE_AFTER_MS)) { // Reset module - DEBUG_MSG("Reset due to lack of activity.\n"); + LOG_DEBUG("Reset due to lack of activity.\n"); e.frameChanged = true; this->currentMessageIndex = -1; this->freetext = ""; // clear freetext @@ -236,7 +236,7 @@ int32_t CannedMessageModule::runOnce() sendText(this->dest, this->freetext.c_str(), true); this->runState = CANNED_MESSAGE_RUN_STATE_SENDING_ACTIVE; } else { - DEBUG_MSG("Reset message is empty.\n"); + LOG_DEBUG("Reset message is empty.\n"); this->runState = CANNED_MESSAGE_RUN_STATE_INACTIVE; } } else { @@ -249,7 +249,7 @@ int32_t CannedMessageModule::runOnce() } this->runState = CANNED_MESSAGE_RUN_STATE_SENDING_ACTIVE; } else { - DEBUG_MSG("Reset message is empty.\n"); + LOG_DEBUG("Reset message is empty.\n"); this->runState = CANNED_MESSAGE_RUN_STATE_INACTIVE; } } @@ -262,7 +262,7 @@ int32_t CannedMessageModule::runOnce() return 2000; } else if ((this->runState != CANNED_MESSAGE_RUN_STATE_FREETEXT) && (this->currentMessageIndex == -1)) { this->currentMessageIndex = 0; - DEBUG_MSG("First touch (%d):%s\n", this->currentMessageIndex, this->getCurrentMessage()); + LOG_DEBUG("First touch (%d):%s\n", this->currentMessageIndex, this->getCurrentMessage()); e.frameChanged = true; this->runState = CANNED_MESSAGE_RUN_STATE_ACTIVE; } else if (this->runState == CANNED_MESSAGE_RUN_STATE_ACTION_UP) { @@ -272,7 +272,7 @@ int32_t CannedMessageModule::runOnce() this->cursor = 0; this->destSelect = false; this->runState = CANNED_MESSAGE_RUN_STATE_ACTIVE; - DEBUG_MSG("MOVE UP (%d):%s\n", this->currentMessageIndex, this->getCurrentMessage()); + LOG_DEBUG("MOVE UP (%d):%s\n", this->currentMessageIndex, this->getCurrentMessage()); } } else if (this->runState == CANNED_MESSAGE_RUN_STATE_ACTION_DOWN) { if (this->messagesCount > 0) { @@ -281,7 +281,7 @@ int32_t CannedMessageModule::runOnce() this->cursor = 0; this->destSelect = false; this->runState = CANNED_MESSAGE_RUN_STATE_ACTIVE; - DEBUG_MSG("MOVE DOWN (%d):%s\n", this->currentMessageIndex, this->getCurrentMessage()); + LOG_DEBUG("MOVE DOWN (%d):%s\n", this->currentMessageIndex, this->getCurrentMessage()); } } else if (this->runState == CANNED_MESSAGE_RUN_STATE_FREETEXT) { e.frameChanged = true; @@ -524,13 +524,13 @@ AdminMessageHandleResult CannedMessageModule::handleAdminMessageForModule(const switch (request->which_payload_variant) { case AdminMessage_get_canned_message_module_messages_request_tag: - DEBUG_MSG("Client is getting radio canned messages\n"); + LOG_DEBUG("Client is getting radio canned messages\n"); this->handleGetCannedMessageModuleMessages(mp, response); result = AdminMessageHandleResult::HANDLED_WITH_RESPONSE; break; case AdminMessage_set_canned_message_module_messages_tag: - DEBUG_MSG("Client is setting radio canned messages\n"); + LOG_DEBUG("Client is setting radio canned messages\n"); this->handleSetCannedMessageModuleMessages(request->set_canned_message_module_messages); result = AdminMessageHandleResult::HANDLED; break; @@ -544,7 +544,7 @@ AdminMessageHandleResult CannedMessageModule::handleAdminMessageForModule(const void CannedMessageModule::handleGetCannedMessageModuleMessages(const MeshPacket &req, AdminMessage *response) { - DEBUG_MSG("*** handleGetCannedMessageModuleMessages\n"); + LOG_DEBUG("*** handleGetCannedMessageModuleMessages\n"); assert(req.decoded.want_response); response->which_payload_variant = AdminMessage_get_canned_message_module_messages_response_tag; @@ -559,7 +559,7 @@ void CannedMessageModule::handleSetCannedMessageModuleMessages(const char *from_ if (*from_msg) { changed |= strcmp(cannedMessageModuleConfig.messages, from_msg); strcpy(cannedMessageModuleConfig.messages, from_msg); - DEBUG_MSG("*** from_msg.text:%s\n", from_msg); + LOG_DEBUG("*** from_msg.text:%s\n", from_msg); } if (changed) { diff --git a/src/modules/ExternalNotificationModule.cpp b/src/modules/ExternalNotificationModule.cpp index c042aa966c..cabed32e3c 100644 --- a/src/modules/ExternalNotificationModule.cpp +++ b/src/modules/ExternalNotificationModule.cpp @@ -48,15 +48,15 @@ int32_t ExternalNotificationModule::runOnce() if (nagCycleCutoff < millis()) { #endif nagCycleCutoff = UINT32_MAX; - DEBUG_MSG("Turning off external notification: "); + LOG_DEBUG("Turning off external notification: "); for (int i = 0; i < 2; i++) { if (getExternal(i)) { setExternalOff(i); externalTurnedOn[i] = 0; - DEBUG_MSG("%d ", i); + LOG_DEBUG("%d ", i); } } - DEBUG_MSG("\n"); + LOG_DEBUG("\n"); return INT32_MAX; // save cycles till we're needed again } @@ -175,26 +175,26 @@ ExternalNotificationModule::ExternalNotificationModule() strncpy(rtttlConfig.ringtone, "a:d=8,o=5,b=125:4d#6,a#,2d#6,16p,g#,4a#,4d#.,p,16g,16a#,d#6,a#,f6,2d#6,16p,c#.6,16c6,16a#,g#.,2a#", sizeof(rtttlConfig.ringtone)); } - DEBUG_MSG("Initializing External Notification Module\n"); + LOG_DEBUG("Initializing External Notification Module\n"); output = moduleConfig.external_notification.output ? moduleConfig.external_notification.output : EXT_NOTIFICATION_MODULE_OUTPUT; // Set the direction of a pin - DEBUG_MSG("Using Pin %i in digital mode\n", output); + LOG_DEBUG("Using Pin %i in digital mode\n", output); pinMode(output, OUTPUT); setExternalOff(0); externalTurnedOn[0] = 0; if(moduleConfig.external_notification.output_vibra) { - DEBUG_MSG("Using Pin %i for vibra motor\n", moduleConfig.external_notification.output_vibra); + LOG_DEBUG("Using Pin %i for vibra motor\n", moduleConfig.external_notification.output_vibra); pinMode(moduleConfig.external_notification.output_vibra, OUTPUT); setExternalOff(1); externalTurnedOn[1] = 0; } if(moduleConfig.external_notification.output_buzzer) { if (!moduleConfig.external_notification.use_pwm) { - DEBUG_MSG("Using Pin %i for buzzer\n", moduleConfig.external_notification.output_buzzer); + LOG_DEBUG("Using Pin %i for buzzer\n", moduleConfig.external_notification.output_buzzer); pinMode(moduleConfig.external_notification.output_buzzer, OUTPUT); setExternalOff(2); externalTurnedOn[2] = 0; @@ -203,11 +203,11 @@ ExternalNotificationModule::ExternalNotificationModule() ? config.device.buzzer_gpio : PIN_BUZZER; // in PWM Mode we force the buzzer pin if it is set - DEBUG_MSG("Using Pin %i in PWM mode\n", config.device.buzzer_gpio); + LOG_DEBUG("Using Pin %i in PWM mode\n", config.device.buzzer_gpio); } } } else { - DEBUG_MSG("External Notification Module Disabled\n"); + LOG_DEBUG("External Notification Module Disabled\n"); enabled = false; } } @@ -229,7 +229,7 @@ ProcessMessage ExternalNotificationModule::handleReceived(const MeshPacket &mp) if (moduleConfig.external_notification.alert_bell) { if (containsBell) { - DEBUG_MSG("externalNotificationModule - Notification Bell\n"); + LOG_DEBUG("externalNotificationModule - Notification Bell\n"); setExternalOn(0); if (moduleConfig.external_notification.nag_timeout) { nagCycleCutoff = millis() + moduleConfig.external_notification.nag_timeout * 1000; @@ -241,7 +241,7 @@ ProcessMessage ExternalNotificationModule::handleReceived(const MeshPacket &mp) if (moduleConfig.external_notification.alert_bell_vibra) { if (containsBell) { - DEBUG_MSG("externalNotificationModule - Notification Bell (Vibra)\n"); + LOG_DEBUG("externalNotificationModule - Notification Bell (Vibra)\n"); setExternalOn(1); if (moduleConfig.external_notification.nag_timeout) { nagCycleCutoff = millis() + moduleConfig.external_notification.nag_timeout * 1000; @@ -253,7 +253,7 @@ ProcessMessage ExternalNotificationModule::handleReceived(const MeshPacket &mp) if (moduleConfig.external_notification.alert_bell_buzzer) { if (containsBell) { - DEBUG_MSG("externalNotificationModule - Notification Bell (Buzzer)\n"); + LOG_DEBUG("externalNotificationModule - Notification Bell (Buzzer)\n"); if (!moduleConfig.external_notification.use_pwm) { setExternalOn(2); } else { @@ -270,7 +270,7 @@ ProcessMessage ExternalNotificationModule::handleReceived(const MeshPacket &mp) } if (moduleConfig.external_notification.alert_message) { - DEBUG_MSG("externalNotificationModule - Notification Module\n"); + LOG_DEBUG("externalNotificationModule - Notification Module\n"); setExternalOn(0); if (moduleConfig.external_notification.nag_timeout) { nagCycleCutoff = millis() + moduleConfig.external_notification.nag_timeout * 1000; @@ -281,7 +281,7 @@ ProcessMessage ExternalNotificationModule::handleReceived(const MeshPacket &mp) if (!moduleConfig.external_notification.use_pwm) { if (moduleConfig.external_notification.alert_message_vibra) { - DEBUG_MSG("externalNotificationModule - Notification Module (Vibra)\n"); + LOG_DEBUG("externalNotificationModule - Notification Module (Vibra)\n"); setExternalOn(1); if (moduleConfig.external_notification.nag_timeout) { nagCycleCutoff = millis() + moduleConfig.external_notification.nag_timeout * 1000; @@ -291,7 +291,7 @@ ProcessMessage ExternalNotificationModule::handleReceived(const MeshPacket &mp) } if (moduleConfig.external_notification.alert_message_buzzer) { - DEBUG_MSG("externalNotificationModule - Notification Module (Buzzer)\n"); + LOG_DEBUG("externalNotificationModule - Notification Module (Buzzer)\n"); if (!moduleConfig.external_notification.use_pwm) { setExternalOn(2); } else { @@ -310,7 +310,7 @@ ProcessMessage ExternalNotificationModule::handleReceived(const MeshPacket &mp) } } else { - DEBUG_MSG("External Notification Module Disabled\n"); + LOG_DEBUG("External Notification Module Disabled\n"); } return ProcessMessage::CONTINUE; // Let others look at this message also if they want @@ -331,13 +331,13 @@ AdminMessageHandleResult ExternalNotificationModule::handleAdminMessageForModule switch (request->which_payload_variant) { case AdminMessage_get_ringtone_request_tag: - DEBUG_MSG("Client is getting ringtone\n"); + LOG_DEBUG("Client is getting ringtone\n"); this->handleGetRingtone(mp, response); result = AdminMessageHandleResult::HANDLED_WITH_RESPONSE; break; case AdminMessage_set_ringtone_message_tag: - DEBUG_MSG("Client is setting ringtone\n"); + LOG_DEBUG("Client is setting ringtone\n"); this->handleSetRingtone(request->set_canned_message_module_messages); result = AdminMessageHandleResult::HANDLED; break; @@ -351,7 +351,7 @@ AdminMessageHandleResult ExternalNotificationModule::handleAdminMessageForModule void ExternalNotificationModule::handleGetRingtone(const MeshPacket &req, AdminMessage *response) { - DEBUG_MSG("*** handleGetRingtone\n"); + LOG_DEBUG("*** handleGetRingtone\n"); assert(req.decoded.want_response); response->which_payload_variant = AdminMessage_get_ringtone_response_tag; @@ -366,7 +366,7 @@ void ExternalNotificationModule::handleSetRingtone(const char *from_msg) if (*from_msg) { changed |= strcmp(rtttlConfig.ringtone, from_msg); strcpy(rtttlConfig.ringtone, from_msg); - DEBUG_MSG("*** from_msg.text:%s\n", from_msg); + LOG_DEBUG("*** from_msg.text:%s\n", from_msg); } if (changed) { diff --git a/src/modules/NodeInfoModule.cpp b/src/modules/NodeInfoModule.cpp index 1ce1acf33b..b4e0547171 100644 --- a/src/modules/NodeInfoModule.cpp +++ b/src/modules/NodeInfoModule.cpp @@ -23,7 +23,7 @@ bool NodeInfoModule::handleReceivedProtobuf(const MeshPacket &mp, User *pptr) screen->print(lcd.c_str()); } - // DEBUG_MSG("did handleReceived\n"); + // LOG_DEBUG("did handleReceived\n"); return false; // Let others look at this message also if they want } @@ -46,7 +46,7 @@ MeshPacket *NodeInfoModule::allocReply() { User &u = owner; - DEBUG_MSG("sending owner %s/%s/%s\n", u.id, u.long_name, u.short_name); + LOG_DEBUG("sending owner %s/%s/%s\n", u.id, u.long_name, u.short_name); return allocDataProtobuf(u); } @@ -65,7 +65,7 @@ int32_t NodeInfoModule::runOnce() bool requestReplies = currentGeneration != radioGeneration; currentGeneration = radioGeneration; - DEBUG_MSG("Sending our nodeinfo to mesh (wantReplies=%d)\n", requestReplies); + LOG_DEBUG("Sending our nodeinfo to mesh (wantReplies=%d)\n", requestReplies); sendOurNodeInfo(NODENUM_BROADCAST, requestReplies); // Send our info (don't request replies) return default_broadcast_interval_secs * 1000; diff --git a/src/modules/PositionModule.cpp b/src/modules/PositionModule.cpp index 013f2ee440..2df3b029b4 100644 --- a/src/modules/PositionModule.cpp +++ b/src/modules/PositionModule.cpp @@ -26,13 +26,13 @@ bool PositionModule::handleReceivedProtobuf(const MeshPacket &mp, Position *pptr // FIXME this can in fact happen with packets sent from EUD (src=RX_SRC_USER) // to set fixed location, EUD-GPS location or just the time (see also issue #900) if (nodeDB.getNodeNum() == getFrom(&mp)) { - DEBUG_MSG("Incoming update from MYSELF\n"); - // DEBUG_MSG("Ignored an incoming update from MYSELF\n"); + LOG_DEBUG("Incoming update from MYSELF\n"); + // LOG_DEBUG("Ignored an incoming update from MYSELF\n"); // return false; } // Log packet size and list of fields - DEBUG_MSG("POSITION node=%08x l=%d %s%s%s%s%s%s%s%s%s%s%s%s%s\n", getFrom(&mp), mp.decoded.payload.size, + LOG_DEBUG("POSITION node=%08x l=%d %s%s%s%s%s%s%s%s%s%s%s%s%s\n", getFrom(&mp), mp.decoded.payload.size, p.latitude_i ? "LAT " : "", p.longitude_i ? "LON " : "", p.altitude ? "MSL " : "", p.altitude_hae ? "HAE " : "", p.altitude_geoidal_separation ? "GEO " : "", p.PDOP ? "PDOP " : "", p.HDOP ? "HDOP " : "", p.VDOP ? "VDOP " : "", p.sats_in_view ? "SIV " : "", p.fix_quality ? "FXQ " : "", p.fix_type ? "FXT " : "", p.timestamp ? "PTS " : "", @@ -109,12 +109,12 @@ MeshPacket *PositionModule::allocReply() // nodes shouldn't trust it anyways) Note: we allow a device with a local GPS to include the time, so that gpsless // devices can get time. if (getRTCQuality() < RTCQualityDevice) { - DEBUG_MSG("Stripping time %u from position send\n", p.time); + LOG_DEBUG("Stripping time %u from position send\n", p.time); p.time = 0; } else - DEBUG_MSG("Providing time to mesh %u\n", p.time); + LOG_DEBUG("Providing time to mesh %u\n", p.time); - DEBUG_MSG("Position reply: time=%i, latI=%i, lonI=-%i\n", p.time, p.latitude_i, p.longitude_i); + LOG_DEBUG("Position reply: time=%i, latI=%i, lonI=-%i\n", p.time, p.latitude_i, p.longitude_i); return allocDataProtobuf(p); } @@ -155,11 +155,11 @@ int32_t PositionModule::runOnce() bool requestReplies = currentGeneration != radioGeneration; currentGeneration = radioGeneration; - DEBUG_MSG("Sending pos@%x:6 to mesh (wantReplies=%d)\n", node->position.timestamp, requestReplies); + LOG_DEBUG("Sending pos@%x:6 to mesh (wantReplies=%d)\n", node->position.timestamp, requestReplies); sendOurPosition(NODENUM_BROADCAST, requestReplies); } } else { - DEBUG_MSG("Channel utilization is >40 percent. Skipping this opportunity to send.\n"); + LOG_DEBUG("Channel utilization is >40 percent. Skipping this opportunity to send.\n"); } } else if (config.position.position_broadcast_smart_enabled) { @@ -194,7 +194,7 @@ int32_t PositionModule::runOnce() bool requestReplies = currentGeneration != radioGeneration; currentGeneration = radioGeneration; - DEBUG_MSG("Sending smart pos@%x:6 to mesh (wantReplies=%d, d=%d, dtt=%d, tt=%d)\n", node2->position.timestamp, + LOG_DEBUG("Sending smart pos@%x:6 to mesh (wantReplies=%d, d=%d, dtt=%d, tt=%d)\n", node2->position.timestamp, requestReplies, distance, distanceTravelThreshold, timeTravel); sendOurPosition(NODENUM_BROADCAST, requestReplies); @@ -209,7 +209,7 @@ int32_t PositionModule::runOnce() } } } else { - DEBUG_MSG("Channel utilization is >25 percent. Skipping this opportunity to send.\n"); + LOG_DEBUG("Channel utilization is >25 percent. Skipping this opportunity to send.\n"); } } diff --git a/src/modules/RemoteHardwareModule.cpp b/src/modules/RemoteHardwareModule.cpp index 26f1c4dba1..9958fbe394 100644 --- a/src/modules/RemoteHardwareModule.cpp +++ b/src/modules/RemoteHardwareModule.cpp @@ -55,7 +55,7 @@ RemoteHardwareModule::RemoteHardwareModule() bool RemoteHardwareModule::handleReceivedProtobuf(const MeshPacket &req, HardwareMessage *pptr) { auto p = *pptr; - DEBUG_MSG("Received RemoteHardware typ=%d\n", p.type); + LOG_DEBUG("Received RemoteHardware typ=%d\n", p.type); switch (p.type) { case HardwareMessage_Type_WRITE_GPIOS: @@ -95,7 +95,7 @@ bool RemoteHardwareModule::handleReceivedProtobuf(const MeshPacket &req, Hardwar lastWatchMsec = 0; // Force a new publish soon previousWatch = ~watchGpios; // generate a 'previous' value which is guaranteed to not match (to force an initial publish) enabled = true; // Let our thread run at least once - DEBUG_MSG("Now watching GPIOs 0x%llx\n", watchGpios); + LOG_DEBUG("Now watching GPIOs 0x%llx\n", watchGpios); break; } @@ -104,7 +104,7 @@ bool RemoteHardwareModule::handleReceivedProtobuf(const MeshPacket &req, Hardwar break; // Ignore - we might see our own replies default: - DEBUG_MSG("Hardware operation %d not yet implemented! FIXME\n", p.type); + LOG_DEBUG("Hardware operation %d not yet implemented! FIXME\n", p.type); break; } @@ -121,7 +121,7 @@ int32_t RemoteHardwareModule::runOnce() if (curVal != previousWatch) { previousWatch = curVal; - DEBUG_MSG("Broadcasting GPIOS 0x%llx changed!\n", curVal); + LOG_DEBUG("Broadcasting GPIOS 0x%llx changed!\n", curVal); // Something changed! Tell the world with a broadcast message HardwareMessage r = HardwareMessage_init_default; diff --git a/src/modules/ReplyModule.cpp b/src/modules/ReplyModule.cpp index af7232895a..cd0dbec3a1 100644 --- a/src/modules/ReplyModule.cpp +++ b/src/modules/ReplyModule.cpp @@ -11,7 +11,7 @@ MeshPacket *ReplyModule::allocReply() auto req = *currentRequest; auto &p = req.decoded; // The incoming message is in p.payload - DEBUG_MSG("Received message from=0x%0x, id=%d, msg=%.*s\n", req.from, req.id, p.payload.size, p.payload.bytes); + LOG_DEBUG("Received message from=0x%0x, id=%d, msg=%.*s\n", req.from, req.id, p.payload.size, p.payload.bytes); screen->print("Sending reply\n"); diff --git a/src/modules/SerialModule.cpp b/src/modules/SerialModule.cpp index eb8f0986bd..f3708a7041 100644 --- a/src/modules/SerialModule.cpp +++ b/src/modules/SerialModule.cpp @@ -109,7 +109,7 @@ int32_t SerialModule::runOnce() if (firstTime) { // Interface with the serial peripheral from in here. - DEBUG_MSG("Initializing serial peripheral interface\n"); + LOG_DEBUG("Initializing serial peripheral interface\n"); uint32_t baud = 0; @@ -213,14 +213,14 @@ int32_t SerialModule::runOnce() serialModuleRadio->sendPayload(); - DEBUG_MSG("Received: %s\n", serialStringChar); + LOG_DEBUG("Received: %s\n", serialStringChar); } } } return (10); } else { - DEBUG_MSG("Serial Module Disabled\n"); + LOG_DEBUG("Serial Module Disabled\n"); return INT32_MAX; } @@ -256,7 +256,7 @@ ProcessMessage SerialModuleRadio::handleReceived(const MeshPacket &mp) } auto &p = mp.decoded; - // DEBUG_MSG("Received text msg self=0x%0x, from=0x%0x, to=0x%0x, id=%d, msg=%.*s\n", + // LOG_DEBUG("Received text msg self=0x%0x, from=0x%0x, to=0x%0x, id=%d, msg=%.*s\n", // nodeDB.getNodeNum(), mp.from, mp.to, mp.id, p.payload.size, p.payload.bytes); if (getFrom(&mp) == nodeDB.getNodeNum()) { @@ -271,7 +271,7 @@ ProcessMessage SerialModuleRadio::handleReceived(const MeshPacket &mp) // TODO: need to find out why. if (lastRxID != mp.id) { lastRxID = mp.id; - // DEBUG_MSG("* * Message came this device\n"); + // LOG_DEBUG("* * Message came this device\n"); // Serial2.println("* * Message came this device"); Serial2.printf("%s", p.payload.bytes); } @@ -305,7 +305,7 @@ ProcessMessage SerialModuleRadio::handleReceived(const MeshPacket &mp) } } else { - DEBUG_MSG("Serial Module Disabled\n"); + LOG_DEBUG("Serial Module Disabled\n"); } return ProcessMessage::CONTINUE; // Let others look at this message also if they want } diff --git a/src/modules/Telemetry/DeviceTelemetry.cpp b/src/modules/Telemetry/DeviceTelemetry.cpp index f3d787682b..301aa1797d 100644 --- a/src/modules/Telemetry/DeviceTelemetry.cpp +++ b/src/modules/Telemetry/DeviceTelemetry.cpp @@ -34,7 +34,7 @@ bool DeviceTelemetryModule::handleReceivedProtobuf(const MeshPacket &mp, Telemet if (t->which_variant == Telemetry_device_metrics_tag) { const char *sender = getSenderShortName(mp); - DEBUG_MSG("(Received from %s): air_util_tx=%f, channel_utilization=%f, battery_level=%i, voltage=%f\n", + LOG_DEBUG("(Received from %s): air_util_tx=%f, channel_utilization=%f, battery_level=%i, voltage=%f\n", sender, t->variant.device_metrics.air_util_tx, t->variant.device_metrics.channel_utilization, @@ -60,7 +60,7 @@ bool DeviceTelemetryModule::sendTelemetry(NodeNum dest, bool phoneOnly) t.variant.device_metrics.channel_utilization = myNodeInfo.channel_utilization; t.variant.device_metrics.voltage = powerStatus->getBatteryVoltageMv() / 1000.0; - DEBUG_MSG("(Sending): air_util_tx=%f, channel_utilization=%f, battery_level=%i, voltage=%f\n", + LOG_DEBUG("(Sending): air_util_tx=%f, channel_utilization=%f, battery_level=%i, voltage=%f\n", t.variant.device_metrics.air_util_tx, t.variant.device_metrics.channel_utilization, t.variant.device_metrics.battery_level, @@ -74,10 +74,10 @@ bool DeviceTelemetryModule::sendTelemetry(NodeNum dest, bool phoneOnly) lastMeasurementPacket = packetPool.allocCopy(*p); nodeDB.updateTelemetry(nodeDB.getNodeNum(), t, RX_SRC_LOCAL); if (phoneOnly) { - DEBUG_MSG("Sending packet to phone\n"); + LOG_DEBUG("Sending packet to phone\n"); service.sendToPhone(p); } else { - DEBUG_MSG("Sending packet to mesh\n"); + LOG_DEBUG("Sending packet to mesh\n"); service.sendToMesh(p, RX_SRC_LOCAL, true); } return true; diff --git a/src/modules/Telemetry/EnvironmentTelemetry.cpp b/src/modules/Telemetry/EnvironmentTelemetry.cpp index 11955f3f63..fa90dc7cf6 100644 --- a/src/modules/Telemetry/EnvironmentTelemetry.cpp +++ b/src/modules/Telemetry/EnvironmentTelemetry.cpp @@ -75,7 +75,7 @@ int32_t EnvironmentTelemetryModule::runOnce() firstTime = 0; if (moduleConfig.telemetry.environment_measurement_enabled) { - DEBUG_MSG("Environment Telemetry: Initializing\n"); + LOG_DEBUG("Environment Telemetry: Initializing\n"); // it's possible to have this module enabled, only for displaying values on the screen. // therefore, we should only enable the sensor loop if measurement is also enabled if (bmp280Sensor.hasSensor()) @@ -162,7 +162,7 @@ void EnvironmentTelemetryModule::drawFrame(OLEDDisplay *display, OLEDDisplayUiSt if (!pb_decode_from_bytes(p.payload.bytes, p.payload.size, &Telemetry_msg, &lastMeasurement)) { display->setFont(FONT_SMALL); display->drawString(x, y += fontHeight(FONT_MEDIUM), "Measurement Error"); - DEBUG_MSG("Unable to decode last packet"); + LOG_DEBUG("Unable to decode last packet"); return; } @@ -187,7 +187,7 @@ bool EnvironmentTelemetryModule::handleReceivedProtobuf(const MeshPacket &mp, Te if (t->which_variant == Telemetry_environment_metrics_tag) { const char *sender = getSenderShortName(mp); - DEBUG_MSG("(Received from %s): barometric_pressure=%f, current=%f, gas_resistance=%f, relative_humidity=%f, temperature=%f, voltage=%f\n", + LOG_DEBUG("(Received from %s): barometric_pressure=%f, current=%f, gas_resistance=%f, relative_humidity=%f, temperature=%f, voltage=%f\n", sender, t->variant.environment_metrics.barometric_pressure, t->variant.environment_metrics.current, @@ -234,7 +234,7 @@ bool EnvironmentTelemetryModule::sendTelemetry(NodeNum dest, bool phoneOnly) if (ina260Sensor.hasSensor()) ina260Sensor.getMetrics(&m); - DEBUG_MSG("(Sending): barometric_pressure=%f, current=%f, gas_resistance=%f, relative_humidity=%f, temperature=%f, voltage=%f\n", + LOG_DEBUG("(Sending): barometric_pressure=%f, current=%f, gas_resistance=%f, relative_humidity=%f, temperature=%f, voltage=%f\n", m.variant.environment_metrics.barometric_pressure, m.variant.environment_metrics.current, m.variant.environment_metrics.gas_resistance, @@ -251,10 +251,10 @@ bool EnvironmentTelemetryModule::sendTelemetry(NodeNum dest, bool phoneOnly) lastMeasurementPacket = packetPool.allocCopy(*p); if (phoneOnly) { - DEBUG_MSG("Sending packet to phone\n"); + LOG_DEBUG("Sending packet to phone\n"); service.sendToPhone(p); } else { - DEBUG_MSG("Sending packet to mesh\n"); + LOG_DEBUG("Sending packet to mesh\n"); service.sendToMesh(p, RX_SRC_LOCAL, true); } return true; diff --git a/src/modules/Telemetry/Sensor/BME280Sensor.cpp b/src/modules/Telemetry/Sensor/BME280Sensor.cpp index 4b6a500911..e33c1e014e 100644 --- a/src/modules/Telemetry/Sensor/BME280Sensor.cpp +++ b/src/modules/Telemetry/Sensor/BME280Sensor.cpp @@ -11,7 +11,7 @@ BME280Sensor::BME280Sensor() : } int32_t BME280Sensor::runOnce() { - DEBUG_MSG("Init sensor: %s\n", sensorName); + LOG_DEBUG("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } @@ -30,7 +30,7 @@ int32_t BME280Sensor::runOnce() { void BME280Sensor::setup() { } bool BME280Sensor::getMetrics(Telemetry *measurement) { - DEBUG_MSG("BME280Sensor::getMetrics\n"); + LOG_DEBUG("BME280Sensor::getMetrics\n"); bme280.takeForcedMeasurement(); measurement->variant.environment_metrics.temperature = bme280.readTemperature(); measurement->variant.environment_metrics.relative_humidity = bme280.readHumidity(); diff --git a/src/modules/Telemetry/Sensor/BME680Sensor.cpp b/src/modules/Telemetry/Sensor/BME680Sensor.cpp index a9171facf8..f07de0d8df 100644 --- a/src/modules/Telemetry/Sensor/BME680Sensor.cpp +++ b/src/modules/Telemetry/Sensor/BME680Sensor.cpp @@ -10,7 +10,7 @@ BME680Sensor::BME680Sensor() : } int32_t BME680Sensor::runOnce() { - DEBUG_MSG("Init sensor: %s\n", sensorName); + LOG_DEBUG("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } diff --git a/src/modules/Telemetry/Sensor/BMP280Sensor.cpp b/src/modules/Telemetry/Sensor/BMP280Sensor.cpp index 917c40d6fb..29a73e2821 100644 --- a/src/modules/Telemetry/Sensor/BMP280Sensor.cpp +++ b/src/modules/Telemetry/Sensor/BMP280Sensor.cpp @@ -11,7 +11,7 @@ BMP280Sensor::BMP280Sensor() : } int32_t BMP280Sensor::runOnce() { - DEBUG_MSG("Init sensor: %s\n", sensorName); + LOG_DEBUG("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } @@ -29,7 +29,7 @@ int32_t BMP280Sensor::runOnce() { void BMP280Sensor::setup() { } bool BMP280Sensor::getMetrics(Telemetry *measurement) { - DEBUG_MSG("BMP280Sensor::getMetrics\n"); + LOG_DEBUG("BMP280Sensor::getMetrics\n"); bmp280.takeForcedMeasurement(); measurement->variant.environment_metrics.temperature = bmp280.readTemperature(); measurement->variant.environment_metrics.barometric_pressure = bmp280.readPressure() / 100.0F; diff --git a/src/modules/Telemetry/Sensor/INA219Sensor.cpp b/src/modules/Telemetry/Sensor/INA219Sensor.cpp index 3e280c5267..9ae886f154 100644 --- a/src/modules/Telemetry/Sensor/INA219Sensor.cpp +++ b/src/modules/Telemetry/Sensor/INA219Sensor.cpp @@ -10,7 +10,7 @@ INA219Sensor::INA219Sensor() : } int32_t INA219Sensor::runOnce() { - DEBUG_MSG("Init sensor: %s\n", sensorName); + LOG_DEBUG("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } diff --git a/src/modules/Telemetry/Sensor/INA260Sensor.cpp b/src/modules/Telemetry/Sensor/INA260Sensor.cpp index 1c924ad719..e648cd824d 100644 --- a/src/modules/Telemetry/Sensor/INA260Sensor.cpp +++ b/src/modules/Telemetry/Sensor/INA260Sensor.cpp @@ -10,7 +10,7 @@ INA260Sensor::INA260Sensor() : } int32_t INA260Sensor::runOnce() { - DEBUG_MSG("Init sensor: %s\n", sensorName); + LOG_DEBUG("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } diff --git a/src/modules/Telemetry/Sensor/LPS22HBSensor.cpp b/src/modules/Telemetry/Sensor/LPS22HBSensor.cpp index 1209c1435d..295fccdfc0 100644 --- a/src/modules/Telemetry/Sensor/LPS22HBSensor.cpp +++ b/src/modules/Telemetry/Sensor/LPS22HBSensor.cpp @@ -11,7 +11,7 @@ LPS22HBSensor::LPS22HBSensor() : } int32_t LPS22HBSensor::runOnce() { - DEBUG_MSG("Init sensor: %s\n", sensorName); + LOG_DEBUG("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } diff --git a/src/modules/Telemetry/Sensor/MCP9808Sensor.cpp b/src/modules/Telemetry/Sensor/MCP9808Sensor.cpp index 57092d2850..3f0cafdfee 100644 --- a/src/modules/Telemetry/Sensor/MCP9808Sensor.cpp +++ b/src/modules/Telemetry/Sensor/MCP9808Sensor.cpp @@ -10,7 +10,7 @@ MCP9808Sensor::MCP9808Sensor() : } int32_t MCP9808Sensor::runOnce() { - DEBUG_MSG("Init sensor: %s\n", sensorName); + LOG_DEBUG("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } @@ -23,7 +23,7 @@ void MCP9808Sensor::setup() { } bool MCP9808Sensor::getMetrics(Telemetry *measurement) { - DEBUG_MSG("MCP9808Sensor::getMetrics\n"); + LOG_DEBUG("MCP9808Sensor::getMetrics\n"); measurement->variant.environment_metrics.temperature = mcp9808.readTempC(); return true; } \ No newline at end of file diff --git a/src/modules/Telemetry/Sensor/SHT31Sensor.cpp b/src/modules/Telemetry/Sensor/SHT31Sensor.cpp index 94591e6cb5..4d367823dd 100644 --- a/src/modules/Telemetry/Sensor/SHT31Sensor.cpp +++ b/src/modules/Telemetry/Sensor/SHT31Sensor.cpp @@ -10,7 +10,7 @@ SHT31Sensor::SHT31Sensor() : } int32_t SHT31Sensor::runOnce() { - DEBUG_MSG("Init sensor: %s\n", sensorName); + LOG_DEBUG("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } diff --git a/src/modules/Telemetry/Sensor/SHTC3Sensor.cpp b/src/modules/Telemetry/Sensor/SHTC3Sensor.cpp index b3a76ba91f..b19d126924 100644 --- a/src/modules/Telemetry/Sensor/SHTC3Sensor.cpp +++ b/src/modules/Telemetry/Sensor/SHTC3Sensor.cpp @@ -10,7 +10,7 @@ SHTC3Sensor::SHTC3Sensor() : } int32_t SHTC3Sensor::runOnce() { - DEBUG_MSG("Init sensor: %s\n", sensorName); + LOG_DEBUG("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } diff --git a/src/modules/Telemetry/Sensor/TelemetrySensor.h b/src/modules/Telemetry/Sensor/TelemetrySensor.h index 12bf17e566..642c82b3a6 100644 --- a/src/modules/Telemetry/Sensor/TelemetrySensor.h +++ b/src/modules/Telemetry/Sensor/TelemetrySensor.h @@ -21,10 +21,10 @@ class TelemetrySensor int32_t initI2CSensor() { if (!status) { - DEBUG_MSG("Could not connect to detected %s sensor.\n Removing from nodeTelemetrySensorsMap.\n", sensorName); + LOG_DEBUG("Could not connect to detected %s sensor.\n Removing from nodeTelemetrySensorsMap.\n", sensorName); nodeTelemetrySensorsMap[sensorType] = 0; } else { - DEBUG_MSG("Opened %s sensor on default i2c bus\n", sensorName); + LOG_DEBUG("Opened %s sensor on default i2c bus\n", sensorName); setup(); } return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; diff --git a/src/modules/TextMessageModule.cpp b/src/modules/TextMessageModule.cpp index abccc0ae85..7e7115b8d4 100644 --- a/src/modules/TextMessageModule.cpp +++ b/src/modules/TextMessageModule.cpp @@ -8,7 +8,7 @@ TextMessageModule *textMessageModule; ProcessMessage TextMessageModule::handleReceived(const MeshPacket &mp) { auto &p = mp.decoded; - DEBUG_MSG("Received text msg from=0x%0x, id=0x%x, msg=%.*s\n", mp.from, mp.id, p.payload.size, p.payload.bytes); + LOG_DEBUG("Received text msg from=0x%0x, id=0x%x, msg=%.*s\n", mp.from, mp.id, p.payload.size, p.payload.bytes); // We only store/display messages destined for us. // Keep a copy of the most recent text message. diff --git a/src/modules/TraceRouteModule.cpp b/src/modules/TraceRouteModule.cpp index fcb2346646..4558c59574 100644 --- a/src/modules/TraceRouteModule.cpp +++ b/src/modules/TraceRouteModule.cpp @@ -43,19 +43,19 @@ void TraceRouteModule::appendMyID(RouteDiscovery* updated) updated->route[updated->route_count] = myNodeInfo.my_node_num; updated->route_count += 1; } else { - DEBUG_MSG("WARNING: Route exceeded maximum hop limit, are you bridging networks?\n"); + LOG_WARN("Route exceeded maximum hop limit, are you bridging networks?\n"); } } void TraceRouteModule::printRoute(RouteDiscovery* r, uint32_t origin, uint32_t dest) { - DEBUG_MSG("Route traced:\n"); - DEBUG_MSG("0x%x --> ", origin); + LOG_DEBUG("Route traced:\n"); + LOG_DEBUG("0x%x --> ", origin); for (uint8_t i=0; iroute_count; i++) { - DEBUG_MSG("0x%x --> ", r->route[i]); + LOG_DEBUG("0x%x --> ", r->route[i]); } - if (dest != NODENUM_BROADCAST) DEBUG_MSG("0x%x\n", dest); else DEBUG_MSG("...\n"); + if (dest != NODENUM_BROADCAST) LOG_DEBUG("0x%x\n", dest); else LOG_DEBUG("...\n"); } diff --git a/src/modules/WaypointModule.cpp b/src/modules/WaypointModule.cpp index fbc519d584..9ab9a5879e 100644 --- a/src/modules/WaypointModule.cpp +++ b/src/modules/WaypointModule.cpp @@ -8,7 +8,7 @@ WaypointModule *waypointModule; ProcessMessage WaypointModule::handleReceived(const MeshPacket &mp) { auto &p = mp.decoded; - DEBUG_MSG("Received waypoint msg from=0x%0x, id=0x%x, msg=%.*s\n", mp.from, mp.id, p.payload.size, p.payload.bytes); + LOG_DEBUG("Received waypoint msg from=0x%0x, id=0x%x, msg=%.*s\n", mp.from, mp.id, p.payload.size, p.payload.bytes); notifyObservers(&mp); diff --git a/src/modules/esp32/AudioModule.cpp b/src/modules/esp32/AudioModule.cpp index e7132fcc4e..8a9dbcf7f5 100644 --- a/src/modules/esp32/AudioModule.cpp +++ b/src/modules/esp32/AudioModule.cpp @@ -71,7 +71,7 @@ void run_codec2(void* parameter) // 4 bytes of header in each frame hex c0 de c2 plus the bitrate memcpy(audioModule->tx_encode_frame,&audioModule->tx_header,sizeof(audioModule->tx_header)); - DEBUG_MSG("Starting codec2 task\n"); + LOG_DEBUG("Starting codec2 task\n"); while (true) { uint32_t tcount = ulTaskNotifyTake(pdFALSE, pdMS_TO_TICKS(10000)); @@ -86,7 +86,7 @@ void run_codec2(void* parameter) if (audioModule->tx_encode_frame_index == (audioModule->encode_frame_size + sizeof(audioModule->tx_header))) { - DEBUG_MSG("Sending %d codec2 bytes\n", audioModule->encode_frame_size); + LOG_DEBUG("Sending %d codec2 bytes\n", audioModule->encode_frame_size); audioModule->sendPayload(); audioModule->tx_encode_frame_index = sizeof(audioModule->tx_header); } @@ -127,7 +127,7 @@ AudioModule::AudioModule() : SinglePortModule("AudioModule", PortNum_AUDIO_APP), // moduleConfig.audio.ptt_pin = 39; if ((moduleConfig.audio.codec2_enabled) && (myRegion->audioPermitted)) { - DEBUG_MSG("Setting up codec2 in mode %u", (moduleConfig.audio.bitrate ? moduleConfig.audio.bitrate : AUDIO_MODULE_MODE) - 1); + LOG_DEBUG("Setting up codec2 in mode %u", (moduleConfig.audio.bitrate ? moduleConfig.audio.bitrate : AUDIO_MODULE_MODE) - 1); codec2 = codec2_create((moduleConfig.audio.bitrate ? moduleConfig.audio.bitrate : AUDIO_MODULE_MODE) - 1); memcpy(tx_header.magic,c2_magic,sizeof(c2_magic)); tx_header.mode = (moduleConfig.audio.bitrate ? moduleConfig.audio.bitrate : AUDIO_MODULE_MODE) - 1; @@ -136,10 +136,10 @@ AudioModule::AudioModule() : SinglePortModule("AudioModule", PortNum_AUDIO_APP), encode_frame_num = (Constants_DATA_PAYLOAD_LEN - sizeof(tx_header)) / encode_codec_size; encode_frame_size = encode_frame_num * encode_codec_size; // max 233 bytes + 4 header bytes adc_buffer_size = codec2_samples_per_frame(codec2); - DEBUG_MSG(" using %d frames of %d bytes for a total payload length of %d bytes\n", encode_frame_num, encode_codec_size, encode_frame_size); + LOG_DEBUG(" using %d frames of %d bytes for a total payload length of %d bytes\n", encode_frame_num, encode_codec_size, encode_frame_size); xTaskCreate(&run_codec2, "codec2_task", 30000, NULL, 5, &codec2HandlerTask); } else { - DEBUG_MSG("Codec2 disabled (AudioModule %d, Region %s, permitted %d)\n", moduleConfig.audio.codec2_enabled, myRegion->name, myRegion->audioPermitted); + LOG_DEBUG("Codec2 disabled (AudioModule %d, Region %s, permitted %d)\n", moduleConfig.audio.codec2_enabled, myRegion->name, myRegion->audioPermitted); } } @@ -173,7 +173,7 @@ int32_t AudioModule::runOnce() esp_err_t res; if (firstTime) { // Set up I2S Processor configuration. This will produce 16bit samples at 8 kHz instead of 12 from the ADC - DEBUG_MSG("Initializing I2S SD: %d DIN: %d WS: %d SCK: %d\n", moduleConfig.audio.i2s_sd, moduleConfig.audio.i2s_din, moduleConfig.audio.i2s_ws, moduleConfig.audio.i2s_sck); + LOG_DEBUG("Initializing I2S SD: %d DIN: %d WS: %d SCK: %d\n", moduleConfig.audio.i2s_sd, moduleConfig.audio.i2s_din, moduleConfig.audio.i2s_ws, moduleConfig.audio.i2s_sck); i2s_config_t i2s_config = { .mode = (i2s_mode_t)(I2S_MODE_MASTER | (moduleConfig.audio.i2s_sd ? I2S_MODE_RX : 0) | (moduleConfig.audio.i2s_din ? I2S_MODE_TX : 0)), .sample_rate = 8000, @@ -189,7 +189,7 @@ int32_t AudioModule::runOnce() }; res = i2s_driver_install(I2S_PORT, &i2s_config, 0, NULL); if(res != ESP_OK) - DEBUG_MSG("Failed to install I2S driver: %d\n", res); + LOG_DEBUG("Failed to install I2S driver: %d\n", res); const i2s_pin_config_t pin_config = { .bck_io_num = moduleConfig.audio.i2s_sck, @@ -199,16 +199,16 @@ int32_t AudioModule::runOnce() }; res = i2s_set_pin(I2S_PORT, &pin_config); if(res != ESP_OK) - DEBUG_MSG("Failed to set I2S pin config: %d\n", res); + LOG_DEBUG("Failed to set I2S pin config: %d\n", res); res = i2s_start(I2S_PORT); if(res != ESP_OK) - DEBUG_MSG("Failed to start I2S: %d\n", res); + LOG_DEBUG("Failed to start I2S: %d\n", res); radio_state = RadioState::rx; // Configure PTT input - DEBUG_MSG("Initializing PTT on Pin %u\n", moduleConfig.audio.ptt_pin ? moduleConfig.audio.ptt_pin : PTT_PIN); + LOG_DEBUG("Initializing PTT on Pin %u\n", moduleConfig.audio.ptt_pin ? moduleConfig.audio.ptt_pin : PTT_PIN); pinMode(moduleConfig.audio.ptt_pin ? moduleConfig.audio.ptt_pin : PTT_PIN, INPUT); firstTime = false; @@ -217,17 +217,17 @@ int32_t AudioModule::runOnce() // Check if PTT is pressed. TODO hook that into Onebutton/Interrupt drive. if (digitalRead(moduleConfig.audio.ptt_pin ? moduleConfig.audio.ptt_pin : PTT_PIN) == HIGH) { if (radio_state == RadioState::rx) { - DEBUG_MSG("PTT pressed, switching to TX\n"); + LOG_DEBUG("PTT pressed, switching to TX\n"); radio_state = RadioState::tx; e.frameChanged = true; this->notifyObservers(&e); } } else { if (radio_state == RadioState::tx) { - DEBUG_MSG("PTT released, switching to RX\n"); + LOG_DEBUG("PTT released, switching to RX\n"); if (tx_encode_frame_index > sizeof(tx_header)) { // Send the incomplete frame - DEBUG_MSG("Sending %d codec2 bytes (incomplete)\n", tx_encode_frame_index); + LOG_DEBUG("Sending %d codec2 bytes (incomplete)\n", tx_encode_frame_index); sendPayload(); } tx_encode_frame_index = sizeof(tx_header); @@ -258,7 +258,7 @@ int32_t AudioModule::runOnce() } return 100; } else { - DEBUG_MSG("Audio Module Disabled\n"); + LOG_DEBUG("Audio Module Disabled\n"); return INT32_MAX; } diff --git a/src/modules/esp32/RangeTestModule.cpp b/src/modules/esp32/RangeTestModule.cpp index d706f8ed3e..e8e9f62dd3 100644 --- a/src/modules/esp32/RangeTestModule.cpp +++ b/src/modules/esp32/RangeTestModule.cpp @@ -53,10 +53,10 @@ int32_t RangeTestModule::runOnce() firstTime = 0; if (moduleConfig.range_test.sender) { - DEBUG_MSG("Initializing Range Test Module -- Sender\n"); + LOG_DEBUG("Initializing Range Test Module -- Sender\n"); return (5000); // Sending first message 5 seconds after initilization. } else { - DEBUG_MSG("Initializing Range Test Module -- Receiver\n"); + LOG_DEBUG("Initializing Range Test Module -- Receiver\n"); return (INT32_MAX); // This thread does not need to run as a receiver } @@ -65,19 +65,19 @@ int32_t RangeTestModule::runOnce() if (moduleConfig.range_test.sender) { // If sender - DEBUG_MSG("Range Test Module - Sending heartbeat every %d ms\n", (senderHeartbeat)); + LOG_DEBUG("Range Test Module - Sending heartbeat every %d ms\n", (senderHeartbeat)); - DEBUG_MSG("gpsStatus->getLatitude() %d\n", gpsStatus->getLatitude()); - DEBUG_MSG("gpsStatus->getLongitude() %d\n", gpsStatus->getLongitude()); - DEBUG_MSG("gpsStatus->getHasLock() %d\n", gpsStatus->getHasLock()); - DEBUG_MSG("gpsStatus->getDOP() %d\n", gpsStatus->getDOP()); - DEBUG_MSG("fixed_position() %d\n", config.position.fixed_position); + LOG_DEBUG("gpsStatus->getLatitude() %d\n", gpsStatus->getLatitude()); + LOG_DEBUG("gpsStatus->getLongitude() %d\n", gpsStatus->getLongitude()); + LOG_DEBUG("gpsStatus->getHasLock() %d\n", gpsStatus->getHasLock()); + LOG_DEBUG("gpsStatus->getDOP() %d\n", gpsStatus->getDOP()); + LOG_DEBUG("fixed_position() %d\n", config.position.fixed_position); // Only send packets if the channel is less than 25% utilized. if (airTime->channelUtilizationPercent() < 25) { rangeTestModuleRadio->sendPayload(); } else { - DEBUG_MSG("rangeTest - Channel utilization is >25 percent. Skipping this opportunity to send.\n"); + LOG_DEBUG("rangeTest - Channel utilization is >25 percent. Skipping this opportunity to send.\n"); } return (senderHeartbeat); @@ -90,7 +90,7 @@ int32_t RangeTestModule::runOnce() } } else { - DEBUG_MSG("Range Test Module - Disabled\n"); + LOG_DEBUG("Range Test Module - Disabled\n"); } #endif @@ -135,7 +135,7 @@ ProcessMessage RangeTestModuleRadio::handleReceived(const MeshPacket &mp) /* auto &p = mp.decoded; - DEBUG_MSG("Received text msg self=0x%0x, from=0x%0x, to=0x%0x, id=%d, msg=%.*s\n", + LOG_DEBUG("Received text msg self=0x%0x, from=0x%0x, to=0x%0x, id=%d, msg=%.*s\n", nodeDB.getNodeNum(), mp.from, mp.to, mp.id, p.payload.size, p.payload.bytes); */ @@ -148,33 +148,33 @@ ProcessMessage RangeTestModuleRadio::handleReceived(const MeshPacket &mp) /* NodeInfo *n = nodeDB.getNode(getFrom(&mp)); - DEBUG_MSG("-----------------------------------------\n"); - DEBUG_MSG("p.payload.bytes \"%s\"\n", p.payload.bytes); - DEBUG_MSG("p.payload.size %d\n", p.payload.size); - DEBUG_MSG("---- Received Packet:\n"); - DEBUG_MSG("mp.from %d\n", mp.from); - DEBUG_MSG("mp.rx_snr %f\n", mp.rx_snr); - DEBUG_MSG("mp.hop_limit %d\n", mp.hop_limit); - // DEBUG_MSG("mp.decoded.position.latitude_i %d\n", mp.decoded.position.latitude_i); // Depricated - // DEBUG_MSG("mp.decoded.position.longitude_i %d\n", mp.decoded.position.longitude_i); // Depricated - DEBUG_MSG("---- Node Information of Received Packet (mp.from):\n"); - DEBUG_MSG("n->user.long_name %s\n", n->user.long_name); - DEBUG_MSG("n->user.short_name %s\n", n->user.short_name); - DEBUG_MSG("n->user.macaddr %X\n", n->user.macaddr); - DEBUG_MSG("n->has_position %d\n", n->has_position); - DEBUG_MSG("n->position.latitude_i %d\n", n->position.latitude_i); - DEBUG_MSG("n->position.longitude_i %d\n", n->position.longitude_i); - DEBUG_MSG("---- Current device location information:\n"); - DEBUG_MSG("gpsStatus->getLatitude() %d\n", gpsStatus->getLatitude()); - DEBUG_MSG("gpsStatus->getLongitude() %d\n", gpsStatus->getLongitude()); - DEBUG_MSG("gpsStatus->getHasLock() %d\n", gpsStatus->getHasLock()); - DEBUG_MSG("gpsStatus->getDOP() %d\n", gpsStatus->getDOP()); - DEBUG_MSG("-----------------------------------------\n"); + LOG_DEBUG("-----------------------------------------\n"); + LOG_DEBUG("p.payload.bytes \"%s\"\n", p.payload.bytes); + LOG_DEBUG("p.payload.size %d\n", p.payload.size); + LOG_DEBUG("---- Received Packet:\n"); + LOG_DEBUG("mp.from %d\n", mp.from); + LOG_DEBUG("mp.rx_snr %f\n", mp.rx_snr); + LOG_DEBUG("mp.hop_limit %d\n", mp.hop_limit); + // LOG_DEBUG("mp.decoded.position.latitude_i %d\n", mp.decoded.position.latitude_i); // Depricated + // LOG_DEBUG("mp.decoded.position.longitude_i %d\n", mp.decoded.position.longitude_i); // Depricated + LOG_DEBUG("---- Node Information of Received Packet (mp.from):\n"); + LOG_DEBUG("n->user.long_name %s\n", n->user.long_name); + LOG_DEBUG("n->user.short_name %s\n", n->user.short_name); + LOG_DEBUG("n->user.macaddr %X\n", n->user.macaddr); + LOG_DEBUG("n->has_position %d\n", n->has_position); + LOG_DEBUG("n->position.latitude_i %d\n", n->position.latitude_i); + LOG_DEBUG("n->position.longitude_i %d\n", n->position.longitude_i); + LOG_DEBUG("---- Current device location information:\n"); + LOG_DEBUG("gpsStatus->getLatitude() %d\n", gpsStatus->getLatitude()); + LOG_DEBUG("gpsStatus->getLongitude() %d\n", gpsStatus->getLongitude()); + LOG_DEBUG("gpsStatus->getHasLock() %d\n", gpsStatus->getHasLock()); + LOG_DEBUG("gpsStatus->getDOP() %d\n", gpsStatus->getDOP()); + LOG_DEBUG("-----------------------------------------\n"); */ } } else { - DEBUG_MSG("Range Test Module Disabled\n"); + LOG_DEBUG("Range Test Module Disabled\n"); } #endif @@ -188,36 +188,36 @@ bool RangeTestModuleRadio::appendFile(const MeshPacket &mp) NodeInfo *n = nodeDB.getNode(getFrom(&mp)); /* - DEBUG_MSG("-----------------------------------------\n"); - DEBUG_MSG("p.payload.bytes \"%s\"\n", p.payload.bytes); - DEBUG_MSG("p.payload.size %d\n", p.payload.size); - DEBUG_MSG("---- Received Packet:\n"); - DEBUG_MSG("mp.from %d\n", mp.from); - DEBUG_MSG("mp.rx_snr %f\n", mp.rx_snr); - DEBUG_MSG("mp.hop_limit %d\n", mp.hop_limit); - // DEBUG_MSG("mp.decoded.position.latitude_i %d\n", mp.decoded.position.latitude_i); // Depricated - // DEBUG_MSG("mp.decoded.position.longitude_i %d\n", mp.decoded.position.longitude_i); // Depricated - DEBUG_MSG("---- Node Information of Received Packet (mp.from):\n"); - DEBUG_MSG("n->user.long_name %s\n", n->user.long_name); - DEBUG_MSG("n->user.short_name %s\n", n->user.short_name); - DEBUG_MSG("n->user.macaddr %X\n", n->user.macaddr); - DEBUG_MSG("n->has_position %d\n", n->has_position); - DEBUG_MSG("n->position.latitude_i %d\n", n->position.latitude_i); - DEBUG_MSG("n->position.longitude_i %d\n", n->position.longitude_i); - DEBUG_MSG("---- Current device location information:\n"); - DEBUG_MSG("gpsStatus->getLatitude() %d\n", gpsStatus->getLatitude()); - DEBUG_MSG("gpsStatus->getLongitude() %d\n", gpsStatus->getLongitude()); - DEBUG_MSG("gpsStatus->getHasLock() %d\n", gpsStatus->getHasLock()); - DEBUG_MSG("gpsStatus->getDOP() %d\n", gpsStatus->getDOP()); - DEBUG_MSG("-----------------------------------------\n"); + LOG_DEBUG("-----------------------------------------\n"); + LOG_DEBUG("p.payload.bytes \"%s\"\n", p.payload.bytes); + LOG_DEBUG("p.payload.size %d\n", p.payload.size); + LOG_DEBUG("---- Received Packet:\n"); + LOG_DEBUG("mp.from %d\n", mp.from); + LOG_DEBUG("mp.rx_snr %f\n", mp.rx_snr); + LOG_DEBUG("mp.hop_limit %d\n", mp.hop_limit); + // LOG_DEBUG("mp.decoded.position.latitude_i %d\n", mp.decoded.position.latitude_i); // Depricated + // LOG_DEBUG("mp.decoded.position.longitude_i %d\n", mp.decoded.position.longitude_i); // Depricated + LOG_DEBUG("---- Node Information of Received Packet (mp.from):\n"); + LOG_DEBUG("n->user.long_name %s\n", n->user.long_name); + LOG_DEBUG("n->user.short_name %s\n", n->user.short_name); + LOG_DEBUG("n->user.macaddr %X\n", n->user.macaddr); + LOG_DEBUG("n->has_position %d\n", n->has_position); + LOG_DEBUG("n->position.latitude_i %d\n", n->position.latitude_i); + LOG_DEBUG("n->position.longitude_i %d\n", n->position.longitude_i); + LOG_DEBUG("---- Current device location information:\n"); + LOG_DEBUG("gpsStatus->getLatitude() %d\n", gpsStatus->getLatitude()); + LOG_DEBUG("gpsStatus->getLongitude() %d\n", gpsStatus->getLongitude()); + LOG_DEBUG("gpsStatus->getHasLock() %d\n", gpsStatus->getHasLock()); + LOG_DEBUG("gpsStatus->getDOP() %d\n", gpsStatus->getDOP()); + LOG_DEBUG("-----------------------------------------\n"); */ if (!FSBegin()) { - DEBUG_MSG("An Error has occurred while mounting the filesystem\n"); + LOG_DEBUG("An Error has occurred while mounting the filesystem\n"); return 0; } if (FSCom.totalBytes() - FSCom.usedBytes() < 51200) { - DEBUG_MSG("Filesystem doesn't have enough free space. Aborting write.\n"); + LOG_DEBUG("Filesystem doesn't have enough free space. Aborting write.\n"); return 0; } @@ -229,16 +229,16 @@ bool RangeTestModuleRadio::appendFile(const MeshPacket &mp) File fileToWrite = FSCom.open("/static/rangetest.csv", FILE_WRITE); if (!fileToWrite) { - DEBUG_MSG("There was an error opening the file for writing\n"); + LOG_DEBUG("There was an error opening the file for writing\n"); return 0; } // Print the CSV header if (fileToWrite.println( "time,from,sender name,sender lat,sender long,rx lat,rx long,rx elevation,rx snr,distance,hop limit,payload")) { - DEBUG_MSG("File was written\n"); + LOG_DEBUG("File was written\n"); } else { - DEBUG_MSG("File write failed\n"); + LOG_DEBUG("File write failed\n"); } fileToWrite.close(); @@ -248,7 +248,7 @@ bool RangeTestModuleRadio::appendFile(const MeshPacket &mp) File fileToAppend = FSCom.open("/static/rangetest.csv", FILE_APPEND); if (!fileToAppend) { - DEBUG_MSG("There was an error opening the file for appending\n"); + LOG_DEBUG("There was an error opening the file for appending\n"); return 0; } diff --git a/src/modules/esp32/StoreForwardModule.cpp b/src/modules/esp32/StoreForwardModule.cpp index 54a250d2a5..524aa06709 100644 --- a/src/modules/esp32/StoreForwardModule.cpp +++ b/src/modules/esp32/StoreForwardModule.cpp @@ -28,20 +28,20 @@ int32_t StoreForwardModule::runOnce() StoreAndForward sf = StoreAndForward_init_zero; sf.rr = StoreAndForward_RequestResponse_ROUTER_PING; storeForwardModule->sendMessage(this->busyTo, sf); - DEBUG_MSG("*** S&F - Done. (ROUTER_PING)\n"); + LOG_DEBUG("*** S&F - Done. (ROUTER_PING)\n"); this->packetHistoryTXQueue_index = 0; this->busy = false; } else { this->packetHistoryTXQueue_index++; } } else { - DEBUG_MSG("*** Channel utilization is too high. Retrying later.\n"); + LOG_DEBUG("*** Channel utilization is too high. Retrying later.\n"); } - DEBUG_MSG("*** SF bitrate = %f bytes / sec\n", myNodeInfo.bitrate); + LOG_DEBUG("*** SF bitrate = %f bytes / sec\n", myNodeInfo.bitrate); } else if ((millis() - lastHeartbeat > (heartbeatInterval * 1000)) && (airTime->channelUtilizationPercent() < polite_channel_util_percent)) { lastHeartbeat = millis(); - DEBUG_MSG("*** Sending heartbeat\n"); + LOG_DEBUG("*** Sending heartbeat\n"); StoreAndForward sf = StoreAndForward_init_zero; sf.rr = StoreAndForward_RequestResponse_ROUTER_HEARTBEAT; sf.which_variant = StoreAndForward_heartbeat_tag; @@ -65,7 +65,7 @@ void StoreForwardModule::populatePSRAM() https://learn.upesy.com/en/programmation/psram.html#psram-tab */ - DEBUG_MSG("*** Before PSRAM initilization: heap %d/%d PSRAM %d/%d\n", ESP.getFreeHeap(), ESP.getHeapSize(), ESP.getFreePsram(), ESP.getPsramSize()); + LOG_DEBUG("*** Before PSRAM initilization: heap %d/%d PSRAM %d/%d\n", ESP.getFreeHeap(), ESP.getHeapSize(), ESP.getFreePsram(), ESP.getPsramSize()); this->packetHistoryTXQueue = static_cast(ps_calloc(this->historyReturnMax, sizeof(PacketHistoryStruct))); @@ -78,8 +78,8 @@ void StoreForwardModule::populatePSRAM() this->packetHistory = static_cast(ps_calloc(numberOfPackets, sizeof(PacketHistoryStruct))); - DEBUG_MSG("*** After PSRAM initilization: heap %d/%d PSRAM %d/%d\n", ESP.getFreeHeap(), ESP.getHeapSize(), ESP.getFreePsram(), ESP.getPsramSize()); - DEBUG_MSG("*** numberOfPackets for packetHistory - %u\n", numberOfPackets); + LOG_DEBUG("*** After PSRAM initilization: heap %d/%d PSRAM %d/%d\n", ESP.getFreeHeap(), ESP.getHeapSize(), ESP.getFreePsram(), ESP.getPsramSize()); + LOG_DEBUG("*** numberOfPackets for packetHistory - %u\n", numberOfPackets); } void StoreForwardModule::historySend(uint32_t msAgo, uint32_t to) @@ -87,11 +87,11 @@ void StoreForwardModule::historySend(uint32_t msAgo, uint32_t to) uint32_t queueSize = storeForwardModule->historyQueueCreate(msAgo, to); if (queueSize) { - DEBUG_MSG ("*** S&F - Sending %u message(s)\n", queueSize); + LOG_DEBUG ("*** S&F - Sending %u message(s)\n", queueSize); this->busy = true; // runOnce() will pickup the next steps once busy = true. this->busyTo = to; } else { - DEBUG_MSG ("*** S&F - No history to send\n"); + LOG_DEBUG ("*** S&F - No history to send\n"); } StoreAndForward sf = StoreAndForward_init_zero; sf.rr = StoreAndForward_RequestResponse_ROUTER_HISTORY; @@ -108,13 +108,13 @@ uint32_t StoreForwardModule::historyQueueCreate(uint32_t msAgo, uint32_t to) for (int i = 0; i < this->packetHistoryCurrent; i++) { /* - DEBUG_MSG("SF historyQueueCreate\n"); - DEBUG_MSG("SF historyQueueCreate - time %d\n", this->packetHistory[i].time); - DEBUG_MSG("SF historyQueueCreate - millis %d\n", millis()); - DEBUG_MSG("SF historyQueueCreate - math %d\n", (millis() - msAgo)); + LOG_DEBUG("SF historyQueueCreate\n"); + LOG_DEBUG("SF historyQueueCreate - time %d\n", this->packetHistory[i].time); + LOG_DEBUG("SF historyQueueCreate - millis %d\n", millis()); + LOG_DEBUG("SF historyQueueCreate - math %d\n", (millis() - msAgo)); */ if (this->packetHistory[i].time && (this->packetHistory[i].time < (millis() - msAgo))) { - DEBUG_MSG("*** SF historyQueueCreate - Time matches - ok\n"); + LOG_DEBUG("*** SF historyQueueCreate - Time matches - ok\n"); /* Copy the messages that were received by the router in the last msAgo to the packetHistoryTXQueue structure. @@ -133,8 +133,8 @@ uint32_t StoreForwardModule::historyQueueCreate(uint32_t msAgo, uint32_t to) Constants_DATA_PAYLOAD_LEN); this->packetHistoryTXQueue_size++; - DEBUG_MSG("*** PacketHistoryStruct time=%d\n", this->packetHistory[i].time); - DEBUG_MSG("*** PacketHistoryStruct msg=%s\n", this->packetHistory[i].payload); + LOG_DEBUG("*** PacketHistoryStruct time=%d\n", this->packetHistory[i].time); + LOG_DEBUG("*** PacketHistoryStruct msg=%s\n", this->packetHistory[i].payload); } } } @@ -164,7 +164,7 @@ MeshPacket *StoreForwardModule::allocReply() void StoreForwardModule::sendPayload(NodeNum dest, uint32_t packetHistory_index) { - DEBUG_MSG("*** Sending S&F Payload\n"); + LOG_DEBUG("*** Sending S&F Payload\n"); MeshPacket *p = allocReply(); p->to = dest; @@ -227,7 +227,7 @@ void StoreForwardModule::statsSend(uint32_t to) sf.variant.stats.return_max = this->historyReturnMax; sf.variant.stats.return_window = this->historyReturnWindow; - DEBUG_MSG("*** Sending S&F Stats\n"); + LOG_DEBUG("*** Sending S&F Stats\n"); storeForwardModule->sendMessage(to, sf); } @@ -241,7 +241,7 @@ ProcessMessage StoreForwardModule::handleReceived(const MeshPacket &mp) if (mp.decoded.portnum == PortNum_TEXT_MESSAGE_APP) { storeForwardModule->historyAdd(mp); - DEBUG_MSG("*** S&F stored. Message history contains %u records now.\n", this->packetHistoryCurrent); + LOG_DEBUG("*** S&F stored. Message history contains %u records now.\n", this->packetHistoryCurrent); } else if (mp.decoded.portnum == PortNum_STORE_FORWARD_APP) { auto &p = mp.decoded; @@ -251,7 +251,7 @@ ProcessMessage StoreForwardModule::handleReceived(const MeshPacket &mp) if (pb_decode_from_bytes(p.payload.bytes, p.payload.size, &StoreAndForward_msg, &scratch)) { decoded = &scratch; } else { - DEBUG_MSG("Error decoding protobuf module!\n"); + LOG_DEBUG("Error decoding protobuf module!\n"); // if we can't decode it, nobody can process it! return ProcessMessage::STOP; } @@ -281,7 +281,7 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo if(is_server) { // stop sending stuff, the client wants to abort or has another error if ((this->busy) && (this->busyTo == getFrom(&mp))) { - DEBUG_MSG("*** Client in ERROR or ABORT requested\n"); + LOG_DEBUG("*** Client in ERROR or ABORT requested\n"); this->packetHistoryTXQueue_index = 0; this->busy = false; } @@ -291,11 +291,11 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo case StoreAndForward_RequestResponse_CLIENT_HISTORY: if(is_server) { requests_history++; - DEBUG_MSG("*** Client Request to send HISTORY\n"); + LOG_DEBUG("*** Client Request to send HISTORY\n"); // Send the last 60 minutes of messages. if (this->busy) { storeForwardModule->sendMessage(getFrom(&mp), StoreAndForward_RequestResponse_ROUTER_BUSY); - DEBUG_MSG("*** S&F - Busy. Try again shortly.\n"); + LOG_DEBUG("*** S&F - Busy. Try again shortly.\n"); } else { if ((p->which_variant == StoreAndForward_history_tag) && (p->variant.history.window > 0)){ storeForwardModule->historySend(p->variant.history.window * 60000, getFrom(&mp)); // window is in minutes @@ -308,7 +308,7 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo case StoreAndForward_RequestResponse_CLIENT_PING: if(is_server) { - DEBUG_MSG("*** StoreAndForward_RequestResponse_CLIENT_PING\n"); + LOG_DEBUG("*** StoreAndForward_RequestResponse_CLIENT_PING\n"); // respond with a ROUTER PONG storeForwardModule->sendMessage(getFrom(&mp), StoreAndForward_RequestResponse_ROUTER_PONG); } @@ -316,7 +316,7 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo case StoreAndForward_RequestResponse_CLIENT_PONG: if(is_server) { - DEBUG_MSG("*** StoreAndForward_RequestResponse_CLIENT_PONG\n"); + LOG_DEBUG("*** StoreAndForward_RequestResponse_CLIENT_PONG\n"); // The Client is alive, update NodeDB nodeDB.updateFrom(mp); } @@ -324,10 +324,10 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo case StoreAndForward_RequestResponse_CLIENT_STATS: if(is_server) { - DEBUG_MSG("*** Client Request to send STATS\n"); + LOG_DEBUG("*** Client Request to send STATS\n"); if (this->busy) { storeForwardModule->sendMessage(getFrom(&mp), StoreAndForward_RequestResponse_ROUTER_BUSY); - DEBUG_MSG("*** S&F - Busy. Try again shortly.\n"); + LOG_DEBUG("*** S&F - Busy. Try again shortly.\n"); } else { storeForwardModule->statsSend(getFrom(&mp)); } @@ -337,7 +337,7 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo case StoreAndForward_RequestResponse_ROUTER_ERROR: case StoreAndForward_RequestResponse_ROUTER_BUSY: if(is_client) { - DEBUG_MSG("*** StoreAndForward_RequestResponse_ROUTER_BUSY\n"); + LOG_DEBUG("*** StoreAndForward_RequestResponse_ROUTER_BUSY\n"); // retry in messages_saved * packetTimeMax ms retry_delay = millis() + packetHistoryCurrent * packetTimeMax * (StoreAndForward_RequestResponse_ROUTER_ERROR ? 2 : 1); } @@ -352,13 +352,13 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo heartbeatInterval = p->variant.heartbeat.period; } lastHeartbeat = millis(); - DEBUG_MSG("*** StoreAndForward Heartbeat received\n"); + LOG_DEBUG("*** StoreAndForward Heartbeat received\n"); } break; case StoreAndForward_RequestResponse_ROUTER_PING: if(is_client) { - DEBUG_MSG("*** StoreAndForward_RequestResponse_ROUTER_PING\n"); + LOG_DEBUG("*** StoreAndForward_RequestResponse_ROUTER_PING\n"); // respond with a CLIENT PONG storeForwardModule->sendMessage(getFrom(&mp), StoreAndForward_RequestResponse_CLIENT_PONG); } @@ -366,7 +366,7 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo case StoreAndForward_RequestResponse_ROUTER_STATS: if(is_client) { - DEBUG_MSG("*** Router Response STATS\n"); + LOG_DEBUG("*** Router Response STATS\n"); // These fields only have informational purpose on a client. Fill them to consume later. if (p->which_variant == StoreAndForward_stats_tag) { this->packetHistoryMax = p->variant.stats.messages_total; @@ -386,7 +386,7 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo // These fields only have informational purpose on a client. Fill them to consume later. if (p->which_variant == StoreAndForward_history_tag) { this->historyReturnWindow = p->variant.history.window / 60000; - DEBUG_MSG("*** Router Response HISTORY - Sending %d messages from last %d minutes\n", p->variant.history.history_messages, this->historyReturnWindow); + LOG_DEBUG("*** Router Response HISTORY - Sending %d messages from last %d minutes\n", p->variant.history.history_messages, this->historyReturnWindow); } } break; @@ -418,7 +418,7 @@ StoreForwardModule::StoreForwardModule() // Router if ((config.device.role == Config_DeviceConfig_Role_ROUTER) || (config.device.role == Config_DeviceConfig_Role_ROUTER_CLIENT)) { - DEBUG_MSG("*** Initializing Store & Forward Module in Router mode\n"); + LOG_DEBUG("*** Initializing Store & Forward Module in Router mode\n"); if (ESP.getPsramSize() > 0) { if (ESP.getFreePsram() >= 1024 * 1024) { @@ -444,19 +444,19 @@ StoreForwardModule::StoreForwardModule() this->populatePSRAM(); is_server = true; } else { - DEBUG_MSG("*** Device has less than 1M of PSRAM free.\n"); - DEBUG_MSG("*** Store & Forward Module - disabling server.\n"); + LOG_DEBUG("*** Device has less than 1M of PSRAM free.\n"); + LOG_DEBUG("*** Store & Forward Module - disabling server.\n"); } } else { - DEBUG_MSG("*** Device doesn't have PSRAM.\n"); - DEBUG_MSG("*** Store & Forward Module - disabling server.\n"); + LOG_DEBUG("*** Device doesn't have PSRAM.\n"); + LOG_DEBUG("*** Store & Forward Module - disabling server.\n"); } // Client } if ((config.device.role == Config_DeviceConfig_Role_CLIENT) || (config.device.role == Config_DeviceConfig_Role_ROUTER_CLIENT)) { is_client = true; - DEBUG_MSG("*** Initializing Store & Forward Module in Client mode\n"); + LOG_DEBUG("*** Initializing Store & Forward Module in Client mode\n"); } } #endif diff --git a/src/mqtt/MQTT.cpp b/src/mqtt/MQTT.cpp index df2d9b0932..33122d091b 100644 --- a/src/mqtt/MQTT.cpp +++ b/src/mqtt/MQTT.cpp @@ -42,7 +42,7 @@ void MQTT::onPublish(char *topic, byte *payload, unsigned int length) payloadStr[length] = 0; // null terminated string JSONValue *json_value = JSON::Parse(payloadStr); if (json_value != NULL) { - DEBUG_MSG("JSON Received on MQTT, parsing..\n"); + LOG_DEBUG("JSON Received on MQTT, parsing..\n"); // check if it is a valid envelope JSONObject json; json = json_value->AsObject(); @@ -50,7 +50,7 @@ void MQTT::onPublish(char *topic, byte *payload, unsigned int length) // this is a valid envelope if (json["payload"]->IsString() && json["type"]->IsString() && (json["sender"]->AsString().compare(owner.id) != 0)) { std::string jsonPayloadStr = json["payload"]->AsString(); - DEBUG_MSG("JSON payload %s, length %u\n", jsonPayloadStr.c_str(), jsonPayloadStr.length()); + LOG_DEBUG("JSON payload %s, length %u\n", jsonPayloadStr.c_str(), jsonPayloadStr.length()); // construct protobuf data packet using TEXT_MESSAGE, send it to the mesh MeshPacket *p = router->allocForSending(); @@ -61,10 +61,10 @@ void MQTT::onPublish(char *topic, byte *payload, unsigned int length) MeshPacket *packet = packetPool.allocCopy(*p); service.sendToMesh(packet, RX_SRC_LOCAL); } else { - DEBUG_MSG("Received MQTT json payload too long, dropping\n"); + LOG_DEBUG("Received MQTT json payload too long, dropping\n"); } } else { - DEBUG_MSG("JSON Ignoring downlink message we originally sent.\n"); + LOG_DEBUG("JSON Ignoring downlink message we originally sent.\n"); } } else if ((json.find("sender") != json.end()) && (json.find("payload") != json.end()) && (json.find("type") != json.end()) && json["type"]->IsString() && (json["type"]->AsString().compare("sendposition") == 0)) { //invent the "sendposition" type for a valid envelope @@ -84,26 +84,26 @@ void MQTT::onPublish(char *topic, byte *payload, unsigned int length) service.sendToMesh(p, RX_SRC_LOCAL); } else { - DEBUG_MSG("JSON Ignoring downlink message we originally sent.\n"); + LOG_DEBUG("JSON Ignoring downlink message we originally sent.\n"); } } else{ - DEBUG_MSG("JSON Received payload on MQTT but not a valid envelope\n"); + LOG_DEBUG("JSON Received payload on MQTT but not a valid envelope\n"); } } else { // no json, this is an invalid payload - DEBUG_MSG("Invalid MQTT service envelope, topic %s, len %u!\n", topic, length); + LOG_DEBUG("Invalid MQTT service envelope, topic %s, len %u!\n", topic, length); } delete json_value; } else { if (!pb_decode_from_bytes(payload, length, &ServiceEnvelope_msg, &e)) { - DEBUG_MSG("Invalid MQTT service envelope, topic %s, len %u!\n", topic, length); + LOG_DEBUG("Invalid MQTT service envelope, topic %s, len %u!\n", topic, length); return; }else { if (strcmp(e.gateway_id, owner.id) == 0) - DEBUG_MSG("Ignoring downlink message we originally sent.\n"); + LOG_DEBUG("Ignoring downlink message we originally sent.\n"); else { if (e.packet) { - DEBUG_MSG("Received MQTT topic %s, len=%u\n", topic, length); + LOG_DEBUG("Received MQTT topic %s, len=%u\n", topic, length); MeshPacket *p = packetPool.allocCopy(*e.packet); // ignore messages sent by us or if we don't have the channel key @@ -166,22 +166,22 @@ void MQTT::reconnect() } pubSub.setServer(serverAddr, serverPort); - DEBUG_MSG("Connecting to MQTT server %s, port: %d, username: %s, password: %s\n", serverAddr, serverPort, mqttUsername, mqttPassword); + LOG_DEBUG("Connecting to MQTT server %s, port: %d, username: %s, password: %s\n", serverAddr, serverPort, mqttUsername, mqttPassword); auto myStatus = (statusTopic + owner.id); bool connected = pubSub.connect(owner.id, mqttUsername, mqttPassword, myStatus.c_str(), 1, true, "offline"); if (connected) { - DEBUG_MSG("MQTT connected\n"); + LOG_DEBUG("MQTT connected\n"); enabled = true; // Start running background process again runASAP = true; reconnectCount = 0; /// FIXME, include more information in the status text bool ok = pubSub.publish(myStatus.c_str(), "online", true); - DEBUG_MSG("published %d\n", ok); + LOG_DEBUG("published %d\n", ok); sendSubscriptions(); } else { - DEBUG_MSG("Failed to contact MQTT server (%d/10)...\n",reconnectCount); + LOG_DEBUG("Failed to contact MQTT server (%d/10)...\n",reconnectCount); #if HAS_WIFI && !defined(ARCH_PORTDUINO) if (reconnectCount > 9) { needReconnect = true; @@ -200,11 +200,11 @@ void MQTT::sendSubscriptions() auto &ch = channels.getByIndex(i); if (ch.settings.downlink_enabled) { String topic = cryptTopic + channels.getGlobalId(i) + "/#"; - DEBUG_MSG("Subscribing to %s\n", topic.c_str()); + LOG_DEBUG("Subscribing to %s\n", topic.c_str()); pubSub.subscribe(topic.c_str(), 1); // FIXME, is QOS 1 right? if (moduleConfig.mqtt.json_enabled == true) { String topicDecoded = jsonTopic + channels.getGlobalId(i) + "/#"; - DEBUG_MSG("Subscribing to %s\n", topicDecoded.c_str()); + LOG_DEBUG("Subscribing to %s\n", topicDecoded.c_str()); pubSub.subscribe(topicDecoded.c_str(), 1); // FIXME, is QOS 1 right? } } @@ -254,7 +254,7 @@ int32_t MQTT::runOnce() size_t numBytes = pb_encode_to_bytes(bytes, sizeof(bytes), &ServiceEnvelope_msg, env); String topic = cryptTopic + env->channel_id + "/" + owner.id; - DEBUG_MSG("publish %s, %u bytes from queue\n", topic.c_str(), numBytes); + LOG_DEBUG("publish %s, %u bytes from queue\n", topic.c_str(), numBytes); pubSub.publish(topic.c_str(), bytes, numBytes, false); @@ -264,7 +264,7 @@ int32_t MQTT::runOnce() auto jsonString = this->downstreamPacketToJson(env->packet); if (jsonString.length() != 0) { String topicJson = jsonTopic + env->channel_id + "/" + owner.id; - DEBUG_MSG("JSON publish message to %s, %u bytes: %s\n", topicJson.c_str(), jsonString.length(), jsonString.c_str()); + LOG_DEBUG("JSON publish message to %s, %u bytes: %s\n", topicJson.c_str(), jsonString.length(), jsonString.c_str()); pubSub.publish(topicJson.c_str(), jsonString.c_str(), false); } } @@ -279,7 +279,7 @@ int32_t MQTT::runOnce() } else { // we are connected to server, check often for new requests on the TCP port if (!wantConnection) { - DEBUG_MSG("MQTT link not needed, dropping\n"); + LOG_DEBUG("MQTT link not needed, dropping\n"); pubSub.disconnect(); } @@ -308,7 +308,7 @@ void MQTT::onSend(const MeshPacket &mp, ChannelIndex chIndex) size_t numBytes = pb_encode_to_bytes(bytes, sizeof(bytes), &ServiceEnvelope_msg, env); String topic = cryptTopic + channelId + "/" + owner.id; - DEBUG_MSG("publish %s, %u bytes\n", topic.c_str(), numBytes); + LOG_DEBUG("publish %s, %u bytes\n", topic.c_str(), numBytes); pubSub.publish(topic.c_str(), bytes, numBytes, false); @@ -317,14 +317,14 @@ void MQTT::onSend(const MeshPacket &mp, ChannelIndex chIndex) auto jsonString = this->downstreamPacketToJson((MeshPacket *)&mp); if (jsonString.length() != 0) { String topicJson = jsonTopic + channelId + "/" + owner.id; - DEBUG_MSG("JSON publish message to %s, %u bytes: %s\n", topicJson.c_str(), jsonString.length(), jsonString.c_str()); + LOG_DEBUG("JSON publish message to %s, %u bytes: %s\n", topicJson.c_str(), jsonString.length(), jsonString.c_str()); pubSub.publish(topicJson.c_str(), jsonString.c_str(), false); } } } else { - DEBUG_MSG("MQTT not connected, queueing packet\n"); + LOG_DEBUG("MQTT not connected, queueing packet\n"); if (mqttQueue.numFree() == 0) { - DEBUG_MSG("NOTE: MQTT queue is full, discarding oldest\n"); + LOG_DEBUG("NOTE: MQTT queue is full, discarding oldest\n"); ServiceEnvelope *d = mqttQueue.dequeuePtr(0); if (d) mqttPool.release(d); @@ -350,20 +350,20 @@ std::string MQTT::downstreamPacketToJson(MeshPacket *mp) case PortNum_TEXT_MESSAGE_APP: { msgType = "text"; // convert bytes to string - DEBUG_MSG("got text message of size %u\n", mp->decoded.payload.size); + LOG_DEBUG("got text message of size %u\n", mp->decoded.payload.size); char payloadStr[(mp->decoded.payload.size) + 1]; memcpy(payloadStr, mp->decoded.payload.bytes, mp->decoded.payload.size); payloadStr[mp->decoded.payload.size] = 0; // null terminated string // check if this is a JSON payload JSONValue *json_value = JSON::Parse(payloadStr); if (json_value != NULL) { - DEBUG_MSG("text message payload is of type json\n"); + LOG_DEBUG("text message payload is of type json\n"); // if it is, then we can just use the json object jsonObj["payload"] = json_value; } else { // if it isn't, then we need to create a json object // with the string as the value - DEBUG_MSG("text message payload is of type plaintext\n"); + LOG_DEBUG("text message payload is of type plaintext\n"); msgPayload["text"] = new JSONValue(payloadStr); jsonObj["payload"] = new JSONValue(msgPayload); } @@ -392,7 +392,7 @@ std::string MQTT::downstreamPacketToJson(MeshPacket *mp) } jsonObj["payload"] = new JSONValue(msgPayload); } else - DEBUG_MSG("Error decoding protobuf for telemetry message!\n"); + LOG_DEBUG("Error decoding protobuf for telemetry message!\n"); }; break; } @@ -410,7 +410,7 @@ std::string MQTT::downstreamPacketToJson(MeshPacket *mp) msgPayload["hardware"] = new JSONValue(decoded->hw_model); jsonObj["payload"] = new JSONValue(msgPayload); } else - DEBUG_MSG("Error decoding protobuf for nodeinfo message!\n"); + LOG_DEBUG("Error decoding protobuf for nodeinfo message!\n"); }; break; } @@ -429,7 +429,7 @@ std::string MQTT::downstreamPacketToJson(MeshPacket *mp) if((int)decoded->altitude){msgPayload["altitude"] = new JSONValue((int)decoded->altitude);} jsonObj["payload"] = new JSONValue(msgPayload); } else { - DEBUG_MSG("Error decoding protobuf for position message!\n"); + LOG_DEBUG("Error decoding protobuf for position message!\n"); } }; break; @@ -452,7 +452,7 @@ std::string MQTT::downstreamPacketToJson(MeshPacket *mp) msgPayload["longitude_i"] = new JSONValue((int)decoded->longitude_i); jsonObj["payload"] = new JSONValue(msgPayload); } else { - DEBUG_MSG("Error decoding protobuf for position message!\n"); + LOG_DEBUG("Error decoding protobuf for position message!\n"); } }; break; @@ -474,7 +474,7 @@ std::string MQTT::downstreamPacketToJson(MeshPacket *mp) JSONValue *value = new JSONValue(jsonObj); std::string jsonStr = value->Stringify(); - DEBUG_MSG("serialized json message: %s\n", jsonStr.c_str()); + LOG_DEBUG("serialized json message: %s\n", jsonStr.c_str()); delete value; return jsonStr; diff --git a/src/nimble/NimbleBluetooth.cpp b/src/nimble/NimbleBluetooth.cpp index c74c733169..ae33e47026 100644 --- a/src/nimble/NimbleBluetooth.cpp +++ b/src/nimble/NimbleBluetooth.cpp @@ -22,7 +22,7 @@ class BluetoothPhoneAPI : public PhoneAPI { PhoneAPI::onNowHasData(fromRadioNum); - DEBUG_MSG("BLE notify fromNum\n"); + LOG_DEBUG("BLE notify fromNum\n"); uint8_t val[4]; put_le32(val, fromRadioNum); @@ -46,7 +46,7 @@ static BluetoothPhoneAPI *bluetoothPhoneAPI; class NimbleBluetoothToRadioCallback : public NimBLECharacteristicCallbacks { virtual void onWrite(NimBLECharacteristic *pCharacteristic) { - DEBUG_MSG("To Radio onwrite\n"); + LOG_DEBUG("To Radio onwrite\n"); auto val = pCharacteristic->getValue(); bluetoothPhoneAPI->handleToRadio(val.data(), val.length()); @@ -56,7 +56,7 @@ class NimbleBluetoothToRadioCallback : public NimBLECharacteristicCallbacks class NimbleBluetoothFromRadioCallback : public NimBLECharacteristicCallbacks { virtual void onRead(NimBLECharacteristic *pCharacteristic) { - DEBUG_MSG("From Radio onread\n"); + LOG_DEBUG("From Radio onread\n"); uint8_t fromRadioBytes[FromRadio_size]; size_t numBytes = bluetoothPhoneAPI->getFromRadio(fromRadioBytes); @@ -72,11 +72,11 @@ class NimbleBluetoothServerCallback : public NimBLEServerCallbacks uint32_t passkey = config.bluetooth.fixed_pin; if (config.bluetooth.mode == Config_BluetoothConfig_PairingMode_RANDOM_PIN) { - DEBUG_MSG("Using random passkey\n"); + LOG_DEBUG("Using random passkey\n"); // This is the passkey to be entered on peer - we pick a number >100,000 to ensure 6 digits passkey = random(100000, 999999); } - DEBUG_MSG("*** Enter passkey %d on the peer side ***\n", passkey); + LOG_DEBUG("*** Enter passkey %d on the peer side ***\n", passkey); powerFSM.trigger(EVENT_BLUETOOTH_PAIR); screen->startBluetoothPinScreen(passkey); @@ -87,7 +87,7 @@ class NimbleBluetoothServerCallback : public NimBLEServerCallbacks virtual void onAuthenticationComplete(ble_gap_conn_desc *desc) { - DEBUG_MSG("BLE authentication complete\n"); + LOG_DEBUG("BLE authentication complete\n"); if (passkeyShowing) { passkeyShowing = false; @@ -98,7 +98,7 @@ class NimbleBluetoothServerCallback : public NimBLEServerCallbacks virtual void onDisconnect(NimBLEServer* pServer, ble_gap_conn_desc *desc) { - DEBUG_MSG("BLE disconnect\n"); + LOG_DEBUG("BLE disconnect\n"); } }; @@ -108,7 +108,7 @@ static NimbleBluetoothFromRadioCallback *fromRadioCallbacks; void NimbleBluetooth::shutdown() { // Shutdown bluetooth for minimum power draw - DEBUG_MSG("Disable bluetooth\n"); + LOG_DEBUG("Disable bluetooth\n"); //Bluefruit.Advertising.stop(); NimBLEAdvertising *pAdvertising = NimBLEDevice::getAdvertising(); pAdvertising->reset(); @@ -125,7 +125,7 @@ void NimbleBluetooth::setup() // Uncomment for testing // NimbleBluetooth::clearBonds(); - DEBUG_MSG("Initialise the NimBLE bluetooth module\n"); + LOG_DEBUG("Initialise the NimBLE bluetooth module\n"); NimBLEDevice::init(getDeviceName()); NimBLEDevice::setPower(ESP_PWR_LVL_P9); @@ -186,7 +186,7 @@ void updateBatteryLevel(uint8_t level) void NimbleBluetooth::clearBonds() { - DEBUG_MSG("Clearing bluetooth bonds!\n"); + LOG_DEBUG("Clearing bluetooth bonds!\n"); NimBLEDevice::deleteAllBonds(); } diff --git a/src/platform/esp32/ESP32CryptoEngine.cpp b/src/platform/esp32/ESP32CryptoEngine.cpp index 4bbbc4ad47..93eb76dbd0 100644 --- a/src/platform/esp32/ESP32CryptoEngine.cpp +++ b/src/platform/esp32/ESP32CryptoEngine.cpp @@ -46,7 +46,7 @@ class ESP32CryptoEngine : public CryptoEngine static uint8_t scratch[MAX_BLOCKSIZE]; size_t nc_off = 0; - DEBUG_MSG("ESP32 crypt fr=%x, num=%x, numBytes=%d!\n", fromNode, (uint32_t) packetId, numBytes); + LOG_DEBUG("ESP32 crypt fr=%x, num=%x, numBytes=%d!\n", fromNode, (uint32_t) packetId, numBytes); initNonce(fromNode, packetId); assert(numBytes <= MAX_BLOCKSIZE); memcpy(scratch, bytes, numBytes); diff --git a/src/platform/esp32/main-esp32.cpp b/src/platform/esp32/main-esp32.cpp index 2fcdf93180..f141ff3be8 100644 --- a/src/platform/esp32/main-esp32.cpp +++ b/src/platform/esp32/main-esp32.cpp @@ -66,17 +66,17 @@ void enableSlowCLK() uint32_t cal_32k = CALIBRATE_ONE(RTC_CAL_32K_XTAL); if (cal_32k == 0) { - DEBUG_MSG("32K XTAL OSC has not started up\n"); + LOG_DEBUG("32K XTAL OSC has not started up\n"); } else { rtc_clk_slow_freq_set(RTC_SLOW_FREQ_32K_XTAL); - DEBUG_MSG("Switching RTC Source to 32.768Khz succeeded, using 32K XTAL\n"); + LOG_DEBUG("Switching RTC Source to 32.768Khz succeeded, using 32K XTAL\n"); CALIBRATE_ONE(RTC_CAL_RTC_MUX); CALIBRATE_ONE(RTC_CAL_32K_XTAL); } CALIBRATE_ONE(RTC_CAL_RTC_MUX); CALIBRATE_ONE(RTC_CAL_32K_XTAL); if (rtc_clk_slow_freq_get() != RTC_SLOW_FREQ_32K_XTAL) { - DEBUG_MSG("Warning: Failed to switch 32K XTAL RTC source to 32.768Khz !!! \n"); return; + LOG_WARN("Failed to switch 32K XTAL RTC source to 32.768Khz !!! \n"); return; } } #endif @@ -85,21 +85,21 @@ void enableSlowCLK() void esp32Setup() { uint32_t seed = esp_random(); - DEBUG_MSG("Setting random seed %u\n", seed); + LOG_DEBUG("Setting random seed %u\n", seed); randomSeed(seed); // ESP docs say this is fairly random - DEBUG_MSG("Total heap: %d\n", ESP.getHeapSize()); - DEBUG_MSG("Free heap: %d\n", ESP.getFreeHeap()); - DEBUG_MSG("Total PSRAM: %d\n", ESP.getPsramSize()); - DEBUG_MSG("Free PSRAM: %d\n", ESP.getFreePsram()); + LOG_DEBUG("Total heap: %d\n", ESP.getHeapSize()); + LOG_DEBUG("Free heap: %d\n", ESP.getFreeHeap()); + LOG_DEBUG("Total PSRAM: %d\n", ESP.getPsramSize()); + LOG_DEBUG("Free PSRAM: %d\n", ESP.getFreePsram()); nvs_stats_t nvs_stats; auto res = nvs_get_stats(NULL, &nvs_stats); assert(res == ESP_OK); - DEBUG_MSG("NVS: UsedEntries %d, FreeEntries %d, AllEntries %d, NameSpaces %d\n", nvs_stats.used_entries, nvs_stats.free_entries, + LOG_DEBUG("NVS: UsedEntries %d, FreeEntries %d, AllEntries %d, NameSpaces %d\n", nvs_stats.used_entries, nvs_stats.free_entries, nvs_stats.total_entries, nvs_stats.namespace_count); - DEBUG_MSG("Setup Preferences in Flash Storage\n"); + LOG_DEBUG("Setup Preferences in Flash Storage\n"); // Create object to store our persistant data Preferences preferences; @@ -109,12 +109,12 @@ void esp32Setup() rebootCounter++; preferences.putUInt("rebootCounter", rebootCounter); preferences.end(); - DEBUG_MSG("Number of Device Reboots: %d\n", rebootCounter); + LOG_DEBUG("Number of Device Reboots: %d\n", rebootCounter); String BLEOTA=BleOta::getOtaAppVersion(); if (BLEOTA.isEmpty()) { - DEBUG_MSG("No OTA firmware available\n"); + LOG_DEBUG("No OTA firmware available\n"); }else{ - DEBUG_MSG("OTA firmware version %s\n", BLEOTA.c_str()); + LOG_DEBUG("OTA firmware version %s\n", BLEOTA.c_str()); } // enableModemSleep(); @@ -141,13 +141,13 @@ void esp32Setup() uint32_t axpDebugRead() { axp.debugCharging(); - DEBUG_MSG("vbus current %f\n", axp.getVbusCurrent()); - DEBUG_MSG("charge current %f\n", axp.getBattChargeCurrent()); - DEBUG_MSG("bat voltage %f\n", axp.getBattVoltage()); - DEBUG_MSG("batt pct %d\n", axp.getBattPercentage()); - DEBUG_MSG("is battery connected %d\n", axp.isBatteryConnect()); - DEBUG_MSG("is USB connected %d\n", axp.isVBUSPlug()); - DEBUG_MSG("is charging %d\n", axp.isChargeing()); + LOG_DEBUG("vbus current %f\n", axp.getVbusCurrent()); + LOG_DEBUG("charge current %f\n", axp.getBattChargeCurrent()); + LOG_DEBUG("bat voltage %f\n", axp.getBattVoltage()); + LOG_DEBUG("batt pct %d\n", axp.getBattPercentage()); + LOG_DEBUG("is battery connected %d\n", axp.isBatteryConnect()); + LOG_DEBUG("is USB connected %d\n", axp.isVBUSPlug()); + LOG_DEBUG("is charging %d\n", axp.isChargeing()); return 30 * 1000; } diff --git a/src/platform/nrf52/NRF52Bluetooth.cpp b/src/platform/nrf52/NRF52Bluetooth.cpp index acb26071fe..950d6b7a46 100644 --- a/src/platform/nrf52/NRF52Bluetooth.cpp +++ b/src/platform/nrf52/NRF52Bluetooth.cpp @@ -33,7 +33,7 @@ class BluetoothPhoneAPI : public PhoneAPI { PhoneAPI::onNowHasData(fromRadioNum); - DEBUG_MSG("BLE notify fromNum\n"); + LOG_DEBUG("BLE notify fromNum\n"); fromNum.notify32(fromRadioNum); } @@ -55,7 +55,7 @@ void onConnect(uint16_t conn_handle) char central_name[32] = {0}; connection->getPeerName(central_name, sizeof(central_name)); - DEBUG_MSG("BLE Connected to %s\n", central_name); + LOG_DEBUG("BLE Connected to %s\n", central_name); } /** @@ -66,21 +66,21 @@ void onConnect(uint16_t conn_handle) void onDisconnect(uint16_t conn_handle, uint8_t reason) { // FIXME - we currently assume only one active connection - DEBUG_MSG("BLE Disconnected, reason = 0x%x\n", reason); + LOG_DEBUG("BLE Disconnected, reason = 0x%x\n", reason); } void onCccd(uint16_t conn_hdl, BLECharacteristic *chr, uint16_t cccd_value) { // Display the raw request packet - DEBUG_MSG("CCCD Updated: %u\n", cccd_value); + LOG_DEBUG("CCCD Updated: %u\n", cccd_value); // Check the characteristic this CCCD update is associated with in case // this handler is used for multiple CCCD records. if (chr->uuid == fromNum.uuid) { if (chr->notifyEnabled(conn_hdl)) { - DEBUG_MSG("fromNum 'Notify' enabled\n"); + LOG_DEBUG("fromNum 'Notify' enabled\n"); } else { - DEBUG_MSG("fromNum 'Notify' disabled\n"); + LOG_DEBUG("fromNum 'Notify' disabled\n"); } } } @@ -135,14 +135,14 @@ void onFromRadioAuthorize(uint16_t conn_hdl, BLECharacteristic *chr, ble_gatts_e // or make empty if the queue is empty fromRadio.write(fromRadioBytes, numBytes); } else { - // DEBUG_MSG("Ignoring successor read\n"); + // LOG_DEBUG("Ignoring successor read\n"); } authorizeRead(conn_hdl); } void onToRadioWrite(uint16_t conn_hdl, BLECharacteristic *chr, uint8_t *data, uint16_t len) { - DEBUG_MSG("toRadioWriteCb data %p, len %u\n", data, len); + LOG_DEBUG("toRadioWriteCb data %p, len %u\n", data, len); bluetoothPhoneAPI->handleToRadio(data, len); } @@ -152,7 +152,7 @@ void onToRadioWrite(uint16_t conn_hdl, BLECharacteristic *chr, uint8_t *data, ui */ void onFromNumAuthorize(uint16_t conn_hdl, BLECharacteristic *chr, ble_gatts_evt_read_t *request) { - DEBUG_MSG("fromNumAuthorizeCb\n"); + LOG_DEBUG("fromNumAuthorizeCb\n"); authorizeRead(conn_hdl); } @@ -204,14 +204,14 @@ static uint32_t configuredPasskey; void NRF52Bluetooth::shutdown() { // Shutdown bluetooth for minimum power draw - DEBUG_MSG("Disable NRF52 bluetooth\n"); + LOG_DEBUG("Disable NRF52 bluetooth\n"); Bluefruit.Advertising.stop(); } void NRF52Bluetooth::setup() { // Initialise the Bluefruit module - DEBUG_MSG("Initialize the Bluefruit nRF52 module\n"); + LOG_DEBUG("Initialize the Bluefruit nRF52 module\n"); Bluefruit.autoConnLed(false); Bluefruit.configPrphBandwidth(BANDWIDTH_MAX); Bluefruit.begin(); @@ -225,7 +225,7 @@ void NRF52Bluetooth::setup() configuredPasskey = config.bluetooth.mode == Config_BluetoothConfig_PairingMode_FIXED_PIN ? config.bluetooth.fixed_pin : random(100000, 999999); auto pinString = std::to_string(configuredPasskey); - DEBUG_MSG("Bluetooth pin set to '%i'\n", configuredPasskey); + LOG_DEBUG("Bluetooth pin set to '%i'\n", configuredPasskey); Bluefruit.Security.setPIN(pinString.c_str()); Bluefruit.Security.setIOCaps(true, false, false); Bluefruit.Security.setPairPasskeyCallback(NRF52Bluetooth::onPairingPasskey); @@ -248,30 +248,30 @@ void NRF52Bluetooth::setup() bledfu.begin(); // Install the DFU helper // Configure and Start the Device Information Service - DEBUG_MSG("Configuring the Device Information Service\n"); + LOG_DEBUG("Configuring the Device Information Service\n"); bledis.setModel(optstr(HW_VERSION)); bledis.setFirmwareRev(optstr(APP_VERSION)); bledis.begin(); // Start the BLE Battery Service and set it to 100% - DEBUG_MSG("Configuring the Battery Service\n"); + LOG_DEBUG("Configuring the Battery Service\n"); blebas.begin(); blebas.write(0); // Unknown battery level for now // Setup the Heart Rate Monitor service using // BLEService and BLECharacteristic classes - DEBUG_MSG("Configuring the Mesh bluetooth service\n"); + LOG_DEBUG("Configuring the Mesh bluetooth service\n"); setupMeshService(); // Supposedly debugging works with soft device if you disable advertising if (isSoftDeviceAllowed) { // Setup the advertising packet(s) - DEBUG_MSG("Setting up the advertising payload(s)\n"); + LOG_DEBUG("Setting up the advertising payload(s)\n"); startAdv(); - DEBUG_MSG("Advertising\n"); + LOG_DEBUG("Advertising\n"); } } @@ -283,7 +283,7 @@ void updateBatteryLevel(uint8_t level) void NRF52Bluetooth::clearBonds() { - DEBUG_MSG("Clearing bluetooth bonds!\n"); + LOG_DEBUG("Clearing bluetooth bonds!\n"); bond_print_list(BLE_GAP_ROLE_PERIPH); bond_print_list(BLE_GAP_ROLE_CENTRAL); @@ -293,12 +293,12 @@ void NRF52Bluetooth::clearBonds() void NRF52Bluetooth::onConnectionSecured(uint16_t conn_handle) { - DEBUG_MSG("BLE connection secured\n"); + LOG_DEBUG("BLE connection secured\n"); } bool NRF52Bluetooth::onPairingPasskey(uint16_t conn_handle, uint8_t const passkey[6], bool match_request) { - DEBUG_MSG("BLE pairing process started with passkey %.3s %.3s\n", passkey, passkey+3); + LOG_DEBUG("BLE pairing process started with passkey %.3s %.3s\n", passkey, passkey+3); screen->startBluetoothPinScreen(configuredPasskey); if (match_request) @@ -309,16 +309,16 @@ bool NRF52Bluetooth::onPairingPasskey(uint16_t conn_handle, uint8_t const passke if (!Bluefruit.connected(conn_handle)) break; } } - DEBUG_MSG("BLE passkey pairing: match_request=%i\n", match_request); + LOG_DEBUG("BLE passkey pairing: match_request=%i\n", match_request); return true; } void NRF52Bluetooth::onPairingCompleted(uint16_t conn_handle, uint8_t auth_status) { if (auth_status == BLE_GAP_SEC_STATUS_SUCCESS) - DEBUG_MSG("BLE pairing success\n"); + LOG_DEBUG("BLE pairing success\n"); else - DEBUG_MSG("BLE pairing failed\n"); + LOG_DEBUG("BLE pairing failed\n"); screen->stopBluetoothPinScreen(); } diff --git a/src/platform/nrf52/NRF52CryptoEngine.cpp b/src/platform/nrf52/NRF52CryptoEngine.cpp index 42eacfc274..73add2c3b3 100644 --- a/src/platform/nrf52/NRF52CryptoEngine.cpp +++ b/src/platform/nrf52/NRF52CryptoEngine.cpp @@ -17,13 +17,13 @@ class NRF52CryptoEngine : public CryptoEngine virtual void encrypt(uint32_t fromNode, uint64_t packetId, size_t numBytes, uint8_t *bytes) override { if (key.length > 16) { - DEBUG_MSG("Software encrypt fr=%x, num=%x, numBytes=%d!\n", fromNode, (uint32_t) packetId, numBytes); + LOG_DEBUG("Software encrypt fr=%x, num=%x, numBytes=%d!\n", fromNode, (uint32_t) packetId, numBytes); AES_ctx ctx; initNonce(fromNode, packetId); AES_init_ctx_iv(&ctx, key.bytes, nonce); AES_CTR_xcrypt_buffer(&ctx, bytes, numBytes); } else if (key.length > 0) { - DEBUG_MSG("nRF52 encrypt fr=%x, num=%x, numBytes=%d!\n", fromNode, (uint32_t) packetId, numBytes); + LOG_DEBUG("nRF52 encrypt fr=%x, num=%x, numBytes=%d!\n", fromNode, (uint32_t) packetId, numBytes); nRFCrypto.begin(); nRFCrypto_AES ctx; uint8_t myLen = ctx.blockLen(numBytes); diff --git a/src/platform/nrf52/hardfault.cpp b/src/platform/nrf52/hardfault.cpp index d638290724..fb27c35509 100644 --- a/src/platform/nrf52/hardfault.cpp +++ b/src/platform/nrf52/hardfault.cpp @@ -5,7 +5,7 @@ enum { r0, r1, r2, r3, r12, lr, pc, psr }; -// we can't use the regular DEBUG_MSG for these crash dumps because it depends on threading still being running. Instead use the +// we can't use the regular LOG_DEBUG for these crash dumps because it depends on threading still being running. Instead use the // segger in memory tool #define FAULT_MSG(...) SEGGER_MSG(__VA_ARGS__) diff --git a/src/platform/nrf52/main-nrf52.cpp b/src/platform/nrf52/main-nrf52.cpp index 254ab695b0..c53c548b52 100644 --- a/src/platform/nrf52/main-nrf52.cpp +++ b/src/platform/nrf52/main-nrf52.cpp @@ -32,7 +32,7 @@ bool loopCanSleep() { // handle standard gcc assert failures void __attribute__((noreturn)) __assert_func(const char *file, int line, const char *func, const char *failedexpr) { - DEBUG_MSG("assert failed %s: %d, %s, test=%s\n", file, line, func, failedexpr); + LOG_DEBUG("assert failed %s: %d, %s, test=%s\n", file, line, func, failedexpr); // debugger_break(); FIXME doesn't work, possibly not for segger // Reboot cpu NVIC_SystemReset(); @@ -73,7 +73,7 @@ void setBluetoothEnable(bool on) if (on) { if (!nrf52Bluetooth) { if (!useSoftDevice) - DEBUG_MSG("DISABLING NRF52 BLUETOOTH WHILE DEBUGGING\n"); + LOG_DEBUG("DISABLING NRF52 BLUETOOTH WHILE DEBUGGING\n"); else { nrf52Bluetooth = new NRF52Bluetooth(); nrf52Bluetooth->setup(); @@ -112,7 +112,7 @@ void checkSDEvents() break; default: - DEBUG_MSG("Unexpected SDevt %d\n", evt); + LOG_DEBUG("Unexpected SDevt %d\n", evt); break; } } @@ -132,7 +132,7 @@ void nrf52Setup() auto why = NRF_POWER->RESETREAS; // per // https://infocenter.nordicsemi.com/index.jsp?topic=%2Fcom.nordic.infocenter.nrf52832.ps.v1.1%2Fpower.html - DEBUG_MSG("Reset reason: 0x%x\n", why); + LOG_DEBUG("Reset reason: 0x%x\n", why); // Per // https://devzone.nordicsemi.com/nordic/nordic-blog/b/blog/posts/monitor-mode-debugging-with-j-link-and-gdbeclipse @@ -142,7 +142,7 @@ void nrf52Setup() #ifdef BQ25703A_ADDR auto *bq = new BQ25713(); if (!bq->setup()) - DEBUG_MSG("ERROR! Charge controller init failed\n"); + LOG_DEBUG("ERROR! Charge controller init failed\n"); #endif // Init random seed @@ -152,7 +152,7 @@ void nrf52Setup() } seed; nRFCrypto.begin(); nRFCrypto.Random.generate(seed.seed8, sizeof(seed.seed8)); - DEBUG_MSG("Setting random seed %u\n", seed.seed32); + LOG_DEBUG("Setting random seed %u\n", seed.seed32); randomSeed(seed.seed32); nRFCrypto.end(); } @@ -178,7 +178,7 @@ void cpuDeepSleep(uint64_t msecToWake) auto ok = sd_power_system_off(); if (ok != NRF_SUCCESS) { - DEBUG_MSG("FIXME: Ignoring soft device (EasyDMA pending?) and forcing " + LOG_DEBUG("FIXME: Ignoring soft device (EasyDMA pending?) and forcing " "system-off!\n"); NRF_POWER->SYSTEMOFF = 1; } @@ -186,7 +186,7 @@ void cpuDeepSleep(uint64_t msecToWake) // The following code should not be run, because we are off while (1) { delay(5000); - DEBUG_MSG("."); + LOG_DEBUG("."); } } diff --git a/src/platform/portduino/CrossPlatformCryptoEngine.cpp b/src/platform/portduino/CrossPlatformCryptoEngine.cpp index b3b3853c31..7bd021a424 100644 --- a/src/platform/portduino/CrossPlatformCryptoEngine.cpp +++ b/src/platform/portduino/CrossPlatformCryptoEngine.cpp @@ -27,7 +27,7 @@ class CrossPlatformCryptoEngine : public CryptoEngine virtual void setKey(const CryptoKey &k) override { CryptoEngine::setKey(k); - DEBUG_MSG("Installing AES%d key!\n", key.length * 8); + LOG_DEBUG("Installing AES%d key!\n", key.length * 8); if (ctr) { delete ctr; ctr = NULL; @@ -54,7 +54,7 @@ class CrossPlatformCryptoEngine : public CryptoEngine static uint8_t scratch[MAX_BLOCKSIZE]; //size_t nc_off = 0; - // DEBUG_MSG("ESP32 encrypt!\n"); + // LOG_DEBUG("ESP32 encrypt!\n"); initNonce(fromNode, packetId); assert(numBytes <= MAX_BLOCKSIZE); memcpy(scratch, bytes, numBytes); diff --git a/src/platform/portduino/SimRadio.cpp b/src/platform/portduino/SimRadio.cpp index 06427a6d56..016b910459 100644 --- a/src/platform/portduino/SimRadio.cpp +++ b/src/platform/portduino/SimRadio.cpp @@ -22,7 +22,7 @@ ErrorCode SimRadio::send(MeshPacket *p) // set (random) transmit delay to let others reconfigure their radio, // to avoid collisions and implement timing-based flooding - DEBUG_MSG("Set random delay before transmitting.\n"); + LOG_DEBUG("Set random delay before transmitting.\n"); setTransmitDelay(); return res; } @@ -42,7 +42,7 @@ void SimRadio::setTransmitDelay() startTransmitTimer(true); } else { // If there is a SNR, start a timer scaled based on that SNR. - DEBUG_MSG("rx_snr found. hop_limit:%d rx_snr:%f\n", p->hop_limit, p->rx_snr); + LOG_DEBUG("rx_snr found. hop_limit:%d rx_snr:%f\n", p->hop_limit, p->rx_snr); startTransmitTimerSNR(p->rx_snr); } } @@ -52,11 +52,11 @@ void SimRadio::startTransmitTimer(bool withDelay) // If we have work to do and the timer wasn't already scheduled, schedule it now if (!txQueue.empty()) { uint32_t delayMsec = !withDelay ? 1 : getTxDelayMsec(); - // DEBUG_MSG("xmit timer %d\n", delay); + // LOG_DEBUG("xmit timer %d\n", delay); delay(delayMsec); onNotify(TRANSMIT_DELAY_COMPLETED); } else { - DEBUG_MSG("TX QUEUE EMPTY!\n"); + LOG_DEBUG("TX QUEUE EMPTY!\n"); } } @@ -65,7 +65,7 @@ void SimRadio::startTransmitTimerSNR(float snr) // If we have work to do and the timer wasn't already scheduled, schedule it now if (!txQueue.empty()) { uint32_t delayMsec = getTxDelayMsecWeighted(snr); - // DEBUG_MSG("xmit timer %d\n", delay); + // LOG_DEBUG("xmit timer %d\n", delay); delay(delayMsec); onNotify(TRANSMIT_DELAY_COMPLETED); } @@ -92,7 +92,7 @@ void SimRadio::completeSending() // We are done sending that packet, release it packetPool.release(p); - // DEBUG_MSG("Done with send\n"); + // LOG_DEBUG("Done with send\n"); } } @@ -108,9 +108,9 @@ bool SimRadio::canSendImmediately() if (busyTx || busyRx) { if (busyTx) - DEBUG_MSG("Can not send yet, busyTx\n"); + LOG_DEBUG("Can not send yet, busyTx\n"); if (busyRx) - DEBUG_MSG("Can not send yet, busyRx\n"); + LOG_DEBUG("Can not send yet, busyRx\n"); return false; } else return true; @@ -134,7 +134,7 @@ bool SimRadio::cancelSending(NodeNum from, PacketId id) packetPool.release(p); // free the packet we just removed bool result = (p != NULL); - DEBUG_MSG("cancelSending id=0x%x, removed=%d\n", id, result); + LOG_DEBUG("cancelSending id=0x%x, removed=%d\n", id, result); return result; } @@ -144,24 +144,24 @@ void SimRadio::onNotify(uint32_t notification) switch (notification) { case ISR_TX: handleTransmitInterrupt(); - DEBUG_MSG("tx complete - starting timer\n"); + LOG_DEBUG("tx complete - starting timer\n"); startTransmitTimer(); break; case ISR_RX: - DEBUG_MSG("rx complete - starting timer\n"); + LOG_DEBUG("rx complete - starting timer\n"); break; case TRANSMIT_DELAY_COMPLETED: - DEBUG_MSG("delay done\n"); + LOG_DEBUG("delay done\n"); // If we are not currently in receive mode, then restart the random delay (this can happen if the main thread // has placed the unit into standby) FIXME, how will this work if the chipset is in sleep mode? if (!txQueue.empty()) { if (!canSendImmediately()) { - // DEBUG_MSG("Currently Rx/Tx-ing: set random delay\n"); + // LOG_DEBUG("Currently Rx/Tx-ing: set random delay\n"); setTransmitDelay(); // currently Rx/Tx-ing: reset random delay } else { if (isChannelActive()) { // check if there is currently a LoRa packet on the channel - // DEBUG_MSG("Channel is active: set random delay\n"); + // LOG_DEBUG("Channel is active: set random delay\n"); setTransmitDelay(); // reset random delay } else { // Send any outgoing packets we have ready @@ -177,7 +177,7 @@ void SimRadio::onNotify(uint32_t notification) } } } else { - // DEBUG_MSG("done with txqueue\n"); + // LOG_DEBUG("done with txqueue\n"); } break; default: @@ -194,12 +194,12 @@ void SimRadio::startSend(MeshPacket * txp) perhapsDecode(p); Compressed c = Compressed_init_default; c.portnum = p->decoded.portnum; - // DEBUG_MSG("Sending back to simulator with portNum %d\n", p->decoded.portnum); + // LOG_DEBUG("Sending back to simulator with portNum %d\n", p->decoded.portnum); if (p->decoded.payload.size <= sizeof(c.data.bytes)) { memcpy(&c.data.bytes, p->decoded.payload.bytes, p->decoded.payload.size); c.data.size = p->decoded.payload.size; } else { - DEBUG_MSG("Payload size is larger than compressed message allows! Sending empty payload.\n"); + LOG_DEBUG("Payload size is larger than compressed message allows! Sending empty payload.\n"); } p->decoded.payload.size = pb_encode_to_bytes(p->decoded.payload.bytes, sizeof(p->decoded.payload.bytes), &Compressed_msg, &c); p->decoded.portnum = PortNum_SIMULATOR_APP; @@ -218,7 +218,7 @@ void SimRadio::startReceive(MeshPacket *p) { void SimRadio::handleReceiveInterrupt(MeshPacket *p) { - DEBUG_MSG("HANDLE RECEIVE INTERRUPT\n"); + LOG_DEBUG("HANDLE RECEIVE INTERRUPT\n"); uint32_t xmitMsec; assert(isReceiving); isReceiving = false; @@ -226,7 +226,7 @@ void SimRadio::handleReceiveInterrupt(MeshPacket *p) // read the number of actually received bytes size_t length = getPacketLength(p); xmitMsec = getPacketTime(length); - // DEBUG_MSG("Payload size %d vs length (includes header) %d\n", p->decoded.payload.size, length); + // LOG_DEBUG("Payload size %d vs length (includes header) %d\n", p->decoded.payload.size, length); MeshPacket *mp = packetPool.allocCopy(*p); // keep a copy in packtPool mp->which_payload_variant = MeshPacket_decoded_tag; // Mark that the payload is already decoded diff --git a/src/shutdown.h b/src/shutdown.h index 3927825fb8..23f5d72520 100644 --- a/src/shutdown.h +++ b/src/shutdown.h @@ -7,14 +7,14 @@ void powerCommandsCheck() { if (rebootAtMsec && millis() > rebootAtMsec) { - DEBUG_MSG("Rebooting\n"); + LOG_DEBUG("Rebooting\n"); #if defined(ARCH_ESP32) ESP.restart(); #elif defined(ARCH_NRF52) NVIC_SystemReset(); #else rebootAtMsec = -1; - DEBUG_MSG("FIXME implement reboot for this platform. Skipping for now.\n"); + LOG_DEBUG("FIXME implement reboot for this platform. Skipping for now.\n"); #endif } @@ -35,7 +35,7 @@ void powerCommandsCheck() #endif if (shutdownAtMsec && millis() > shutdownAtMsec) { - DEBUG_MSG("Shutting down from admin command\n"); + LOG_DEBUG("Shutting down from admin command\n"); #ifdef HAS_PMU if (pmu_found == true) { playShutdownMelody(); @@ -45,7 +45,7 @@ void powerCommandsCheck() playShutdownMelody(); power->shutdown(); #else - DEBUG_MSG("FIXME implement shutdown for this platform"); + LOG_DEBUG("FIXME implement shutdown for this platform"); #endif } } diff --git a/src/sleep.cpp b/src/sleep.cpp index 40426a7771..ee38da6994 100644 --- a/src/sleep.cpp +++ b/src/sleep.cpp @@ -60,7 +60,7 @@ void setCPUFast(bool on) * all WiFi use cases. * (Added: Dec 23, 2021 by Jm Casler) */ - DEBUG_MSG("Setting CPU to 240mhz because WiFi is in use.\n"); + LOG_DEBUG("Setting CPU to 240mhz because WiFi is in use.\n"); setCpuFrequencyMhz(240); return; } @@ -90,7 +90,7 @@ void setLed(bool ledOn) void setGPSPower(bool on) { - DEBUG_MSG("Setting GPS power=%d\n", on); + LOG_DEBUG("Setting GPS power=%d\n", on); #ifdef HAS_PMU if (pmu_found && PMU){ @@ -136,7 +136,7 @@ void initDeepSleep() if (wakeCause == ESP_SLEEP_WAKEUP_TIMER) reason = "timeout"; - DEBUG_MSG("booted, wake cause %d (boot count %d), reset_reason=%s\n", wakeCause, bootCount, reason); + LOG_DEBUG("booted, wake cause %d (boot count %d), reset_reason=%s\n", wakeCause, bootCount, reason); #endif } @@ -174,13 +174,13 @@ void doGPSpowersave(bool on) #ifdef HAS_PMU if (on) { - DEBUG_MSG("Turning GPS back on\n"); + LOG_DEBUG("Turning GPS back on\n"); gps->forceWake(1); setGPSPower(1); } else { - DEBUG_MSG("Turning off GPS chip\n"); + LOG_DEBUG("Turning off GPS chip\n"); notifyGPSSleep.notifyObservers(NULL); setGPSPower(0); } @@ -188,12 +188,12 @@ void doGPSpowersave(bool on) #ifdef PIN_GPS_WAKE if (on) { - DEBUG_MSG("Waking GPS"); + LOG_DEBUG("Waking GPS"); gps->forceWake(1); } else { - DEBUG_MSG("GPS entering sleep"); + LOG_DEBUG("GPS entering sleep"); notifyGPSSleep.notifyObservers(NULL); } #endif @@ -201,7 +201,7 @@ void doGPSpowersave(bool on) void doDeepSleep(uint64_t msecToWake) { - DEBUG_MSG("Entering deep sleep for %lu seconds\n", msecToWake / 1000); + LOG_DEBUG("Entering deep sleep for %lu seconds\n", msecToWake / 1000); // not using wifi yet, but once we are this is needed to shutoff the radio hw // esp_wifi_stop(); @@ -258,7 +258,7 @@ void doDeepSleep(uint64_t msecToWake) */ esp_sleep_wakeup_cause_t doLightSleep(uint64_t sleepMsec) // FIXME, use a more reasonable default { - // DEBUG_MSG("Enter light sleep\n"); + // LOG_DEBUG("Enter light sleep\n"); waitEnterSleep(); @@ -310,7 +310,7 @@ esp_sleep_wakeup_cause_t doLightSleep(uint64_t sleepMsec) // FIXME, use a more r esp_sleep_wakeup_cause_t cause = esp_sleep_get_wakeup_cause(); #ifdef BUTTON_PIN if (cause == ESP_SLEEP_WAKEUP_GPIO) - DEBUG_MSG("Exit light sleep gpio: btn=%d\n", !digitalRead(BUTTON_PIN)); + LOG_DEBUG("Exit light sleep gpio: btn=%d\n", !digitalRead(BUTTON_PIN)); #endif return cause; @@ -340,6 +340,6 @@ void enableModemSleep() esp32_config.min_freq_mhz = 20; // 10Mhz is minimum recommended esp32_config.light_sleep_enable = false; int rv = esp_pm_configure(&esp32_config); - DEBUG_MSG("Sleep request result %x\n", rv); + LOG_DEBUG("Sleep request result %x\n", rv); } #endif From 3eefd46ca1f0a7bb322194e39db27c04afe54b50 Mon Sep 17 00:00:00 2001 From: Ben Meadors Date: Fri, 30 Dec 2022 07:48:59 -0600 Subject: [PATCH 3/7] Log levels log function --- src/DebugConfiguration.h | 8 ++++---- src/RedirectablePrint.cpp | 7 +++---- src/RedirectablePrint.h | 2 +- 3 files changed, 8 insertions(+), 9 deletions(-) diff --git a/src/DebugConfiguration.h b/src/DebugConfiguration.h index f7733d5b1c..d82ea186ca 100644 --- a/src/DebugConfiguration.h +++ b/src/DebugConfiguration.h @@ -29,10 +29,10 @@ #define LOG_ERROR(...) SEGGER_RTT_printf(0, __VA_ARGS__) #else #ifdef DEBUG_PORT -#define LOG_DEBUG(...) DEBUG_PORT.logDebug(__VA_ARGS__) -#define LOG_INFO(...) DEBUG_PORT.logDebug(__VA_ARGS__) -#define LOG_WARN(...) DEBUG_PORT.logDebug(__VA_ARGS__) -#define LOG_ERROR(...) DEBUG_PORT.logDebug(__VA_ARGS__) +#define LOG_DEBUG(...) DEBUG_PORT.log(LOG_LEVEL_DEBUG, __VA_ARGS__) +#define LOG_INFO(...) DEBUG_PORT.log(LOG_LEVEL_INFO, __VA_ARGS__) +#define LOG_WARN(...) DEBUG_PORT.log(LOG_LEVEL_WARN, __VA_ARGS__) +#define LOG_ERROR(...) DEBUG_PORT.log(LOG_LEVEL_ERROR, __VA_ARGS__) #else #define LOG_DEBUG(...) #define LOG_INFO(...) diff --git a/src/RedirectablePrint.cpp b/src/RedirectablePrint.cpp index 66c83171ad..e7f305e196 100644 --- a/src/RedirectablePrint.cpp +++ b/src/RedirectablePrint.cpp @@ -58,7 +58,7 @@ size_t RedirectablePrint::vprintf(const char *format, va_list arg) return len; } -size_t RedirectablePrint::logDebug(const char *format, ...) +size_t RedirectablePrint::log(const char *logLevel, const char *format, ...) { size_t r = 0; @@ -86,9 +86,9 @@ size_t RedirectablePrint::logDebug(const char *format, ...) int min = (hms % SEC_PER_HOUR) / SEC_PER_MIN; int sec = (hms % SEC_PER_HOUR) % SEC_PER_MIN; // or hms % SEC_PER_MIN - r += printf("%02d:%02d:%02d %u ", hour, min, sec, millis() / 1000); + r += printf("%s | %02d:%02d:%02d %u ", logLevel, hour, min, sec, millis() / 1000); } else - r += printf("??:??:?? %u ", millis() / 1000); + r += printf("%s | ??:??:?? %u ", logLevel, millis() / 1000); auto thread = concurrency::OSThread::currentThread; if (thread) { @@ -99,7 +99,6 @@ size_t RedirectablePrint::logDebug(const char *format, ...) print("] "); } } - r += vprintf(format, arg); va_end(arg); diff --git a/src/RedirectablePrint.h b/src/RedirectablePrint.h index 9443d1672f..8fabd4a72b 100644 --- a/src/RedirectablePrint.h +++ b/src/RedirectablePrint.h @@ -34,7 +34,7 @@ class RedirectablePrint : public Print * log message. Otherwise we assume more prints will come before the log message ends. This * allows you to call logDebug a few times to build up a single log message line if you wish. */ - size_t logDebug(const char * format, ...) __attribute__ ((format (printf, 2, 3))); + size_t log(const char *logLevel, const char *format, ...) __attribute__ ((format (printf, 3, 4))); /** like printf but va_list based */ size_t vprintf(const char *format, va_list arg); From 819321529494fe66e510eec97497de69f628ec24 Mon Sep 17 00:00:00 2001 From: Ben Meadors Date: Fri, 30 Dec 2022 08:14:37 -0600 Subject: [PATCH 4/7] Trace --- src/DebugConfiguration.h | 2 ++ src/mesh/NodeDB.cpp | 20 ++++++++++---------- 2 files changed, 12 insertions(+), 10 deletions(-) diff --git a/src/DebugConfiguration.h b/src/DebugConfiguration.h index d82ea186ca..cae83cb182 100644 --- a/src/DebugConfiguration.h +++ b/src/DebugConfiguration.h @@ -17,6 +17,7 @@ #define LOG_LEVEL_INFO "INFO " #define LOG_LEVEL_WARN "WARN " #define LOG_LEVEL_ERROR "ERROR" +#define LOG_LEVEL_TRACE "TRACE" #include "SerialConsole.h" @@ -33,6 +34,7 @@ #define LOG_INFO(...) DEBUG_PORT.log(LOG_LEVEL_INFO, __VA_ARGS__) #define LOG_WARN(...) DEBUG_PORT.log(LOG_LEVEL_WARN, __VA_ARGS__) #define LOG_ERROR(...) DEBUG_PORT.log(LOG_LEVEL_ERROR, __VA_ARGS__) +#define LOG_TRACE(...) DEBUG_PORT.log(LOG_TRACE, __VA_ARGS__) #else #define LOG_DEBUG(...) #define LOG_INFO(...) diff --git a/src/mesh/NodeDB.cpp b/src/mesh/NodeDB.cpp index 57d462da21..e198c7065e 100644 --- a/src/mesh/NodeDB.cpp +++ b/src/mesh/NodeDB.cpp @@ -203,7 +203,7 @@ void NodeDB::initConfigIntervals() void NodeDB::installDefaultModuleConfig() { - LOG_DEBUG("Installing default ModuleConfig\n"); + LOG_INFO("Installing default ModuleConfig\n"); memset(&moduleConfig, 0, sizeof(ModuleConfig)); moduleConfig.version = DEVICESTATE_CUR_VER; @@ -230,7 +230,7 @@ void NodeDB::initModuleConfigIntervals() void NodeDB::installDefaultChannels() { - LOG_DEBUG("Installing default ChannelFile\n"); + LOG_INFO("Installing default ChannelFile\n"); memset(&channelFile, 0, sizeof(ChannelFile)); channelFile.version = DEVICESTATE_CUR_VER; } @@ -244,7 +244,7 @@ void NodeDB::resetNodes() void NodeDB::installDefaultDeviceState() { - LOG_DEBUG("Installing default DeviceState\n"); + LOG_INFO("Installing default DeviceState\n"); memset(&devicestate, 0, sizeof(DeviceState)); *numNodes = 0; @@ -275,7 +275,7 @@ void NodeDB::installDefaultDeviceState() void NodeDB::init() { - LOG_DEBUG("Initializing NodeDB\n"); + LOG_INFO("Initializing NodeDB\n"); loadFromDisk(); uint32_t devicestateCRC = crc32Buffer(&devicestate, sizeof(devicestate)); @@ -383,7 +383,7 @@ bool NodeDB::loadProto(const char *filename, size_t protoSize, size_t objSize, c memset(dest_struct, 0, objSize); if (!pb_decode(&stream, fields, dest_struct)) { - LOG_DEBUG("Error: can't decode protobuf %s\n", PB_GET_ERROR(&stream)); + LOG_ERROR("Error: can't decode protobuf %s\n", PB_GET_ERROR(&stream)); } else { okay = true; } @@ -393,7 +393,7 @@ bool NodeDB::loadProto(const char *filename, size_t protoSize, size_t objSize, c LOG_DEBUG("No %s preferences found\n", filename); } #else - LOG_DEBUG("ERROR: Filesystem not implemented\n"); + LOG_ERROR("ERROR: Filesystem not implemented\n"); #endif return okay; } @@ -405,7 +405,7 @@ void NodeDB::loadFromDisk() installDefaultDeviceState(); // Our in RAM copy might now be corrupt } else { if (devicestate.version < DEVICESTATE_MIN_VER) { - LOG_DEBUG("Warn: devicestate %d is old, discarding\n", devicestate.version); + LOG_WARN("Devicestate %d is old, discarding\n", devicestate.version); factoryReset(); } else { LOG_DEBUG("Loaded saved devicestate version %d\n", devicestate.version); @@ -416,7 +416,7 @@ void NodeDB::loadFromDisk() installDefaultConfig(); // Our in RAM copy might now be corrupt } else { if (config.version < DEVICESTATE_MIN_VER) { - LOG_DEBUG("Warn: config %d is old, discarding\n", config.version); + LOG_WARN("config %d is old, discarding\n", config.version); installDefaultConfig(); } else { LOG_DEBUG("Loaded saved config version %d\n", config.version); @@ -427,7 +427,7 @@ void NodeDB::loadFromDisk() installDefaultModuleConfig(); // Our in RAM copy might now be corrupt } else { if (moduleConfig.version < DEVICESTATE_MIN_VER) { - LOG_DEBUG("Warn: moduleConfig %d is old, discarding\n", moduleConfig.version); + LOG_WARN("moduleConfig %d is old, discarding\n", moduleConfig.version); installDefaultModuleConfig(); } else { LOG_DEBUG("Loaded saved moduleConfig version %d\n", moduleConfig.version); @@ -438,7 +438,7 @@ void NodeDB::loadFromDisk() installDefaultChannels(); // Our in RAM copy might now be corrupt } else { if (channelFile.version < DEVICESTATE_MIN_VER) { - LOG_DEBUG("Warn: channelFile %d is old, discarding\n", channelFile.version); + LOG_WARN("channelFile %d is old, discarding\n", channelFile.version); installDefaultChannels(); } else { LOG_DEBUG("Loaded saved channelFile version %d\n", channelFile.version); From f1cdfd163df371a0fd3926535e508556175f230d Mon Sep 17 00:00:00 2001 From: Ben Meadors Date: Fri, 30 Dec 2022 10:27:07 -0600 Subject: [PATCH 5/7] Replaced all of the logging with proper log levels --- src/ButtonThread.h | 2 +- src/FSCommon.cpp | 6 +- src/GPSStatus.h | 2 +- src/Power.cpp | 10 +- src/PowerFSM.cpp | 34 +++--- src/detect/einkScan.h | 4 +- src/detect/i2cScan.h | 52 ++++----- src/gps/GPS.cpp | 12 +- src/gps/NMEAGPS.cpp | 4 +- src/graphics/EInkDisplay2.cpp | 2 +- src/graphics/Screen.cpp | 10 +- src/graphics/TFTDisplay.cpp | 2 +- src/input/RotaryEncoderInterruptBase.cpp | 2 +- src/main.cpp | 14 +-- src/memtest.cpp | 2 +- src/mesh/FloodingRouter.cpp | 2 +- src/mesh/MeshModule.cpp | 4 +- src/mesh/MeshService.cpp | 8 +- src/mesh/NodeDB.cpp | 44 +++---- src/mesh/PhoneAPI.cpp | 34 +++--- src/mesh/ProtobufModule.h | 4 +- src/mesh/RF95Interface.cpp | 8 +- src/mesh/RadioInterface.cpp | 22 ++-- src/mesh/RadioLibInterface.cpp | 20 ++-- src/mesh/Router.cpp | 10 +- src/mesh/SX126xInterface.cpp | 10 +- src/mesh/SX128xInterface.cpp | 12 +- src/mesh/eth/ethClient.cpp | 30 ++--- src/mesh/eth/ethServerAPI.cpp | 8 +- src/mesh/http/ContentHandler.cpp | 18 +-- src/mesh/http/WebServer.cpp | 20 ++-- src/mesh/http/WiFiAPClient.cpp | 103 ++++++++--------- src/mesh/mesh-pb-constants.cpp | 4 +- src/mesh/wifi/WiFiServerAPI.cpp | 8 +- src/modules/AdminModule.cpp | 108 +++++++++--------- src/modules/CannedMessageModule.cpp | 6 +- src/modules/ExternalNotificationModule.cpp | 40 +++---- src/modules/NodeInfoModule.cpp | 4 +- src/modules/PositionModule.cpp | 16 +-- src/modules/RemoteHardwareModule.cpp | 8 +- src/modules/ReplyModule.cpp | 2 +- src/modules/SerialModule.cpp | 8 +- src/modules/Telemetry/DeviceTelemetry.cpp | 8 +- .../Telemetry/EnvironmentTelemetry.cpp | 12 +- src/modules/Telemetry/Sensor/BME280Sensor.cpp | 2 +- src/modules/Telemetry/Sensor/BME680Sensor.cpp | 2 +- src/modules/Telemetry/Sensor/BMP280Sensor.cpp | 2 +- src/modules/Telemetry/Sensor/INA219Sensor.cpp | 2 +- src/modules/Telemetry/Sensor/INA260Sensor.cpp | 2 +- .../Telemetry/Sensor/LPS22HBSensor.cpp | 2 +- .../Telemetry/Sensor/MCP9808Sensor.cpp | 2 +- src/modules/Telemetry/Sensor/SHT31Sensor.cpp | 2 +- src/modules/Telemetry/Sensor/SHTC3Sensor.cpp | 2 +- .../Telemetry/Sensor/TelemetrySensor.h | 4 +- src/modules/TextMessageModule.cpp | 2 +- src/modules/TraceRouteModule.cpp | 8 +- src/modules/WaypointModule.cpp | 2 +- src/modules/esp32/AudioModule.cpp | 28 ++--- src/modules/esp32/RangeTestModule.cpp | 33 +++--- src/modules/esp32/StoreForwardModule.cpp | 46 ++++---- src/mqtt/MQTT.cpp | 54 ++++----- src/nimble/NimbleBluetooth.cpp | 20 ++-- src/platform/esp32/SimpleAllocator.cpp | 4 +- src/platform/nrf52/NRF52Bluetooth.cpp | 46 ++++---- src/platform/nrf52/main-nrf52.cpp | 9 +- src/platform/portduino/SimRadio.cpp | 6 +- src/shutdown.h | 8 +- src/sleep.cpp | 16 +-- 68 files changed, 519 insertions(+), 524 deletions(-) diff --git a/src/ButtonThread.h b/src/ButtonThread.h index d1076c326e..d94b6a769e 100644 --- a/src/ButtonThread.h +++ b/src/ButtonThread.h @@ -139,7 +139,7 @@ class ButtonThread : public concurrency::OSThread // may wake the board immediatedly. if ((!shutdown_on_long_stop) && (millis() > 30 * 1000)) { screen->startShutdownScreen(); - LOG_DEBUG("Shutdown from long press"); + LOG_INFO("Shutdown from long press"); playBeep(); #ifdef PIN_LED1 ledOff(PIN_LED1); diff --git a/src/FSCommon.cpp b/src/FSCommon.cpp index 2f901d26af..73d5d92b3c 100644 --- a/src/FSCommon.cpp +++ b/src/FSCommon.cpp @@ -21,13 +21,13 @@ bool copyFile(const char* from, const char* to) File f1 = FSCom.open(from, FILE_O_READ); if (!f1){ - LOG_DEBUG("Failed to open source file %s\n", from); + LOG_ERROR("Failed to open source file %s\n", from); return false; } File f2 = FSCom.open(to, FILE_O_WRITE); if (!f2) { - LOG_DEBUG("Failed to open destination file %s\n", to); + LOG_ERROR("Failed to open destination file %s\n", to); return false; } @@ -170,7 +170,7 @@ void fsInit() #ifdef FSCom if (!FSBegin()) { - LOG_DEBUG("ERROR filesystem mount Failed. Formatting...\n"); + LOG_ERROR("Filesystem mount Failed. Formatting...\n"); assert(0); // FIXME - report failure to phone } #ifdef ARCH_ESP32 diff --git a/src/GPSStatus.h b/src/GPSStatus.h index 9ada4e66e8..c76b661032 100644 --- a/src/GPSStatus.h +++ b/src/GPSStatus.h @@ -114,7 +114,7 @@ class GPSStatus : public Status if (isDirty && p.timestamp && (newStatus->p.timestamp == p.timestamp)) { // We can NEVER be in two locations at the same time! (also PR #886) - LOG_DEBUG("BUG!! positional timestamp unchanged from prev solution\n"); + LOG_ERROR("BUG: Positional timestamp unchanged from prev solution\n"); } initialized = true; diff --git a/src/Power.cpp b/src/Power.cpp index bba21549b5..7f6dd92a0b 100644 --- a/src/Power.cpp +++ b/src/Power.cpp @@ -242,7 +242,7 @@ void Power::shutdown() #endif #ifdef HAS_PMU - LOG_DEBUG("Shutting down\n"); + LOG_INFO("Shutting down\n"); if(PMU) { PMU->setChargingLedMode(XPOWERS_CHG_LED_OFF); PMU->shutdown(); @@ -333,12 +333,12 @@ int32_t Power::runOnce() PMU->getIrqStatus(); if(PMU->isVbusRemoveIrq()){ - LOG_DEBUG("USB unplugged\n"); + LOG_INFO("USB unplugged\n"); powerFSM.trigger(EVENT_POWER_DISCONNECTED); } if (PMU->isVbusInsertIrq()) { - LOG_DEBUG("USB plugged In\n"); + LOG_INFO("USB plugged In\n"); powerFSM.trigger(EVENT_POWER_CONNECTED); } @@ -405,7 +405,7 @@ bool Power::axpChipInit() delete PMU; PMU = NULL; } else { - LOG_DEBUG("AXP2101 PMU init succeeded, using AXP2101 PMU\n"); + LOG_INFO("AXP2101 PMU init succeeded, using AXP2101 PMU\n"); } } @@ -416,7 +416,7 @@ bool Power::axpChipInit() delete PMU; PMU = NULL; } else { - LOG_DEBUG("AXP192 PMU init succeeded, using AXP192 PMU\n"); + LOG_INFO("AXP192 PMU init succeeded, using AXP192 PMU\n"); } } diff --git a/src/PowerFSM.cpp b/src/PowerFSM.cpp index f35e755cac..d5235c00b5 100644 --- a/src/PowerFSM.cpp +++ b/src/PowerFSM.cpp @@ -32,7 +32,7 @@ static bool isPowered() static void sdsEnter() { - LOG_DEBUG("Enter state: SDS\n"); + LOG_INFO("Enter state: SDS\n"); // FIXME - make sure GPS and LORA radio are off first - because we want close to zero current draw doDeepSleep(getConfiguredOrDefaultMs(config.power.sds_secs)); } @@ -41,7 +41,7 @@ extern Power *power; static void shutdownEnter() { - LOG_DEBUG("Enter state: SHUTDOWN\n"); + LOG_INFO("Enter state: SHUTDOWN\n"); power->shutdown(); } @@ -51,16 +51,16 @@ static uint32_t secsSlept; static void lsEnter() { - LOG_DEBUG("lsEnter begin, ls_secs=%u\n", config.power.ls_secs); + LOG_INFO("lsEnter begin, ls_secs=%u\n", config.power.ls_secs); screen->setOn(false); secsSlept = 0; // How long have we been sleeping this time - // LOG_DEBUG("lsEnter end\n"); + // LOG_INFO("lsEnter end\n"); } static void lsIdle() { - // LOG_DEBUG("lsIdle begin ls_secs=%u\n", getPref_ls_secs()); + // LOG_INFO("lsIdle begin ls_secs=%u\n", getPref_ls_secs()); #ifdef ARCH_ESP32 @@ -82,7 +82,7 @@ static void lsIdle() wakeCause2 = doLightSleep(1); // leave led on for 1ms secsSlept += sleepTime; - // LOG_DEBUG("sleeping, flash led!\n"); + // LOG_INFO("sleeping, flash led!\n"); break; case ESP_SLEEP_WAKEUP_UART: @@ -93,7 +93,7 @@ static void lsIdle() default: // We woke for some other reason (button press, device interrupt) // uint64_t status = esp_sleep_get_ext1_wakeup_status(); - LOG_DEBUG("wakeCause2 %d\n", wakeCause2); + LOG_INFO("wakeCause2 %d\n", wakeCause2); #ifdef BUTTON_PIN bool pressed = !digitalRead(BUTTON_PIN); @@ -117,7 +117,7 @@ static void lsIdle() } else { // Time to stop sleeping! setLed(false); - LOG_DEBUG("reached ls_secs, servicing loop()\n"); + LOG_INFO("Reached ls_secs, servicing loop()\n"); powerFSM.trigger(EVENT_WAKE_TIMER); } #endif @@ -125,7 +125,7 @@ static void lsIdle() static void lsExit() { - LOG_DEBUG("Exit state: LS\n"); + LOG_INFO("Exit state: LS\n"); // setGPSPower(true); // restore GPS power if (gps) gps->forceWake(true); @@ -133,7 +133,7 @@ static void lsExit() static void nbEnter() { - LOG_DEBUG("Enter state: NB\n"); + LOG_INFO("Enter state: NB\n"); screen->setOn(false); setBluetoothEnable(false); @@ -148,7 +148,7 @@ static void darkEnter() static void serialEnter() { - LOG_DEBUG("Enter state: SERIAL\n"); + LOG_INFO("Enter state: SERIAL\n"); setBluetoothEnable(false); screen->setOn(true); screen->print("Serial connected\n"); @@ -161,10 +161,10 @@ static void serialExit() static void powerEnter() { - LOG_DEBUG("Enter state: POWER\n"); + LOG_INFO("Enter state: POWER\n"); if (!isPowered()) { // If we got here, we are in the wrong state - we should be in powered, let that state ahndle things - LOG_DEBUG("Loss of power in Powered\n"); + LOG_INFO("Loss of power in Powered\n"); powerFSM.trigger(EVENT_POWER_DISCONNECTED); } else { screen->setOn(true); @@ -177,7 +177,7 @@ static void powerIdle() { if (!isPowered()) { // If we got here, we are in the wrong state - LOG_DEBUG("Loss of power in Powered\n"); + LOG_INFO("Loss of power in Powered\n"); powerFSM.trigger(EVENT_POWER_DISCONNECTED); } } @@ -191,7 +191,7 @@ static void powerExit() static void onEnter() { - LOG_DEBUG("Enter state: ON\n"); + LOG_INFO("Enter state: ON\n"); screen->setOn(true); setBluetoothEnable(true); @@ -221,7 +221,7 @@ static void screenPress() static void bootEnter() { - LOG_DEBUG("Enter state: BOOT\n"); + LOG_INFO("Enter state: BOOT\n"); } State stateSHUTDOWN(shutdownEnter, NULL, NULL, "SHUTDOWN"); @@ -240,7 +240,7 @@ void PowerFSM_setup() bool isRouter = (config.device.role == Config_DeviceConfig_Role_ROUTER ? 1 : 0); bool hasPower = isPowered(); - LOG_DEBUG("PowerFSM init, USB power=%d\n", hasPower ? 1 : 0); + LOG_INFO("PowerFSM init, USB power=%d\n", hasPower ? 1 : 0); powerFSM.add_timed_transition(&stateBOOT, hasPower ? &statePOWER : &stateON, 3 * 1000, NULL, "boot timeout"); // wake timer expired or a packet arrived diff --git a/src/detect/einkScan.h b/src/detect/einkScan.h index dd2bf01c26..a7a855709f 100644 --- a/src/detect/einkScan.h +++ b/src/detect/einkScan.h @@ -52,9 +52,9 @@ void scanEInkDevice(void) d_writeCommand(0x20); eink_found = (d_waitWhileBusy(150) > 0) ? true : false; if(eink_found) - LOG_DEBUG("EInk display found\n"); + LOG_DEBUG("EInk display found\n"); else - LOG_DEBUG("EInk display not found\n"); + LOG_DEBUG("EInk display not found\n"); SPI1.end(); } #endif diff --git a/src/detect/i2cScan.h b/src/detect/i2cScan.h index f2ebc18b8c..77d1fff171 100644 --- a/src/detect/i2cScan.h +++ b/src/detect/i2cScan.h @@ -107,20 +107,20 @@ void scanI2Cdevice() screen_found = addr; screen_model = oled_probe(addr); if (screen_model == 1) { - LOG_DEBUG("ssd1306 display found\n"); + LOG_INFO("ssd1306 display found\n"); } else if (screen_model == 2) { - LOG_DEBUG("sh1106 display found\n"); + LOG_INFO("sh1106 display found\n"); } else { - LOG_DEBUG("unknown display found\n"); + LOG_INFO("unknown display found\n"); } } #if !defined(ARCH_PORTDUINO) && !defined(ARCH_STM32WL) if (addr == ATECC608B_ADDR) { keystore_found = addr; if (atecc.begin(keystore_found) == true) { - LOG_DEBUG("ATECC608B initialized\n"); + LOG_INFO("ATECC608B initialized\n"); } else { - LOG_DEBUG("ATECC608B initialization failed\n"); + LOG_WARN("ATECC608B initialization failed\n"); } printATECCInfo(); } @@ -128,7 +128,7 @@ void scanI2Cdevice() #ifdef RV3028_RTC if (addr == RV3028_RTC){ rtc_found = addr; - LOG_DEBUG("RV3028 RTC found\n"); + LOG_INFO("RV3028 RTC found\n"); Melopero_RV3028 rtc; rtc.initI2C(); rtc.writeToRegister(0x35,0x07); // no Clkout @@ -138,7 +138,7 @@ void scanI2Cdevice() #ifdef PCF8563_RTC if (addr == PCF8563_RTC){ rtc_found = addr; - LOG_DEBUG("PCF8563 RTC found\n"); + LOG_INFO("PCF8563 RTC found\n"); } #endif if (addr == CARDKB_ADDR) { @@ -146,33 +146,33 @@ void scanI2Cdevice() // Do we have the RAK14006 instead? registerValue = getRegisterValue(addr, 0x04, 1); if (registerValue == 0x02) { // KEYPAD_VERSION - LOG_DEBUG("RAK14004 found\n"); + LOG_INFO("RAK14004 found\n"); kb_model = 0x02; } else { - LOG_DEBUG("m5 cardKB found\n"); + LOG_INFO("m5 cardKB found\n"); kb_model = 0x00; } } if (addr == ST7567_ADDRESS) { screen_found = addr; - LOG_DEBUG("st7567 display found\n"); + LOG_INFO("st7567 display found\n"); } #ifdef HAS_PMU if (addr == XPOWERS_AXP192_AXP2101_ADDRESS) { pmu_found = true; - LOG_DEBUG("axp192/axp2101 PMU found\n"); + LOG_INFO("axp192/axp2101 PMU found\n"); } #endif if (addr == BME_ADDR || addr == BME_ADDR_ALTERNATE) { registerValue = getRegisterValue(addr, 0xD0, 1); // GET_ID if (registerValue == 0x61) { - LOG_DEBUG("BME-680 sensor found at address 0x%x\n", (uint8_t)addr); + LOG_INFO("BME-680 sensor found at address 0x%x\n", (uint8_t)addr); nodeTelemetrySensorsMap[TelemetrySensorType_BME680] = addr; } else if (registerValue == 0x60) { - LOG_DEBUG("BME-280 sensor found at address 0x%x\n", (uint8_t)addr); + LOG_INFO("BME-280 sensor found at address 0x%x\n", (uint8_t)addr); nodeTelemetrySensorsMap[TelemetrySensorType_BME280] = addr; } else { - LOG_DEBUG("BMP-280 sensor found at address 0x%x\n", (uint8_t)addr); + LOG_INFO("BMP-280 sensor found at address 0x%x\n", (uint8_t)addr); nodeTelemetrySensorsMap[TelemetrySensorType_BMP280] = addr; } } @@ -180,52 +180,52 @@ void scanI2Cdevice() registerValue = getRegisterValue(addr, 0xFE, 2); LOG_DEBUG("Register MFG_UID: 0x%x\n", registerValue); if (registerValue == 0x5449) { - LOG_DEBUG("INA260 sensor found at address 0x%x\n", (uint8_t)addr); + LOG_INFO("INA260 sensor found at address 0x%x\n", (uint8_t)addr); nodeTelemetrySensorsMap[TelemetrySensorType_INA260] = addr; } else { // Assume INA219 if INA260 ID is not found - LOG_DEBUG("INA219 sensor found at address 0x%x\n", (uint8_t)addr); + LOG_INFO("INA219 sensor found at address 0x%x\n", (uint8_t)addr); nodeTelemetrySensorsMap[TelemetrySensorType_INA219] = addr; } } if (addr == MCP9808_ADDR) { nodeTelemetrySensorsMap[TelemetrySensorType_MCP9808] = addr; - LOG_DEBUG("MCP9808 sensor found\n"); + LOG_INFO("MCP9808 sensor found\n"); } if (addr == SHT31_ADDR) { - LOG_DEBUG("SHT31 sensor found\n"); + LOG_INFO("SHT31 sensor found\n"); nodeTelemetrySensorsMap[TelemetrySensorType_SHT31] = addr; } if (addr == SHTC3_ADDR) { - LOG_DEBUG("SHTC3 sensor found\n"); + LOG_INFO("SHTC3 sensor found\n"); nodeTelemetrySensorsMap[TelemetrySensorType_SHTC3] = addr; } if (addr == LPS22HB_ADDR || addr == LPS22HB_ADDR_ALT) { - LOG_DEBUG("LPS22HB sensor found\n"); + LOG_INFO("LPS22HB sensor found\n"); nodeTelemetrySensorsMap[TelemetrySensorType_LPS22] = addr; } // High rate sensors, will be processed internally if (addr == QMC6310_ADDR) { - LOG_DEBUG("QMC6310 Highrate 3-Axis magnetic sensor found\n"); + LOG_INFO("QMC6310 Highrate 3-Axis magnetic sensor found\n"); nodeTelemetrySensorsMap[TelemetrySensorType_QMC6310] = addr; } if (addr == QMI8658_ADDR) { - LOG_DEBUG("QMI8658 Highrate 6-Axis inertial measurement sensor found\n"); + LOG_INFO("QMI8658 Highrate 6-Axis inertial measurement sensor found\n"); nodeTelemetrySensorsMap[TelemetrySensorType_QMI8658] = addr; } if (addr == QMC5883L_ADDR) { - LOG_DEBUG("QMC5883L Highrate 3-Axis magnetic sensor found\n"); + LOG_INFO("QMC5883L Highrate 3-Axis magnetic sensor found\n"); nodeTelemetrySensorsMap[TelemetrySensorType_QMC5883L] = addr; } } else if (err == 4) { - LOG_DEBUG("Unknow error at address 0x%x\n", addr); + LOG_ERROR("Unknow error at address 0x%x\n", addr); } } if (nDevices == 0) - LOG_DEBUG("No I2C devices found\n"); + LOG_INFO("No I2C devices found\n"); else - LOG_DEBUG("%i I2C devices found\n",nDevices); + LOG_INFO("%i I2C devices found\n",nDevices); } #else void scanI2Cdevice() {} diff --git a/src/gps/GPS.cpp b/src/gps/GPS.cpp index d8c33a5ea4..7eec132283 100644 --- a/src/gps/GPS.cpp +++ b/src/gps/GPS.cpp @@ -361,7 +361,7 @@ void GPS::setNumSatellites(uint8_t n) void GPS::setAwake(bool on) { if (!wakeAllowed && on) { - LOG_DEBUG("Inhibiting because !wakeAllowed\n"); + LOG_WARN("Inhibiting because !wakeAllowed\n"); on = false; } @@ -516,7 +516,7 @@ void GPS::forceWake(bool on) /// Prepare the GPS for the cpu entering deep or light sleep, expect to be gone for at least 100s of msecs int GPS::prepareSleep(void *unused) { - LOG_DEBUG("GPS prepare sleep!\n"); + LOG_INFO("GPS prepare sleep!\n"); forceWake(false); return 0; @@ -525,7 +525,7 @@ int GPS::prepareSleep(void *unused) /// Prepare the GPS for the cpu entering deep or light sleep, expect to be gone for at least 100s of msecs int GPS::prepareDeepSleep(void *unused) { - LOG_DEBUG("GPS deep sleep!\n"); + LOG_INFO("GPS deep sleep!\n"); // For deep sleep we also want abandon any lock attempts (because we want minimum power) getSleepTime(); @@ -568,7 +568,7 @@ GnssModel_t GPS::probe() if(index != -1){ ver = ver.substring(index); if (ver.startsWith("$GPTXT,01,01,02")) { - LOG_DEBUG("L76K GNSS init succeeded, using L76K GNSS Module\n"); + LOG_INFO("L76K GNSS init succeeded, using L76K GNSS Module\n"); return GNSS_MODEL_MTK; } } @@ -631,9 +631,9 @@ GnssModel_t GPS::probe() } if (strlen((char*)buffer)) { - LOG_DEBUG("UBlox GNSS init succeeded, using UBlox %s GNSS Module\n" , buffer); + LOG_INFO("UBlox GNSS init succeeded, using UBlox %s GNSS Module\n" , buffer); }else{ - LOG_DEBUG("UBlox GNSS init succeeded, using UBlox GNSS Module\n"); + LOG_INFO("UBlox GNSS init succeeded, using UBlox GNSS Module\n"); } return GNSS_MODEL_UBLOX; diff --git a/src/gps/NMEAGPS.cpp b/src/gps/NMEAGPS.cpp index a99b558732..a89083c0e1 100644 --- a/src/gps/NMEAGPS.cpp +++ b/src/gps/NMEAGPS.cpp @@ -137,7 +137,7 @@ bool NMEAGPS::lookForLocation() (reader.time.age() < GPS_SOL_EXPIRY_MS) && (reader.date.age() < GPS_SOL_EXPIRY_MS))) { - LOG_DEBUG("SOME data is TOO OLD: LOC %u, TIME %u, DATE %u\n", reader.location.age(), reader.time.age(), reader.date.age()); + LOG_WARN("SOME data is TOO OLD: LOC %u, TIME %u, DATE %u\n", reader.location.age(), reader.time.age(), reader.date.age()); return false; } @@ -212,7 +212,7 @@ bool NMEAGPS::lookForLocation() if (reader.course.value() < 36000) { // sanity check p.ground_track = reader.course.value() * 1e3; // Scale the heading (in degrees * 10^-2) to match the expected degrees * 10^-5 } else { - LOG_DEBUG("BOGUS course.value() REJECTED: %d\n", + LOG_WARN("BOGUS course.value() REJECTED: %d\n", reader.course.value()); } } diff --git a/src/graphics/EInkDisplay2.cpp b/src/graphics/EInkDisplay2.cpp index a7ec5e0560..07fcd2c46c 100644 --- a/src/graphics/EInkDisplay2.cpp +++ b/src/graphics/EInkDisplay2.cpp @@ -162,7 +162,7 @@ void EInkDisplay::setDetected(uint8_t detected) // Connect to the display bool EInkDisplay::connect() { - LOG_DEBUG("Doing EInk init\n"); + LOG_INFO("Doing EInk init\n"); #ifdef PIN_EINK_PWR_ON digitalWrite(PIN_EINK_PWR_ON, HIGH); // If we need to assert a pin to power external peripherals diff --git a/src/graphics/Screen.cpp b/src/graphics/Screen.cpp index 426d5f2cd2..53ca75a51f 100644 --- a/src/graphics/Screen.cpp +++ b/src/graphics/Screen.cpp @@ -936,14 +936,14 @@ void Screen::handleSetOn(bool on) if (on != screenOn) { if (on) { - LOG_DEBUG("Turning on screen\n"); + LOG_INFO("Turning on screen\n"); dispdev.displayOn(); dispdev.displayOn(); enabled = true; setInterval(0); // Draw ASAP runASAP = true; } else { - LOG_DEBUG("Turning off screen\n"); + LOG_INFO("Turning off screen\n"); dispdev.displayOff(); enabled = false; } @@ -1056,7 +1056,7 @@ int32_t Screen::runOnce() // serialSinceMsec adjusts for additional serial wait time during nRF52 bootup static bool showingBootScreen = true; if (showingBootScreen && (millis() > (logo_timeout + serialSinceMsec))) { - LOG_DEBUG("Done with boot screen...\n"); + LOG_INFO("Done with boot screen...\n"); stopBootScreen(); showingBootScreen = false; } @@ -1065,7 +1065,7 @@ int32_t Screen::runOnce() if (strlen(oemStore.oem_text) > 0) { static bool showingOEMBootScreen = true; if (showingOEMBootScreen && (millis() > ((logo_timeout / 2) + serialSinceMsec))) { - LOG_DEBUG("Switch to OEM screen...\n"); + LOG_INFO("Switch to OEM screen...\n"); // Change frames. static FrameCallback bootOEMFrames[] = {drawOEMBootScreen}; static const int bootOEMFrameCount = sizeof(bootOEMFrames) / sizeof(bootOEMFrames[0]); @@ -1127,7 +1127,7 @@ int32_t Screen::runOnce() handleRebootScreen(); break; default: - LOG_DEBUG("BUG: invalid cmd\n"); + LOG_ERROR("Invalid screen cmd\n"); } } diff --git a/src/graphics/TFTDisplay.cpp b/src/graphics/TFTDisplay.cpp index 083ee273c7..670c0f1625 100644 --- a/src/graphics/TFTDisplay.cpp +++ b/src/graphics/TFTDisplay.cpp @@ -59,7 +59,7 @@ void TFTDisplay::setDetected(uint8_t detected) bool TFTDisplay::connect() { concurrency::LockGuard g(spiLock); - LOG_DEBUG("Doing TFT init\n"); + LOG_INFO("Doing TFT init\n"); #ifdef TFT_BL digitalWrite(TFT_BL, HIGH); diff --git a/src/input/RotaryEncoderInterruptBase.cpp b/src/input/RotaryEncoderInterruptBase.cpp index 0f75c3a5af..7a71e5d961 100644 --- a/src/input/RotaryEncoderInterruptBase.cpp +++ b/src/input/RotaryEncoderInterruptBase.cpp @@ -28,7 +28,7 @@ void RotaryEncoderInterruptBase::init( this->rotaryLevelA = digitalRead(this->_pinA); this->rotaryLevelB = digitalRead(this->_pinB); - LOG_DEBUG("Rotary initialized (%d, %d, %d)\n", this->_pinA, this->_pinB, pinPress); + LOG_INFO("Rotary initialized (%d, %d, %d)\n", this->_pinA, this->_pinB, pinPress); } int32_t RotaryEncoderInterruptBase::runOnce() diff --git a/src/main.cpp b/src/main.cpp index 6f25ac1f7e..af7f28b503 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -256,7 +256,7 @@ void setup() Wire1.beginTransmission(PCF8563_RTC); if (Wire1.endTransmission() == 0){ rtc_found = PCF8563_RTC; - LOG_DEBUG("PCF8563 RTC found\n"); + LOG_INFO("PCF8563 RTC found\n"); } #endif @@ -378,7 +378,7 @@ void setup() delete rIf; rIf = NULL; } else { - LOG_DEBUG("RF95 Radio init succeeded, using RF95 radio\n"); + LOG_INFO("RF95 Radio init succeeded, using RF95 radio\n"); } } #endif @@ -391,7 +391,7 @@ void setup() delete rIf; rIf = NULL; } else { - LOG_DEBUG("SX1280 Radio init succeeded, using SX1280 radio\n"); + LOG_INFO("SX1280 Radio init succeeded, using SX1280 radio\n"); } } #endif @@ -404,7 +404,7 @@ void setup() delete rIf; rIf = NULL; } else { - LOG_DEBUG("SX1262 Radio init succeeded, using SX1262 radio\n"); + LOG_INFO("SX1262 Radio init succeeded, using SX1262 radio\n"); } } #endif @@ -417,7 +417,7 @@ void setup() delete rIf; rIf = NULL; } else { - LOG_DEBUG("SX1268 Radio init succeeded, using SX1268 radio\n"); + LOG_INFO("SX1268 Radio init succeeded, using SX1268 radio\n"); } } #endif @@ -430,7 +430,7 @@ void setup() delete rIf; rIf = NULL; } else { - LOG_DEBUG("LLCC68 Radio init succeeded, using LLCC68 radio\n"); + LOG_INFO("LLCC68 Radio init succeeded, using LLCC68 radio\n"); } } #endif @@ -443,7 +443,7 @@ void setup() delete rIf; rIf = NULL; } else { - LOG_DEBUG("Using SIMULATED radio!\n"); + LOG_INFO("Using SIMULATED radio!\n"); } } #endif diff --git a/src/memtest.cpp b/src/memtest.cpp index f5fe3d7d28..20a4bfa534 100644 --- a/src/memtest.cpp +++ b/src/memtest.cpp @@ -270,7 +270,7 @@ static int mem_test(uint32_t *_start, size_t len, bool doRead = true, bool doWri for (addr = start, val = pattern; addr < end; addr++) { readback = *addr; if (readback != val) { - LOG_DEBUG("Mem error @ 0x%08X: " + LOG_ERROR("Mem error @ 0x%08X: " "found 0x%08lX, expected 0x%08lX\n", addr, readback, val); rcode++; diff --git a/src/mesh/FloodingRouter.cpp b/src/mesh/FloodingRouter.cpp index 568af182de..b6c093e222 100644 --- a/src/mesh/FloodingRouter.cpp +++ b/src/mesh/FloodingRouter.cpp @@ -47,7 +47,7 @@ void FloodingRouter::sniffReceived(const MeshPacket *p, const Routing *c) traceRouteModule->updateRoute(tosend); } - printPacket("Rebroadcasting received floodmsg to neighbors", p); + LOG_INFO("Rebroadcasting received floodmsg to neighbors", p); // Note: we are careful to resend using the original senders node id // We are careful not to call our hooked version of send() - because we don't want to check this again Router::send(tosend); diff --git a/src/mesh/MeshModule.cpp b/src/mesh/MeshModule.cpp index fe5e3d81ea..34a40d7955 100644 --- a/src/mesh/MeshModule.cpp +++ b/src/mesh/MeshModule.cpp @@ -52,7 +52,7 @@ MeshPacket *MeshModule::allocAckNak(Routing_Error err, NodeNum to, PacketId idFr p->to = to; p->decoded.request_id = idFrom; p->channel = chIndex; - LOG_DEBUG("Alloc an err=%d,to=0x%x,idFrom=0x%x,id=0x%x\n", err, to, idFrom, p->id); + LOG_ERROR("Alloc an err=%d,to=0x%x,idFrom=0x%x,id=0x%x\n", err, to, idFrom, p->id); return p; } @@ -134,7 +134,7 @@ void MeshModule::callPlugins(const MeshPacket &mp, RxSource src) // any other node. if (mp.decoded.want_response && toUs && (getFrom(&mp) != ourNodeNum || mp.to == ourNodeNum) && !currentReply) { pi.sendResponse(mp); - LOG_DEBUG("Module '%s' sent a response\n", pi.name); + LOG_INFO("Module '%s' sent a response\n", pi.name); } else { LOG_DEBUG("Module '%s' considered\n", pi.name); } diff --git a/src/mesh/MeshService.cpp b/src/mesh/MeshService.cpp index 6ac7321dac..c300104a45 100644 --- a/src/mesh/MeshService.cpp +++ b/src/mesh/MeshService.cpp @@ -140,7 +140,7 @@ void MeshService::handleToRadio(MeshPacket &p) // Switch the port from PortNum_SIMULATOR_APP back to the original PortNum p.decoded.portnum = decoded->portnum; } else - LOG_DEBUG("Error decoding protobuf for simulator message!\n"); + LOG_ERROR("Error decoding protobuf for simulator message!\n"); } // Let SimRadio receive as if it did via its LoRa chip SimRadio::instance->startReceive(&p); @@ -198,12 +198,12 @@ void MeshService::sendNetworkPing(NodeNum dest, bool wantReplies) if (node->has_position && (node->position.latitude_i != 0 || node->position.longitude_i != 0)) { if (positionModule) { - LOG_DEBUG("Sending position ping to 0x%x, wantReplies=%d\n", dest, wantReplies); + LOG_INFO("Sending position ping to 0x%x, wantReplies=%d\n", dest, wantReplies); positionModule->sendOurPosition(dest, wantReplies); } } else { if (nodeInfoModule) { - LOG_DEBUG("Sending nodeinfo ping to 0x%x, wantReplies=%d\n", dest, wantReplies); + LOG_INFO("Sending nodeinfo ping to 0x%x, wantReplies=%d\n", dest, wantReplies); nodeInfoModule->sendOurNodeInfo(dest, wantReplies); } } @@ -212,7 +212,7 @@ void MeshService::sendNetworkPing(NodeNum dest, bool wantReplies) void MeshService::sendToPhone(MeshPacket *p) { if (toPhoneQueue.numFree() == 0) { - LOG_DEBUG("NOTE: tophone queue is full, discarding oldest\n"); + LOG_WARN("ToPhone queue is full, discarding oldest\n"); MeshPacket *d = toPhoneQueue.dequeuePtr(0); if (d) releaseToPool(d); diff --git a/src/mesh/NodeDB.cpp b/src/mesh/NodeDB.cpp index e198c7065e..e995e0b227 100644 --- a/src/mesh/NodeDB.cpp +++ b/src/mesh/NodeDB.cpp @@ -86,7 +86,7 @@ bool NodeDB::resetRadioConfig(bool factory_reset) } if (channelFile.channels_count != MAX_NUM_CHANNELS) { - LOG_DEBUG("Setting default channel and radio preferences!\n"); + LOG_INFO("Setting default channel and radio preferences!\n"); channels.initDefaults(); } @@ -114,7 +114,7 @@ bool NodeDB::resetRadioConfig(bool factory_reset) initRegion(); if (didFactoryReset) { - LOG_DEBUG("Rebooting due to factory reset"); + LOG_INFO("Rebooting due to factory reset"); screen->startRebootScreen(); rebootAtMsec = millis() + (5 * 1000); } @@ -124,7 +124,7 @@ bool NodeDB::resetRadioConfig(bool factory_reset) bool NodeDB::factoryReset() { - LOG_DEBUG("Performing factory reset!\n"); + LOG_INFO("Performing factory reset!\n"); // first, remove the "/prefs" (this removes most prefs) rmDir("/prefs"); // second, install default state (this will deal with the duplicate mac address issue) @@ -140,7 +140,7 @@ bool NodeDB::factoryReset() #endif #ifdef ARCH_NRF52 Bluefruit.begin(); - LOG_DEBUG("Clearing bluetooth bonds!\n"); + LOG_INFO("Clearing bluetooth bonds!\n"); bond_print_list(BLE_GAP_ROLE_PERIPH); bond_print_list(BLE_GAP_ROLE_CENTRAL); Bluefruit.Periph.clearBonds(); @@ -151,7 +151,7 @@ bool NodeDB::factoryReset() void NodeDB::installDefaultConfig() { - LOG_DEBUG("Installing default LocalConfig\n"); + LOG_INFO("Installing default LocalConfig\n"); memset(&config, 0, sizeof(LocalConfig)); config.version = DEVICESTATE_CUR_VER; config.has_device = true; @@ -376,7 +376,7 @@ bool NodeDB::loadProto(const char *filename, size_t protoSize, size_t objSize, c auto f = FSCom.open(filename, FILE_O_READ); if (f) { - LOG_DEBUG("Loading %s\n", filename); + LOG_INFO("Loading %s\n", filename); pb_istream_t stream = {&readcb, &f, protoSize}; // LOG_DEBUG("Preload channel name=%s\n", channelSettings.name); @@ -390,7 +390,7 @@ bool NodeDB::loadProto(const char *filename, size_t protoSize, size_t objSize, c f.close(); } else { - LOG_DEBUG("No %s preferences found\n", filename); + LOG_INFO("No %s preferences found\n", filename); } #else LOG_ERROR("ERROR: Filesystem not implemented\n"); @@ -408,7 +408,7 @@ void NodeDB::loadFromDisk() LOG_WARN("Devicestate %d is old, discarding\n", devicestate.version); factoryReset(); } else { - LOG_DEBUG("Loaded saved devicestate version %d\n", devicestate.version); + LOG_INFO("Loaded saved devicestate version %d\n", devicestate.version); } } @@ -419,7 +419,7 @@ void NodeDB::loadFromDisk() LOG_WARN("config %d is old, discarding\n", config.version); installDefaultConfig(); } else { - LOG_DEBUG("Loaded saved config version %d\n", config.version); + LOG_INFO("Loaded saved config version %d\n", config.version); } } @@ -430,7 +430,7 @@ void NodeDB::loadFromDisk() LOG_WARN("moduleConfig %d is old, discarding\n", moduleConfig.version); installDefaultModuleConfig(); } else { - LOG_DEBUG("Loaded saved moduleConfig version %d\n", moduleConfig.version); + LOG_INFO("Loaded saved moduleConfig version %d\n", moduleConfig.version); } } @@ -441,12 +441,12 @@ void NodeDB::loadFromDisk() LOG_WARN("channelFile %d is old, discarding\n", channelFile.version); installDefaultChannels(); } else { - LOG_DEBUG("Loaded saved channelFile version %d\n", channelFile.version); + LOG_INFO("Loaded saved channelFile version %d\n", channelFile.version); } } if (loadProto(oemConfigFile, OEMStore_size, sizeof(OEMStore), &OEMStore_msg, &oemStore)) - LOG_DEBUG("Loaded OEMStore\n"); + LOG_INFO("Loaded OEMStore\n"); } /** Save a protobuf from a file, return true for success */ @@ -459,11 +459,11 @@ bool NodeDB::saveProto(const char *filename, size_t protoSize, const pb_msgdesc_ filenameTmp += ".tmp"; auto f = FSCom.open(filenameTmp.c_str(), FILE_O_WRITE); if (f) { - LOG_DEBUG("Saving %s\n", filename); + LOG_INFO("Saving %s\n", filename); pb_ostream_t stream = {&writecb, &f, protoSize}; if (!pb_encode(&stream, fields, dest_struct)) { - LOG_DEBUG("Error: can't encode protobuf %s\n", PB_GET_ERROR(&stream)); + LOG_ERROR("Error: can't encode protobuf %s\n", PB_GET_ERROR(&stream)); } else { okay = true; } @@ -473,9 +473,9 @@ bool NodeDB::saveProto(const char *filename, size_t protoSize, const pb_msgdesc_ if (FSCom.exists(filename) && !FSCom.remove(filename)) LOG_WARN("Can't remove old pref file\n"); if (!renameFile(filenameTmp.c_str(), filename)) - LOG_DEBUG("Error: can't rename new pref file\n"); + LOG_ERROR("Error: can't rename new pref file\n"); } else { - LOG_DEBUG("Can't write prefs\n"); + LOG_ERROR("Can't write prefs\n"); #ifdef ARCH_NRF52 static uint8_t failedCounter = 0; failedCounter++; @@ -487,7 +487,7 @@ bool NodeDB::saveProto(const char *filename, size_t protoSize, const pb_msgdesc_ #endif } #else - LOG_DEBUG("ERROR: Filesystem not implemented\n"); + LOG_ERROR("ERROR: Filesystem not implemented\n"); #endif return okay; } @@ -599,7 +599,7 @@ void NodeDB::updatePosition(uint32_t nodeId, const Position &p, RxSource src) if (src == RX_SRC_LOCAL) { // Local packet, fully authoritative - LOG_DEBUG("updatePosition LOCAL pos@%x, time=%u, latI=%d, lonI=%d, alt=%d\n", p.timestamp, p.time, p.latitude_i, + LOG_INFO("updatePosition LOCAL pos@%x, time=%u, latI=%d, lonI=%d, alt=%d\n", p.timestamp, p.time, p.latitude_i, p.longitude_i, p.altitude); info->position = p; @@ -615,7 +615,7 @@ void NodeDB::updatePosition(uint32_t nodeId, const Position &p, RxSource src) // recorded based on the packet rxTime // // FIXME perhaps handle RX_SRC_USER separately? - LOG_DEBUG("updatePosition REMOTE node=0x%x time=%u, latI=%d, lonI=%d\n", nodeId, p.time, p.latitude_i, p.longitude_i); + LOG_INFO("updatePosition REMOTE node=0x%x time=%u, latI=%d, lonI=%d\n", nodeId, p.time, p.latitude_i, p.longitude_i); // First, back up fields that we want to protect from overwrite uint32_t tmp_time = info->position.time; @@ -756,9 +756,9 @@ void recordCriticalError(CriticalErrorCode code, uint32_t address, const char *f String lcd = String("Critical error ") + code + "!\n"; screen->print(lcd.c_str()); if (filename) - LOG_DEBUG("NOTE! Recording critical error %d at %s:%lu\n", code, filename, address); + LOG_ERROR("NOTE! Recording critical error %d at %s:%lu\n", code, filename, address); else - LOG_DEBUG("NOTE! Recording critical error %d, address=0x%lx\n", code, address); + LOG_ERROR("NOTE! Recording critical error %d, address=0x%lx\n", code, address); // Record error to DB myNodeInfo.error_code = code; @@ -767,7 +767,7 @@ void recordCriticalError(CriticalErrorCode code, uint32_t address, const char *f // Currently portuino is mostly used for simulation. Make sue the user notices something really bad happend #ifdef ARCH_PORTDUINO - LOG_DEBUG("A critical failure occurred, portduino is exiting..."); + LOG_ERROR("A critical failure occurred, portduino is exiting..."); exit(2); #endif } diff --git a/src/mesh/PhoneAPI.cpp b/src/mesh/PhoneAPI.cpp index 75805c11c5..897ddfe8a2 100644 --- a/src/mesh/PhoneAPI.cpp +++ b/src/mesh/PhoneAPI.cpp @@ -37,7 +37,7 @@ void PhoneAPI::handleStartConfig() // even if we were already connected - restart our state machine state = STATE_SEND_MY_INFO; - LOG_DEBUG("Starting API client config\n"); + LOG_INFO("Starting API client config\n"); nodeInfoForPhone = NULL; // Don't keep returning old nodeinfos nodeDB.resetReadPointer(); // FIXME, this read pointer should be moved out of nodeDB and into this class - because // this will break once we have multiple instances of PhoneAPI running independently @@ -60,7 +60,7 @@ void PhoneAPI::checkConnectionTimeout() if (isConnected()) { bool newContact = checkIsConnected(); if (!newContact) { - LOG_DEBUG("Lost phone connection\n"); + LOG_INFO("Lost phone connection\n"); close(); } } @@ -83,11 +83,11 @@ bool PhoneAPI::handleToRadio(const uint8_t *buf, size_t bufLength) return handleToRadioPacket(toRadioScratch.packet); case ToRadio_want_config_id_tag: config_nonce = toRadioScratch.want_config_id; - LOG_DEBUG("Client wants config, nonce=%u\n", config_nonce); + LOG_INFO("Client wants config, nonce=%u\n", config_nonce); handleStartConfig(); break; case ToRadio_disconnect_tag: - LOG_DEBUG("Disconnecting from phone\n"); + LOG_INFO("Disconnecting from phone\n"); close(); break; default: @@ -96,7 +96,7 @@ bool PhoneAPI::handleToRadio(const uint8_t *buf, size_t bufLength) break; } } else { - LOG_DEBUG("Error: ignoring malformed toradio\n"); + LOG_ERROR("Error: ignoring malformed toradio\n"); } return false; @@ -128,11 +128,11 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) // Advance states as needed switch (state) { case STATE_SEND_NOTHING: - LOG_DEBUG("getFromRadio=STATE_SEND_NOTHING\n"); + LOG_INFO("getFromRadio=STATE_SEND_NOTHING\n"); break; case STATE_SEND_MY_INFO: - LOG_DEBUG("getFromRadio=STATE_SEND_MY_INFO\n"); + LOG_INFO("getFromRadio=STATE_SEND_MY_INFO\n"); // If the user has specified they don't want our node to share its location, make sure to tell the phone // app not to send locations on our behalf. myNodeInfo.has_gps = gps && gps->isConnected(); // Update with latest GPS connect info @@ -144,18 +144,18 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) break; case STATE_SEND_NODEINFO: { - LOG_DEBUG("getFromRadio=STATE_SEND_NODEINFO\n"); + LOG_INFO("getFromRadio=STATE_SEND_NODEINFO\n"); const NodeInfo *info = nodeInfoForPhone; nodeInfoForPhone = NULL; // We just consumed a nodeinfo, will need a new one next time if (info) { - LOG_DEBUG("Sending nodeinfo: num=0x%x, lastseen=%u, id=%s, name=%s\n", info->num, info->last_heard, info->user.id, + LOG_INFO("Sending nodeinfo: num=0x%x, lastseen=%u, id=%s, name=%s\n", info->num, info->last_heard, info->user.id, info->user.long_name); fromRadioScratch.which_payload_variant = FromRadio_node_info_tag; fromRadioScratch.node_info = *info; // Stay in current state until done sending nodeinfos } else { - LOG_DEBUG("Done sending nodeinfos\n"); + LOG_INFO("Done sending nodeinfos\n"); state = STATE_SEND_CHANNELS; // Go ahead and send that ID right now return getFromRadio(buf); @@ -164,7 +164,7 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) } case STATE_SEND_CHANNELS: - LOG_DEBUG("getFromRadio=STATE_SEND_CHANNELS\n"); + LOG_INFO("getFromRadio=STATE_SEND_CHANNELS\n"); fromRadioScratch.which_payload_variant = FromRadio_channel_tag; fromRadioScratch.channel = channels.getByIndex(config_state); config_state++; @@ -176,7 +176,7 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) break; case STATE_SEND_CONFIG: - LOG_DEBUG("getFromRadio=STATE_SEND_CONFIG\n"); + LOG_INFO("getFromRadio=STATE_SEND_CONFIG\n"); fromRadioScratch.which_payload_variant = FromRadio_config_tag; switch (config_state) { case Config_device_tag: @@ -222,7 +222,7 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) break; case STATE_SEND_MODULECONFIG: - LOG_DEBUG("getFromRadio=STATE_SEND_MODULECONFIG\n"); + LOG_INFO("getFromRadio=STATE_SEND_MODULECONFIG\n"); fromRadioScratch.which_payload_variant = FromRadio_moduleConfig_tag; switch (config_state) { case ModuleConfig_mqtt_tag: @@ -272,7 +272,7 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) break; case STATE_SEND_COMPLETE_ID: - LOG_DEBUG("getFromRadio=STATE_SEND_COMPLETE_ID\n"); + LOG_INFO("getFromRadio=STATE_SEND_COMPLETE_ID\n"); fromRadioScratch.which_payload_variant = FromRadio_config_complete_id_tag; fromRadioScratch.config_complete_id = config_nonce; config_nonce = 0; @@ -281,7 +281,7 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) case STATE_SEND_PACKETS: // Do we have a message from the mesh? - LOG_DEBUG("getFromRadio=STATE_SEND_PACKETS\n"); + LOG_INFO("getFromRadio=STATE_SEND_PACKETS\n"); if (packetForPhone) { printPacket("phone downloaded packet", packetForPhone); @@ -311,7 +311,7 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf) void PhoneAPI::handleDisconnect() { - LOG_DEBUG("PhoneAPI disconnect\n"); + LOG_INFO("PhoneAPI disconnect\n"); } void PhoneAPI::releasePhonePacket() @@ -373,7 +373,7 @@ int PhoneAPI::onNotify(uint32_t newValue) // from idle) if (state == STATE_SEND_PACKETS) { - LOG_DEBUG("Telling client we have new packets %u\n", newValue); + LOG_INFO("Telling client we have new packets %u\n", newValue); onNowHasData(newValue); } else LOG_DEBUG("(Client not yet interested in packets)\n"); diff --git a/src/mesh/ProtobufModule.h b/src/mesh/ProtobufModule.h index bac38b7861..61fc95b7af 100644 --- a/src/mesh/ProtobufModule.h +++ b/src/mesh/ProtobufModule.h @@ -70,7 +70,7 @@ template class ProtobufModule : protected SinglePortModule // it would be better to update even if the message was destined to others. auto &p = mp.decoded; - LOG_DEBUG("Received %s from=0x%0x, id=0x%x, portnum=%d, payloadlen=%d\n", name, mp.from, mp.id, p.portnum, + LOG_INFO("Received %s from=0x%0x, id=0x%x, portnum=%d, payloadlen=%d\n", name, mp.from, mp.id, p.portnum, p.payload.size); T scratch; @@ -80,7 +80,7 @@ template class ProtobufModule : protected SinglePortModule if (pb_decode_from_bytes(p.payload.bytes, p.payload.size, fields, &scratch)) { decoded = &scratch; } else { - LOG_DEBUG("Error decoding protobuf module!\n"); + LOG_ERROR("Error decoding protobuf module!\n"); // if we can't decode it, nobody can process it! return ProcessMessage::STOP; } diff --git a/src/mesh/RF95Interface.cpp b/src/mesh/RF95Interface.cpp index e679775c3c..4502d0810d 100644 --- a/src/mesh/RF95Interface.cpp +++ b/src/mesh/RF95Interface.cpp @@ -68,11 +68,11 @@ bool RF95Interface::init() setTransmitEnable(false); int res = lora->begin(getFreq(), bw, sf, cr, syncWord, power, currentLimit, preambleLength); - LOG_DEBUG("RF95 init result %d\n", res); + LOG_INFO("RF95 init result %d\n", res); - LOG_DEBUG("Frequency set to %f\n", getFreq()); - LOG_DEBUG("Bandwidth set to %f\n", bw); - LOG_DEBUG("Power output set to %d\n", power); + LOG_INFO("Frequency set to %f\n", getFreq()); + LOG_INFO("Bandwidth set to %f\n", bw); + LOG_INFO("Power output set to %d\n", power); // current limit was removed from module' ctor // override default value (60 mA) diff --git a/src/mesh/RadioInterface.cpp b/src/mesh/RadioInterface.cpp index f3971ddb02..7c0f238a00 100644 --- a/src/mesh/RadioInterface.cpp +++ b/src/mesh/RadioInterface.cpp @@ -117,7 +117,7 @@ void initRegion() for (; r->code != Config_LoRaConfig_RegionCode_UNSET && r->code != config.lora.region; r++) ; myRegion = r; - LOG_DEBUG("Wanted region %d, using %s\n", config.lora.region, r->name); + LOG_INFO("Wanted region %d, using %s\n", config.lora.region, r->name); } /** @@ -284,7 +284,7 @@ bool RadioInterface::reconfigure() bool RadioInterface::init() { - LOG_DEBUG("Starting meshradio init...\n"); + LOG_INFO("Starting meshradio init...\n"); configChangedObserver.observe(&service.configChanged); preflightSleepObserver.observe(&preflightSleep); @@ -449,13 +449,13 @@ void RadioInterface::applyModemConfig() saveChannelNum(channel_num); saveFreq(freq + config.lora.frequency_offset); - LOG_DEBUG("Radio freq=%.3f, config.lora.frequency_offset=%.3f\n", freq, config.lora.frequency_offset); - LOG_DEBUG("Set radio: region=%s, name=%s, config=%u, ch=%d, power=%d\n", myRegion->name, channelName, loraConfig.modem_preset, channel_num, power); - LOG_DEBUG("Radio myRegion->freqStart -> myRegion->freqEnd: %f -> %f (%f mhz)\n", myRegion->freqStart, myRegion->freqEnd, myRegion->freqEnd - myRegion->freqStart); - LOG_DEBUG("Radio myRegion->numChannels: %d x %.3fkHz\n", numChannels, bw); - LOG_DEBUG("Radio channel_num: %d\n", channel_num); - LOG_DEBUG("Radio frequency: %f\n", getFreq()); - LOG_DEBUG("Slot time: %u msec\n", slotTimeMsec); + LOG_INFO("Radio freq=%.3f, config.lora.frequency_offset=%.3f\n", freq, config.lora.frequency_offset); + LOG_INFO("Set radio: region=%s, name=%s, config=%u, ch=%d, power=%d\n", myRegion->name, channelName, loraConfig.modem_preset, channel_num, power); + LOG_INFO("Radio myRegion->freqStart -> myRegion->freqEnd: %f -> %f (%f mhz)\n", myRegion->freqStart, myRegion->freqEnd, myRegion->freqEnd - myRegion->freqStart); + LOG_INFO("Radio myRegion->numChannels: %d x %.3fkHz\n", numChannels, bw); + LOG_INFO("Radio channel_num: %d\n", channel_num); + LOG_INFO("Radio frequency: %f\n", getFreq()); + LOG_INFO("Slot time: %u msec\n", slotTimeMsec); } /** @@ -470,11 +470,11 @@ void RadioInterface::limitPower() maxPower = myRegion->powerLimit; if ((power > maxPower) && !devicestate.owner.is_licensed) { - LOG_DEBUG("Lowering transmit power because of regulatory limits\n"); + LOG_INFO("Lowering transmit power because of regulatory limits\n"); power = maxPower; } - LOG_DEBUG("Set radio: final power level=%d\n", power); + LOG_INFO("Set radio: final power level=%d\n", power); } diff --git a/src/mesh/RadioLibInterface.cpp b/src/mesh/RadioLibInterface.cpp index 127a246c0b..53eaeca60b 100644 --- a/src/mesh/RadioLibInterface.cpp +++ b/src/mesh/RadioLibInterface.cpp @@ -82,17 +82,17 @@ bool RadioLibInterface::canSendImmediately() if (busyTx || busyRx) { if (busyTx) - LOG_DEBUG("Can not send yet, busyTx\n"); + LOG_WARN("Can not send yet, busyTx\n"); // If we've been trying to send the same packet more than one minute and we haven't gotten a // TX IRQ from the radio, the radio is probably broken. if (busyTx && (millis() - lastTxStart > 60000)) { - LOG_DEBUG("Hardware Failure! busyTx for more than 60s\n"); + LOG_ERROR("Hardware Failure! busyTx for more than 60s\n"); RECORD_CRITICALERROR(CriticalErrorCode_TRANSMIT_FAILED); // reboot in 5 seconds when this condition occurs. rebootAtMsec = lastTxStart + 65000; } if (busyRx) - LOG_DEBUG("Can not send yet, busyRx\n"); + LOG_WARN("Can not send yet, busyRx\n"); return false; } else return true; @@ -111,13 +111,13 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) if (config.lora.region != Config_LoRaConfig_RegionCode_UNSET) { if (disabled || !config.lora.tx_enabled) { - LOG_DEBUG("send - !config.lora.tx_enabled\n"); + LOG_WARN("send - !config.lora.tx_enabled\n"); packetPool.release(p); return ERRNO_DISABLED; } } else { - LOG_DEBUG("send - lora tx disable because RegionCode_Unset\n"); + LOG_WARN("send - lora tx disable because RegionCode_Unset\n"); packetPool.release(p); return ERRNO_DISABLED; } @@ -127,7 +127,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) #else if (disabled || !config.lora.tx_enabled) { - LOG_DEBUG("send - !config.lora.tx_enabled\n"); + LOG_WARN("send - !config.lora.tx_enabled\n"); packetPool.release(p); return ERRNO_DISABLED; } @@ -319,7 +319,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) int state = iface->readData(radiobuf, length); if (state != RADIOLIB_ERR_NONE) { - LOG_DEBUG("ignoring received packet due to error=%d\n", state); + LOG_ERROR("ignoring received packet due to error=%d\n", state); rxBad++; airTime->logAirtime(RX_ALL_LOG, xmitMsec); @@ -331,7 +331,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) // check for short packets if (payloadLen < 0) { - LOG_DEBUG("ignoring received packet too short\n"); + LOG_WARN("ignoring received packet too short\n"); rxBad++; airTime->logAirtime(RX_ALL_LOG, xmitMsec); } else { @@ -374,7 +374,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) { printPacket("Starting low level send", txp); if (disabled || !config.lora.tx_enabled) { - LOG_DEBUG("startSend is dropping tx packet because we are disabled\n"); + LOG_WARN("startSend is dropping tx packet because we are disabled\n"); packetPool.release(txp); } else { setStandby(); // Cancel any already in process receives @@ -385,7 +385,7 @@ ErrorCode RadioLibInterface::send(MeshPacket *p) int res = iface->startTransmit(radiobuf, numbytes); if (res != RADIOLIB_ERR_NONE) { - LOG_DEBUG("startTransmit failed, error=%d\n", res); + LOG_ERROR("startTransmit failed, error=%d\n", res); RECORD_CRITICALERROR(CriticalErrorCode_RADIO_SPI_BUG); // This send failed, but make sure to 'complete' it properly diff --git a/src/mesh/Router.cpp b/src/mesh/Router.cpp index 826a3f0896..a94e8c2952 100644 --- a/src/mesh/Router.cpp +++ b/src/mesh/Router.cpp @@ -136,7 +136,7 @@ void Router::sendAckNak(Routing_Error err, NodeNum to, PacketId idFrom, ChannelI void Router::abortSendAndNak(Routing_Error err, MeshPacket *p) { - LOG_DEBUG("Error=%d, returning NAK and dropping packet.\n", err); + LOG_ERROR("Error=%d, returning NAK and dropping packet.\n", err); sendAckNak(Routing_Error_NO_INTERFACE, getFrom(p), p->id, p->channel); packetPool.release(p); } @@ -239,7 +239,7 @@ ErrorCode Router::send(MeshPacket *p) shouldActuallyEncrypt = false; } - LOG_DEBUG("Should encrypt MQTT?: %d\n", shouldActuallyEncrypt); + LOG_INFO("Should encrypt MQTT?: %d\n", shouldActuallyEncrypt); // the packet is currently in a decrypted state. send it now if they want decrypted packets if (mqtt && !shouldActuallyEncrypt) @@ -307,9 +307,9 @@ bool perhapsDecode(MeshPacket *p) // Take those raw bytes and convert them back into a well structured protobuf we can understand memset(&p->decoded, 0, sizeof(p->decoded)); if (!pb_decode_from_bytes(bytes, rawSize, &Data_msg, &p->decoded)) { - LOG_DEBUG("Invalid protobufs in received mesh packet (bad psk?)!\n"); + LOG_ERROR("Invalid protobufs in received mesh packet (bad psk?)!\n"); } else if (p->decoded.portnum == PortNum_UNKNOWN_APP) { - LOG_DEBUG("Invalid portnum (bad psk?)!\n"); + LOG_ERROR("Invalid portnum (bad psk?)!\n"); } else { // parsing was successful p->which_payload_variant = MeshPacket_decoded_tag; // change type to decoded @@ -348,7 +348,7 @@ bool perhapsDecode(MeshPacket *p) } } - LOG_DEBUG("No suitable channel found for decoding, hash was 0x%x!\n", p->channel); + LOG_WARN("No suitable channel found for decoding, hash was 0x%x!\n", p->channel); return false; } diff --git a/src/mesh/SX126xInterface.cpp b/src/mesh/SX126xInterface.cpp index 1caf8c9d88..15b8088523 100644 --- a/src/mesh/SX126xInterface.cpp +++ b/src/mesh/SX126xInterface.cpp @@ -12,7 +12,7 @@ SX126xInterface::SX126xInterface(RADIOLIB_PIN_TYPE cs, RADIOLIB_PIN_TYPE irq, SPIClass &spi) : RadioLibInterface(cs, irq, rst, busy, spi, &lora), lora(&module) { - LOG_DEBUG("SX126xInterface(cs=%d, irq=%d, rst=%d, busy=%d)\n", cs, irq, rst, busy); + LOG_WARN("SX126xInterface(cs=%d, irq=%d, rst=%d, busy=%d)\n", cs, irq, rst, busy); } /// Initialise the Driver transport hardware and software. @@ -55,11 +55,11 @@ bool SX126xInterface::init() int res = lora.begin(getFreq(), bw, sf, cr, syncWord, power, preambleLength, tcxoVoltage, useRegulatorLDO); // \todo Display actual typename of the adapter, not just `SX126x` - LOG_DEBUG("SX126x init result %d\n", res); + LOG_INFO("SX126x init result %d\n", res); - LOG_DEBUG("Frequency set to %f\n", getFreq()); - LOG_DEBUG("Bandwidth set to %f\n", bw); - LOG_DEBUG("Power output set to %d\n", power); + LOG_INFO("Frequency set to %f\n", getFreq()); + LOG_INFO("Bandwidth set to %f\n", bw); + LOG_INFO("Power output set to %d\n", power); // current limit was removed from module' ctor // override default value (60 mA) diff --git a/src/mesh/SX128xInterface.cpp b/src/mesh/SX128xInterface.cpp index b96801794d..cc6d299c8c 100644 --- a/src/mesh/SX128xInterface.cpp +++ b/src/mesh/SX128xInterface.cpp @@ -49,7 +49,7 @@ bool SX128xInterface::init() int res = lora.begin(getFreq(), bw, sf, cr, syncWord, power, preambleLength); // \todo Display actual typename of the adapter, not just `SX128x` - LOG_DEBUG("SX128x init result %d\n", res); + LOG_INFO("SX128x init result %d\n", res); if((config.lora.region != Config_LoRaConfig_RegionCode_LORA_24) && (res == RADIOLIB_ERR_INVALID_FREQUENCY)) { LOG_WARN("Radio chip only supports 2.4GHz LoRa. Adjusting Region and rebooting.\n"); @@ -61,13 +61,13 @@ bool SX128xInterface::init() #elif defined(ARCH_NRF52) NVIC_SystemReset(); #else - LOG_DEBUG("FIXME implement reboot for this platform. Skipping for now.\n"); + LOG_ERROR("FIXME implement reboot for this platform. Skipping for now.\n"); #endif } - LOG_DEBUG("Frequency set to %f\n", getFreq()); - LOG_DEBUG("Bandwidth set to %f\n", bw); - LOG_DEBUG("Power output set to %d\n", power); + LOG_INFO("Frequency set to %f\n", getFreq()); + LOG_INFO("Bandwidth set to %f\n", bw); + LOG_INFO("Power output set to %d\n", power); if (res == RADIOLIB_ERR_NONE) res = lora.setCRC(2); @@ -145,7 +145,7 @@ void SX128xInterface::setStandby() int err = lora.standby(); if (err != RADIOLIB_ERR_NONE) - LOG_DEBUG("SX128x standby failed with error %d\n", err); + LOG_ERROR("SX128x standby failed with error %d\n", err); assert(err == RADIOLIB_ERR_NONE); diff --git a/src/mesh/eth/ethClient.cpp b/src/mesh/eth/ethClient.cpp index 57decacdc1..5889137816 100644 --- a/src/mesh/eth/ethClient.cpp +++ b/src/mesh/eth/ethClient.cpp @@ -29,10 +29,10 @@ static int32_t reconnectETH() Ethernet.maintain(); if (!ethStartupComplete) { // Start web server - LOG_DEBUG("... Starting network services\n"); + LOG_INFO("... Starting network services\n"); #ifndef DISABLE_NTP - LOG_DEBUG("Starting NTP time client\n"); + LOG_INFO("Starting NTP time client\n"); timeClient.begin(); timeClient.setUpdateInterval(60 * 60); // Update once an hour #endif @@ -51,7 +51,7 @@ static int32_t reconnectETH() #ifndef DISABLE_NTP if (isEthernetAvailable() && (ntp_renew < millis())) { - LOG_DEBUG("Updating NTP time from %s\n", config.network.ntp_server); + LOG_INFO("Updating NTP time from %s\n", config.network.ntp_server); if (timeClient.update()) { LOG_DEBUG("NTP Request Success - Setting RTCQualityNTP if needed\n"); @@ -64,7 +64,7 @@ static int32_t reconnectETH() ntp_renew = millis() + 43200 * 1000; // success, refresh every 12 hours } else { - LOG_DEBUG("NTP Update failed\n"); + LOG_ERROR("NTP Update failed\n"); ntp_renew = millis() + 300 * 1000; // failure, retry every 5 minutes } } @@ -96,32 +96,32 @@ bool initEthernet() getMacAddr(mac); // FIXME use the BLE MAC for now... if (config.network.eth_mode == Config_NetworkConfig_EthMode_DHCP) { - LOG_DEBUG("starting Ethernet DHCP\n"); + LOG_INFO("starting Ethernet DHCP\n"); status = Ethernet.begin(mac); } else if (config.network.eth_mode == Config_NetworkConfig_EthMode_STATIC) { - LOG_DEBUG("starting Ethernet Static\n"); + LOG_INFO("starting Ethernet Static\n"); Ethernet.begin(mac, config.network.ipv4_config.ip, config.network.ipv4_config.dns, config.network.ipv4_config.subnet); } else { - LOG_DEBUG("Ethernet Disabled\n"); + LOG_INFO("Ethernet Disabled\n"); return false; } if (status == 0) { if (Ethernet.hardwareStatus() == EthernetNoHardware) { - LOG_DEBUG("Ethernet shield was not found.\n"); + LOG_ERROR("Ethernet shield was not found.\n"); return false; } else if (Ethernet.linkStatus() == LinkOFF) { - LOG_DEBUG("Ethernet cable is not connected.\n"); + LOG_ERROR("Ethernet cable is not connected.\n"); return false; } else{ - LOG_DEBUG("Unknown Ethernet error.\n"); + LOG_ERROR("Unknown Ethernet error.\n"); return false; } } else { - LOG_DEBUG("Local IP %u.%u.%u.%u\n",Ethernet.localIP()[0], Ethernet.localIP()[1], Ethernet.localIP()[2], Ethernet.localIP()[3]); - LOG_DEBUG("Subnet Mask %u.%u.%u.%u\n",Ethernet.subnetMask()[0], Ethernet.subnetMask()[1], Ethernet.subnetMask()[2], Ethernet.subnetMask()[3]); - LOG_DEBUG("Gateway IP %u.%u.%u.%u\n",Ethernet.gatewayIP()[0], Ethernet.gatewayIP()[1], Ethernet.gatewayIP()[2], Ethernet.gatewayIP()[3]); - LOG_DEBUG("DNS Server IP %u.%u.%u.%u\n",Ethernet.dnsServerIP()[0], Ethernet.dnsServerIP()[1], Ethernet.dnsServerIP()[2], Ethernet.dnsServerIP()[3]); + LOG_INFO("Local IP %u.%u.%u.%u\n",Ethernet.localIP()[0], Ethernet.localIP()[1], Ethernet.localIP()[2], Ethernet.localIP()[3]); + LOG_INFO("Subnet Mask %u.%u.%u.%u\n",Ethernet.subnetMask()[0], Ethernet.subnetMask()[1], Ethernet.subnetMask()[2], Ethernet.subnetMask()[3]); + LOG_INFO("Gateway IP %u.%u.%u.%u\n",Ethernet.gatewayIP()[0], Ethernet.gatewayIP()[1], Ethernet.gatewayIP()[2], Ethernet.gatewayIP()[3]); + LOG_INFO("DNS Server IP %u.%u.%u.%u\n",Ethernet.dnsServerIP()[0], Ethernet.dnsServerIP()[1], Ethernet.dnsServerIP()[2], Ethernet.dnsServerIP()[3]); } ethEvent = new Periodic("ethConnect", reconnectETH); @@ -129,7 +129,7 @@ bool initEthernet() return true; } else { - LOG_DEBUG("Not using Ethernet\n"); + LOG_INFO("Not using Ethernet\n"); return false; } } diff --git a/src/mesh/eth/ethServerAPI.cpp b/src/mesh/eth/ethServerAPI.cpp index 4159d285aa..d91b798a04 100644 --- a/src/mesh/eth/ethServerAPI.cpp +++ b/src/mesh/eth/ethServerAPI.cpp @@ -9,14 +9,14 @@ void initApiServer(int port) // Start API server on port 4403 if (!apiPort) { apiPort = new ethServerPort(port); - LOG_DEBUG("API server listening on TCP port %d\n", port); + LOG_INFO("API server listening on TCP port %d\n", port); apiPort->init(); } } ethServerAPI::ethServerAPI(EthernetClient &_client) : StreamAPI(&client), concurrency::OSThread("ethServerAPI"), client(_client) { - LOG_DEBUG("Incoming ethernet connection\n"); + LOG_INFO("Incoming ethernet connection\n"); } ethServerAPI::~ethServerAPI() @@ -44,7 +44,7 @@ int32_t ethServerAPI::runOnce() if (client.connected()) { return StreamAPI::runOncePart(); } else { - LOG_DEBUG("Client dropped connection, suspending API service\n"); + LOG_INFO("Client dropped connection, suspending API service\n"); enabled = false; // we no longer need to run return 0; } @@ -71,7 +71,7 @@ int32_t ethServerPort::runOnce() if (client) { // Close any previous connection (see FIXME in header file) if (openAPI) { - LOG_DEBUG("Force closing previous TCP connection\n"); + LOG_WARN("Force closing previous TCP connection\n"); delete openAPI; } diff --git a/src/mesh/http/ContentHandler.cpp b/src/mesh/http/ContentHandler.cpp index 22d97a2b62..7551a0828f 100644 --- a/src/mesh/http/ContentHandler.cpp +++ b/src/mesh/http/ContentHandler.cpp @@ -335,7 +335,7 @@ void handleFsDeleteStatic(HTTPRequest *req, HTTPResponse *res) if (params->getQueryParameter("delete", paramValDelete)) { std::string pathDelete = "/" + paramValDelete; if (FSCom.remove(pathDelete.c_str())) { - Serial.println(pathDelete.c_str()); + LOG_INFO("%s\n", pathDelete.c_str()); JSONObject jsonObjOuter; jsonObjOuter["status"] = new JSONValue("ok"); JSONValue *value = new JSONValue(jsonObjOuter); @@ -343,7 +343,7 @@ void handleFsDeleteStatic(HTTPRequest *req, HTTPResponse *res) delete value; return; } else { - Serial.println(pathDelete.c_str()); + LOG_INFO("%s\n", pathDelete.c_str()); JSONObject jsonObjOuter; jsonObjOuter["status"] = new JSONValue("Error"); JSONValue *value = new JSONValue(jsonObjOuter); @@ -379,13 +379,13 @@ void handleStatic(HTTPRequest *req, HTTPResponse *res) if (FSCom.exists(filename.c_str())) { file = FSCom.open(filename.c_str()); if (!file.available()) { - LOG_DEBUG("File not available - %s\n", filename.c_str()); + LOG_WARN("File not available - %s\n", filename.c_str()); } } else if (FSCom.exists(filenameGzip.c_str())) { file = FSCom.open(filenameGzip.c_str()); res->setHeader("Content-Encoding", "gzip"); if (!file.available()) { - LOG_DEBUG("File not available - %s\n", filenameGzip.c_str()); + LOG_WARN("File not available - %s\n", filenameGzip.c_str()); } } else { has_set_content_type = true; @@ -393,7 +393,7 @@ void handleStatic(HTTPRequest *req, HTTPResponse *res) file = FSCom.open(filenameGzip.c_str()); res->setHeader("Content-Type", "text/html"); if (!file.available()) { - LOG_DEBUG("File not available - %s\n", filenameGzip.c_str()); + LOG_WARN("File not available - %s\n", filenameGzip.c_str()); res->println("Web server is running.

The content you are looking for can't be found. Please see: FAQ.

admin"); @@ -437,7 +437,7 @@ void handleStatic(HTTPRequest *req, HTTPResponse *res) return; } else { - LOG_DEBUG("ERROR: This should not have happened...\n"); + LOG_ERROR("This should not have happened...\n"); res->println("ERROR: This should not have happened..."); } } @@ -472,7 +472,7 @@ void handleFormUpload(HTTPRequest *req, HTTPResponse *res) LOG_DEBUG("Form Upload - multipart/form-data\n"); parser = new HTTPMultipartBodyParser(req); } else { - Serial.printf("Unknown POST Content-Type: %s\n", contentType.c_str()); + LOG_DEBUG("Unknown POST Content-Type: %s\n", contentType.c_str()); return; } @@ -671,7 +671,7 @@ void handleReport(HTTPRequest *req, HTTPResponse *res) */ void handleHotspot(HTTPRequest *req, HTTPResponse *res) { - LOG_DEBUG("Hotspot Request\n"); + LOG_INFO("Hotspot Request\n"); /* If we don't do a redirect, be sure to return a "Success" message @@ -697,7 +697,7 @@ void handleDeleteFsContent(HTTPRequest *req, HTTPResponse *res) res->println("

Meshtastic

\n"); res->println("Deleting Content in /static/*"); - LOG_DEBUG("Deleting files from /static/* : \n"); + LOG_INFO("Deleting files from /static/* : \n"); htmlDeleteDir("/static"); diff --git a/src/mesh/http/WebServer.cpp b/src/mesh/http/WebServer.cpp index 10f8067f66..9b22016df9 100644 --- a/src/mesh/http/WebServer.cpp +++ b/src/mesh/http/WebServer.cpp @@ -74,13 +74,13 @@ static void taskCreateCert(void *parameter) prefs.remove("cert"); #endif - LOG_DEBUG("Checking if we have a previously saved SSL Certificate.\n"); + LOG_INFO("Checking if we have a previously saved SSL Certificate.\n"); size_t pkLen = prefs.getBytesLength("PK"); size_t certLen = prefs.getBytesLength("cert"); if (pkLen && certLen) { - LOG_DEBUG("Existing SSL Certificate found!\n"); + LOG_INFO("Existing SSL Certificate found!\n"); uint8_t *pkBuffer = new uint8_t[pkLen]; prefs.getBytes("PK", pkBuffer, pkLen); @@ -95,7 +95,7 @@ static void taskCreateCert(void *parameter) } else { - LOG_DEBUG("Creating the certificate. This may take a while. Please wait...\n"); + LOG_INFO("Creating the certificate. This may take a while. Please wait...\n"); yield(); cert = new SSLCert(); yield(); @@ -104,10 +104,10 @@ static void taskCreateCert(void *parameter) yield(); if (createCertResult != 0) { - LOG_DEBUG("Creating the certificate failed\n"); + LOG_ERROR("Creating the certificate failed\n"); } else { - LOG_DEBUG("Creating the certificate was successful\n"); + LOG_INFO("Creating the certificate was successful\n"); LOG_DEBUG("Created Private Key: %d Bytes\n", cert->getPKLength()); @@ -159,7 +159,7 @@ void createSSLCert() runLoop = true; } } - LOG_DEBUG("SSL Cert Ready!\n"); + LOG_INFO("SSL Cert Ready!\n"); } } @@ -191,15 +191,15 @@ void initWebServer() registerHandlers(insecureServer, secureServer); if (secureServer) { - LOG_DEBUG("Starting Secure Web Server...\n"); + LOG_INFO("Starting Secure Web Server...\n"); secureServer->start(); } - LOG_DEBUG("Starting Insecure Web Server...\n"); + LOG_INFO("Starting Insecure Web Server...\n"); insecureServer->start(); if (insecureServer->isRunning()) { - LOG_DEBUG("Web Servers Ready! :-) \n"); + LOG_INFO("Web Servers Ready! :-) \n"); isWebServerReady = true; } else { - LOG_DEBUG("Web Servers Failed! ;-( \n"); + LOG_ERROR("Web Servers Failed! ;-( \n"); } } diff --git a/src/mesh/http/WiFiAPClient.cpp b/src/mesh/http/WiFiAPClient.cpp index 13e1277566..cba09dd7c2 100644 --- a/src/mesh/http/WiFiAPClient.cpp +++ b/src/mesh/http/WiFiAPClient.cpp @@ -56,7 +56,7 @@ static int32_t reconnectWiFi() // Make sure we clear old connection credentials WiFi.disconnect(false, true); - LOG_DEBUG("Reconnecting to WiFi access point %s\n",wifiName); + LOG_INFO("Reconnecting to WiFi access point %s\n",wifiName); WiFi.mode(WIFI_MODE_STA); WiFi.begin(wifiName, wifiPsw); @@ -101,12 +101,12 @@ bool isWifiAvailable() // Disable WiFi void deinitWifi() { - LOG_DEBUG("WiFi deinit\n"); + LOG_INFO("WiFi deinit\n"); if (isWifiAvailable()) { WiFi.disconnect(true); WiFi.mode(WIFI_MODE_NULL); - LOG_DEBUG("WiFi Turned Off\n"); + LOG_INFO("WiFi Turned Off\n"); // WiFi.printDiag(Serial); } } @@ -115,20 +115,20 @@ static void onNetworkConnected() { if (!APStartupComplete) { // Start web server - LOG_DEBUG("Starting network services\n"); + LOG_INFO("Starting network services\n"); // start mdns if (!MDNS.begin("Meshtastic")) { - LOG_DEBUG("Error setting up MDNS responder!\n"); + LOG_ERROR("Error setting up MDNS responder!\n"); } else { - LOG_DEBUG("mDNS responder started\n"); - LOG_DEBUG("mDNS Host: Meshtastic.local\n"); + LOG_INFO("mDNS responder started\n"); + LOG_INFO("mDNS Host: Meshtastic.local\n"); MDNS.addService("http", "tcp", 80); MDNS.addService("https", "tcp", 443); } #ifndef DISABLE_NTP - LOG_DEBUG("Starting NTP time client\n"); + LOG_INFO("Starting NTP time client\n"); timeClient.begin(); timeClient.setUpdateInterval(60 * 60); // Update once an hour #endif @@ -182,8 +182,7 @@ bool initWifi() WiFi.onEvent( [](WiFiEvent_t event, WiFiEventInfo_t info) { - Serial.print("WiFi lost connection. Reason: "); - Serial.println(info.wifi_sta_disconnected.reason); + LOG_WARN("WiFi lost connection. Reason: %s", info.wifi_sta_disconnected.reason); /* If we are disconnected from the AP for some reason, @@ -201,7 +200,7 @@ bool initWifi() } return true; } else { - LOG_DEBUG("Not using WIFI\n"); + LOG_INFO("Not using WIFI\n"); return false; } } @@ -213,133 +212,131 @@ static void WiFiEvent(WiFiEvent_t event) switch (event) { case ARDUINO_EVENT_WIFI_READY: - LOG_DEBUG("WiFi interface ready\n"); + LOG_INFO("WiFi interface ready\n"); break; case ARDUINO_EVENT_WIFI_SCAN_DONE: - LOG_DEBUG("Completed scan for access points\n"); + LOG_INFO("Completed scan for access points\n"); break; case ARDUINO_EVENT_WIFI_STA_START: - LOG_DEBUG("WiFi station started\n"); + LOG_INFO("WiFi station started\n"); break; case ARDUINO_EVENT_WIFI_STA_STOP: - LOG_DEBUG("WiFi station stopped\n"); + LOG_INFO("WiFi station stopped\n"); break; case ARDUINO_EVENT_WIFI_STA_CONNECTED: - LOG_DEBUG("Connected to access point\n"); + LOG_INFO("Connected to access point\n"); break; case ARDUINO_EVENT_WIFI_STA_DISCONNECTED: - LOG_DEBUG("Disconnected from WiFi access point\n"); + LOG_INFO("Disconnected from WiFi access point\n"); WiFi.disconnect(false, true); needReconnect = true; wifiReconnect->setIntervalFromNow(1000); break; case ARDUINO_EVENT_WIFI_STA_AUTHMODE_CHANGE: - LOG_DEBUG("Authentication mode of access point has changed\n"); + LOG_INFO("Authentication mode of access point has changed\n"); break; case ARDUINO_EVENT_WIFI_STA_GOT_IP: - LOG_DEBUG("Obtained IP address: "); - Serial.println(WiFi.localIP()); + LOG_INFO("Obtained IP address: ", WiFi.localIPv6()); onNetworkConnected(); break; case ARDUINO_EVENT_WIFI_STA_GOT_IP6: - LOG_DEBUG("Obtained IP6 address: "); - Serial.println(WiFi.localIPv6()); + LOG_INFO("Obtained IP6 address: %s", WiFi.localIPv6()); break; case ARDUINO_EVENT_WIFI_STA_LOST_IP: - LOG_DEBUG("Lost IP address and IP address is reset to 0\n"); + LOG_INFO("Lost IP address and IP address is reset to 0\n"); WiFi.disconnect(false, true); needReconnect = true; wifiReconnect->setIntervalFromNow(1000); break; case ARDUINO_EVENT_WPS_ER_SUCCESS: - LOG_DEBUG("WiFi Protected Setup (WPS): succeeded in enrollee mode\n"); + LOG_INFO("WiFi Protected Setup (WPS): succeeded in enrollee mode\n"); break; case ARDUINO_EVENT_WPS_ER_FAILED: - LOG_DEBUG("WiFi Protected Setup (WPS): failed in enrollee mode\n"); + LOG_INFO("WiFi Protected Setup (WPS): failed in enrollee mode\n"); break; case ARDUINO_EVENT_WPS_ER_TIMEOUT: - LOG_DEBUG("WiFi Protected Setup (WPS): timeout in enrollee mode\n"); + LOG_INFO("WiFi Protected Setup (WPS): timeout in enrollee mode\n"); break; case ARDUINO_EVENT_WPS_ER_PIN: - LOG_DEBUG("WiFi Protected Setup (WPS): pin code in enrollee mode\n"); + LOG_INFO("WiFi Protected Setup (WPS): pin code in enrollee mode\n"); break; case ARDUINO_EVENT_WPS_ER_PBC_OVERLAP: - LOG_DEBUG("WiFi Protected Setup (WPS): push button overlap in enrollee mode\n"); + LOG_INFO("WiFi Protected Setup (WPS): push button overlap in enrollee mode\n"); break; case ARDUINO_EVENT_WIFI_AP_START: - LOG_DEBUG("WiFi access point started\n"); + LOG_INFO("WiFi access point started\n"); break; case ARDUINO_EVENT_WIFI_AP_STOP: - LOG_DEBUG("WiFi access point stopped\n"); + LOG_INFO("WiFi access point stopped\n"); break; case ARDUINO_EVENT_WIFI_AP_STACONNECTED: - LOG_DEBUG("Client connected\n"); + LOG_INFO("Client connected\n"); break; case ARDUINO_EVENT_WIFI_AP_STADISCONNECTED: - LOG_DEBUG("Client disconnected\n"); + LOG_INFO("Client disconnected\n"); break; case ARDUINO_EVENT_WIFI_AP_STAIPASSIGNED: - LOG_DEBUG("Assigned IP address to client\n"); + LOG_INFO("Assigned IP address to client\n"); break; case ARDUINO_EVENT_WIFI_AP_PROBEREQRECVED: - LOG_DEBUG("Received probe request\n"); + LOG_INFO("Received probe request\n"); break; case ARDUINO_EVENT_WIFI_AP_GOT_IP6: - LOG_DEBUG("IPv6 is preferred\n"); + LOG_INFO("IPv6 is preferred\n"); break; case ARDUINO_EVENT_WIFI_FTM_REPORT: - LOG_DEBUG("Fast Transition Management report\n"); + LOG_INFO("Fast Transition Management report\n"); break; case ARDUINO_EVENT_ETH_START: - LOG_DEBUG("Ethernet started\n"); + LOG_INFO("Ethernet started\n"); break; case ARDUINO_EVENT_ETH_STOP: - LOG_DEBUG("Ethernet stopped\n"); + LOG_INFO("Ethernet stopped\n"); break; case ARDUINO_EVENT_ETH_CONNECTED: - LOG_DEBUG("Ethernet connected\n"); + LOG_INFO("Ethernet connected\n"); break; case ARDUINO_EVENT_ETH_DISCONNECTED: - LOG_DEBUG("Ethernet disconnected\n"); + LOG_INFO("Ethernet disconnected\n"); break; case ARDUINO_EVENT_ETH_GOT_IP: - LOG_DEBUG("Obtained IP address (ARDUINO_EVENT_ETH_GOT_IP)\n"); + LOG_INFO("Obtained IP address (ARDUINO_EVENT_ETH_GOT_IP)\n"); break; case ARDUINO_EVENT_ETH_GOT_IP6: - LOG_DEBUG("Obtained IP6 address (ARDUINO_EVENT_ETH_GOT_IP6)\n"); + LOG_INFO("Obtained IP6 address (ARDUINO_EVENT_ETH_GOT_IP6)\n"); break; case ARDUINO_EVENT_SC_SCAN_DONE: - LOG_DEBUG("SmartConfig: Scan done\n"); + LOG_INFO("SmartConfig: Scan done\n"); break; case ARDUINO_EVENT_SC_FOUND_CHANNEL: - LOG_DEBUG("SmartConfig: Found channel\n"); + LOG_INFO("SmartConfig: Found channel\n"); break; case ARDUINO_EVENT_SC_GOT_SSID_PSWD: - LOG_DEBUG("SmartConfig: Got SSID and password\n"); + LOG_INFO("SmartConfig: Got SSID and password\n"); break; case ARDUINO_EVENT_SC_SEND_ACK_DONE: - LOG_DEBUG("SmartConfig: Send ACK done\n"); + LOG_INFO("SmartConfig: Send ACK done\n"); break; case ARDUINO_EVENT_PROV_INIT: - LOG_DEBUG("Provisioning: Init\n"); + LOG_INFO("Provisioning: Init\n"); break; case ARDUINO_EVENT_PROV_DEINIT: - LOG_DEBUG("Provisioning: Stopped\n"); + LOG_INFO("Provisioning: Stopped\n"); break; case ARDUINO_EVENT_PROV_START: - LOG_DEBUG("Provisioning: Started\n"); + LOG_INFO("Provisioning: Started\n"); break; case ARDUINO_EVENT_PROV_END: - LOG_DEBUG("Provisioning: End\n"); + LOG_INFO("Provisioning: End\n"); break; case ARDUINO_EVENT_PROV_CRED_RECV: - LOG_DEBUG("Provisioning: Credentials received\n"); + LOG_INFO("Provisioning: Credentials received\n"); break; case ARDUINO_EVENT_PROV_CRED_FAIL: - LOG_DEBUG("Provisioning: Credentials failed\n"); + LOG_INFO("Provisioning: Credentials failed\n"); break; case ARDUINO_EVENT_PROV_CRED_SUCCESS: - LOG_DEBUG("Provisioning: Credentials success\n"); + LOG_INFO("Provisioning: Credentials success\n"); break; default: break; diff --git a/src/mesh/mesh-pb-constants.cpp b/src/mesh/mesh-pb-constants.cpp index cbf4c76d3f..d8a9810549 100644 --- a/src/mesh/mesh-pb-constants.cpp +++ b/src/mesh/mesh-pb-constants.cpp @@ -12,7 +12,7 @@ size_t pb_encode_to_bytes(uint8_t *destbuf, size_t destbufsize, const pb_msgdesc { pb_ostream_t stream = pb_ostream_from_buffer(destbuf, destbufsize); if (!pb_encode(&stream, fields, src_struct)) { - LOG_DEBUG("Panic: can't encode protobuf reason='%s'\n", PB_GET_ERROR(&stream)); + LOG_ERROR("Panic: can't encode protobuf reason='%s'\n", PB_GET_ERROR(&stream)); assert(0); // If this asser fails it probably means you made a field too large for the max limits specified in mesh.options } else { return stream.bytes_written; @@ -24,7 +24,7 @@ bool pb_decode_from_bytes(const uint8_t *srcbuf, size_t srcbufsize, const pb_msg { pb_istream_t stream = pb_istream_from_buffer(srcbuf, srcbufsize); if (!pb_decode(&stream, fields, dest_struct)) { - LOG_DEBUG("Error: can't decode protobuf reason='%s', pb_msgdesc 0x%p\n", PB_GET_ERROR(&stream), fields); + LOG_ERROR("Can't decode protobuf reason='%s', pb_msgdesc 0x%p\n", PB_GET_ERROR(&stream), fields); return false; } else { return true; diff --git a/src/mesh/wifi/WiFiServerAPI.cpp b/src/mesh/wifi/WiFiServerAPI.cpp index 98e38f9260..136dfadb7c 100644 --- a/src/mesh/wifi/WiFiServerAPI.cpp +++ b/src/mesh/wifi/WiFiServerAPI.cpp @@ -9,14 +9,14 @@ void initApiServer(int port) // Start API server on port 4403 if (!apiPort) { apiPort = new WiFiServerPort(port); - LOG_DEBUG("API server listening on TCP port %d\n", port); + LOG_INFO("API server listening on TCP port %d\n", port); apiPort->init(); } } WiFiServerAPI::WiFiServerAPI(WiFiClient &_client) : StreamAPI(&client), concurrency::OSThread("WiFiServerAPI"), client(_client) { - LOG_DEBUG("Incoming wifi connection\n"); + LOG_INFO("Incoming wifi connection\n"); } WiFiServerAPI::~WiFiServerAPI() @@ -44,7 +44,7 @@ int32_t WiFiServerAPI::runOnce() if (client.connected()) { return StreamAPI::runOncePart(); } else { - LOG_DEBUG("Client dropped connection, suspending API service\n"); + LOG_INFO("Client dropped connection, suspending API service\n"); enabled = false; // we no longer need to run return 0; } @@ -71,7 +71,7 @@ int32_t WiFiServerPort::runOnce() if (client) { // Close any previous connection (see FIXME in header file) if (openAPI) { - LOG_DEBUG("Force closing previous TCP connection\n"); + LOG_INFO("Force closing previous TCP connection\n"); delete openAPI; } diff --git a/src/modules/AdminModule.cpp b/src/modules/AdminModule.cpp index 30bff79b6a..b6ea8826ad 100644 --- a/src/modules/AdminModule.cpp +++ b/src/modules/AdminModule.cpp @@ -50,23 +50,23 @@ bool AdminModule::handleReceivedProtobuf(const MeshPacket &mp, AdminMessage *r) * Getters */ case AdminMessage_get_owner_request_tag: - LOG_DEBUG("Client is getting owner\n"); + LOG_INFO("Client is getting owner\n"); handleGetOwner(mp); break; case AdminMessage_get_config_request_tag: - LOG_DEBUG("Client is getting config\n"); + LOG_INFO("Client is getting config\n"); handleGetConfig(mp, r->get_config_request); break; case AdminMessage_get_module_config_request_tag: - LOG_DEBUG("Client is getting module config\n"); + LOG_INFO("Client is getting module config\n"); handleGetModuleConfig(mp, r->get_module_config_request); break; case AdminMessage_get_channel_request_tag: { uint32_t i = r->get_channel_request - 1; - LOG_DEBUG("Client is getting channel %u\n", i); + LOG_INFO("Client is getting channel %u\n", i); if (i >= MAX_NUM_CHANNELS) myReply = allocErrorResponse(Routing_Error_BAD_REQUEST, &mp); else @@ -78,22 +78,22 @@ bool AdminModule::handleReceivedProtobuf(const MeshPacket &mp, AdminMessage *r) * Setters */ case AdminMessage_set_owner_tag: - LOG_DEBUG("Client is setting owner\n"); + LOG_INFO("Client is setting owner\n"); handleSetOwner(r->set_owner); break; case AdminMessage_set_config_tag: - LOG_DEBUG("Client is setting the config\n"); + LOG_INFO("Client is setting the config\n"); handleSetConfig(r->set_config); break; case AdminMessage_set_module_config_tag: - LOG_DEBUG("Client is setting the module config\n"); + LOG_INFO("Client is setting the module config\n"); handleSetModuleConfig(r->set_module_config); break; case AdminMessage_set_channel_tag: - LOG_DEBUG("Client is setting channel %d\n", r->set_channel.index); + LOG_INFO("Client is setting channel %d\n", r->set_channel.index); if (r->set_channel.index < 0 || r->set_channel.index >= (int)MAX_NUM_CHANNELS) myReply = allocErrorResponse(Routing_Error_BAD_REQUEST, &mp); else @@ -111,15 +111,15 @@ bool AdminModule::handleReceivedProtobuf(const MeshPacket &mp, AdminMessage *r) int32_t s = r->reboot_ota_seconds; #ifdef ARCH_ESP32 if (BleOta::getOtaAppVersion().isEmpty()) { - LOG_DEBUG("No OTA firmware available, scheduling regular reboot in %d seconds\n", s); + LOG_INFO("No OTA firmware available, scheduling regular reboot in %d seconds\n", s); screen->startRebootScreen(); }else{ screen->startFirmwareUpdateScreen(); BleOta::switchToOtaApp(); - LOG_DEBUG("Rebooting to OTA in %d seconds\n", s); + LOG_INFO("Rebooting to OTA in %d seconds\n", s); } #else - LOG_DEBUG("Not on ESP32, scheduling regular reboot in %d seconds\n", s); + LOG_INFO("Not on ESP32, scheduling regular reboot in %d seconds\n", s); screen->startRebootScreen(); #endif rebootAtMsec = (s < 0) ? 0 : (millis() + s * 1000); @@ -127,40 +127,40 @@ bool AdminModule::handleReceivedProtobuf(const MeshPacket &mp, AdminMessage *r) } case AdminMessage_shutdown_seconds_tag: { int32_t s = r->shutdown_seconds; - LOG_DEBUG("Shutdown in %d seconds\n", s); + LOG_INFO("Shutdown in %d seconds\n", s); shutdownAtMsec = (s < 0) ? 0 : (millis() + s * 1000); break; } case AdminMessage_get_device_metadata_request_tag: { - LOG_DEBUG("Client is getting device metadata\n"); + LOG_INFO("Client is getting device metadata\n"); handleGetDeviceMetadata(mp); break; } case AdminMessage_factory_reset_tag: { - LOG_DEBUG("Initiating factory reset\n"); + LOG_INFO("Initiating factory reset\n"); nodeDB.factoryReset(); reboot(DEFAULT_REBOOT_SECONDS); break; } case AdminMessage_nodedb_reset_tag: { - LOG_DEBUG("Initiating node-db reset\n"); + LOG_INFO("Initiating node-db reset\n"); nodeDB.resetNodes(); reboot(DEFAULT_REBOOT_SECONDS); break; } case AdminMessage_begin_edit_settings_tag: { - LOG_DEBUG("Beginning transaction for editing settings\n"); + LOG_INFO("Beginning transaction for editing settings\n"); hasOpenEditTransaction = true; break; } case AdminMessage_commit_edit_settings_tag: { - LOG_DEBUG("Committing transaction for edited settings\n"); + LOG_INFO("Committing transaction for edited settings\n"); hasOpenEditTransaction = false; saveChanges(SEGMENT_CONFIG | SEGMENT_MODULECONFIG | SEGMENT_DEVICESTATE | SEGMENT_CHANNELS); break; } #ifdef ARCH_PORTDUINO case AdminMessage_exit_simulator_tag: - LOG_DEBUG("Exiting simulator\n"); + LOG_INFO("Exiting simulator\n"); _exit(0); break; #endif @@ -175,7 +175,7 @@ bool AdminModule::handleReceivedProtobuf(const MeshPacket &mp, AdminMessage *r) LOG_DEBUG("We did not responded to a request that wanted a respond. req.variant=%d\n", r->which_payload_variant); } else if (handleResult != AdminMessageHandleResult::HANDLED) { // Probably a message sent by us or sent to our local node. FIXME, we should avoid scanning these messages - LOG_DEBUG("Ignoring nonrelevant admin %d\n", r->which_payload_variant); + LOG_INFO("Ignoring nonrelevant admin %d\n", r->which_payload_variant); } break; } @@ -229,7 +229,7 @@ void AdminModule::handleSetConfig(const Config &c) switch (c.which_payload_variant) { case Config_device_tag: - LOG_DEBUG("Setting config: Device\n"); + LOG_INFO("Setting config: Device\n"); config.has_device = true; config.device = c.payload_variant.device; // If we're setting router role for the first time, install its intervals @@ -240,29 +240,29 @@ void AdminModule::handleSetConfig(const Config &c) } break; case Config_position_tag: - LOG_DEBUG("Setting config: Position\n"); + LOG_INFO("Setting config: Position\n"); config.has_position = true; config.position = c.payload_variant.position; // Save nodedb as well in case we got a fixed position packet saveChanges(SEGMENT_DEVICESTATE, false); break; case Config_power_tag: - LOG_DEBUG("Setting config: Power\n"); + LOG_INFO("Setting config: Power\n"); config.has_power = true; config.power = c.payload_variant.power; break; case Config_network_tag: - LOG_DEBUG("Setting config: WiFi\n"); + LOG_INFO("Setting config: WiFi\n"); config.has_network = true; config.network = c.payload_variant.network; break; case Config_display_tag: - LOG_DEBUG("Setting config: Display\n"); + LOG_INFO("Setting config: Display\n"); config.has_display = true; config.display = c.payload_variant.display; break; case Config_lora_tag: - LOG_DEBUG("Setting config: LoRa\n"); + LOG_INFO("Setting config: LoRa\n"); config.has_lora = true; config.lora = c.payload_variant.lora; if (isRegionUnset && @@ -271,7 +271,7 @@ void AdminModule::handleSetConfig(const Config &c) } break; case Config_bluetooth_tag: - LOG_DEBUG("Setting config: Bluetooth\n"); + LOG_INFO("Setting config: Bluetooth\n"); config.has_bluetooth = true; config.bluetooth = c.payload_variant.bluetooth; break; @@ -284,47 +284,47 @@ void AdminModule::handleSetModuleConfig(const ModuleConfig &c) { switch (c.which_payload_variant) { case ModuleConfig_mqtt_tag: - LOG_DEBUG("Setting module config: MQTT\n"); + LOG_INFO("Setting module config: MQTT\n"); moduleConfig.has_mqtt = true; moduleConfig.mqtt = c.payload_variant.mqtt; break; case ModuleConfig_serial_tag: - LOG_DEBUG("Setting module config: Serial\n"); + LOG_INFO("Setting module config: Serial\n"); moduleConfig.has_serial = true; moduleConfig.serial = c.payload_variant.serial; break; case ModuleConfig_external_notification_tag: - LOG_DEBUG("Setting module config: External Notification\n"); + LOG_INFO("Setting module config: External Notification\n"); moduleConfig.has_external_notification = true; moduleConfig.external_notification = c.payload_variant.external_notification; break; case ModuleConfig_store_forward_tag: - LOG_DEBUG("Setting module config: Store & Forward\n"); + LOG_INFO("Setting module config: Store & Forward\n"); moduleConfig.has_store_forward = true; moduleConfig.store_forward = c.payload_variant.store_forward; break; case ModuleConfig_range_test_tag: - LOG_DEBUG("Setting module config: Range Test\n"); + LOG_INFO("Setting module config: Range Test\n"); moduleConfig.has_range_test = true; moduleConfig.range_test = c.payload_variant.range_test; break; case ModuleConfig_telemetry_tag: - LOG_DEBUG("Setting module config: Telemetry\n"); + LOG_INFO("Setting module config: Telemetry\n"); moduleConfig.has_telemetry = true; moduleConfig.telemetry = c.payload_variant.telemetry; break; case ModuleConfig_canned_message_tag: - LOG_DEBUG("Setting module config: Canned Message\n"); + LOG_INFO("Setting module config: Canned Message\n"); moduleConfig.has_canned_message = true; moduleConfig.canned_message = c.payload_variant.canned_message; break; case ModuleConfig_audio_tag: - LOG_DEBUG("Setting module config: Audio\n"); + LOG_INFO("Setting module config: Audio\n"); moduleConfig.has_audio = true; moduleConfig.audio = c.payload_variant.audio; break; case ModuleConfig_remote_hardware_tag: - LOG_DEBUG("Setting module config: Remote Hardware\n"); + LOG_INFO("Setting module config: Remote Hardware\n"); moduleConfig.has_remote_hardware = true; moduleConfig.remote_hardware = c.payload_variant.remote_hardware; break; @@ -363,38 +363,38 @@ void AdminModule::handleGetConfig(const MeshPacket &req, const uint32_t configTy if (req.decoded.want_response) { switch (configType) { case AdminMessage_ConfigType_DEVICE_CONFIG: - LOG_DEBUG("Getting config: Device\n"); + LOG_INFO("Getting config: Device\n"); res.get_config_response.which_payload_variant = Config_device_tag; res.get_config_response.payload_variant.device = config.device; break; case AdminMessage_ConfigType_POSITION_CONFIG: - LOG_DEBUG("Getting config: Position\n"); + LOG_INFO("Getting config: Position\n"); res.get_config_response.which_payload_variant = Config_position_tag; res.get_config_response.payload_variant.position = config.position; break; case AdminMessage_ConfigType_POWER_CONFIG: - LOG_DEBUG("Getting config: Power\n"); + LOG_INFO("Getting config: Power\n"); res.get_config_response.which_payload_variant = Config_power_tag; res.get_config_response.payload_variant.power = config.power; break; case AdminMessage_ConfigType_NETWORK_CONFIG: - LOG_DEBUG("Getting config: Network\n"); + LOG_INFO("Getting config: Network\n"); res.get_config_response.which_payload_variant = Config_network_tag; res.get_config_response.payload_variant.network = config.network; writeSecret(res.get_config_response.payload_variant.network.wifi_psk, config.network.wifi_psk); break; case AdminMessage_ConfigType_DISPLAY_CONFIG: - LOG_DEBUG("Getting config: Display\n"); + LOG_INFO("Getting config: Display\n"); res.get_config_response.which_payload_variant = Config_display_tag; res.get_config_response.payload_variant.display = config.display; break; case AdminMessage_ConfigType_LORA_CONFIG: - LOG_DEBUG("Getting config: LoRa\n"); + LOG_INFO("Getting config: LoRa\n"); res.get_config_response.which_payload_variant = Config_lora_tag; res.get_config_response.payload_variant.lora = config.lora; break; case AdminMessage_ConfigType_BLUETOOTH_CONFIG: - LOG_DEBUG("Getting config: Bluetooth\n"); + LOG_INFO("Getting config: Bluetooth\n"); res.get_config_response.which_payload_variant = Config_bluetooth_tag; res.get_config_response.payload_variant.bluetooth = config.bluetooth; break; @@ -418,48 +418,48 @@ void AdminModule::handleGetModuleConfig(const MeshPacket &req, const uint32_t co if (req.decoded.want_response) { switch (configType) { case AdminMessage_ModuleConfigType_MQTT_CONFIG: - LOG_DEBUG("Getting module config: MQTT\n"); + LOG_INFO("Getting module config: MQTT\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_mqtt_tag; res.get_module_config_response.payload_variant.mqtt = moduleConfig.mqtt; break; case AdminMessage_ModuleConfigType_SERIAL_CONFIG: - LOG_DEBUG("Getting module config: Serial\n"); + LOG_INFO("Getting module config: Serial\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_serial_tag; res.get_module_config_response.payload_variant.serial = moduleConfig.serial; break; case AdminMessage_ModuleConfigType_EXTNOTIF_CONFIG: - LOG_DEBUG("Getting module config: External Notification\n"); + LOG_INFO("Getting module config: External Notification\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_external_notification_tag; res.get_module_config_response.payload_variant.external_notification = moduleConfig.external_notification; break; case AdminMessage_ModuleConfigType_STOREFORWARD_CONFIG: - LOG_DEBUG("Getting module config: Store & Forward\n"); + LOG_INFO("Getting module config: Store & Forward\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_store_forward_tag; res.get_module_config_response.payload_variant.store_forward = moduleConfig.store_forward; break; case AdminMessage_ModuleConfigType_RANGETEST_CONFIG: - LOG_DEBUG("Getting module config: Range Test\n"); + LOG_INFO("Getting module config: Range Test\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_range_test_tag; res.get_module_config_response.payload_variant.range_test = moduleConfig.range_test; break; case AdminMessage_ModuleConfigType_TELEMETRY_CONFIG: - LOG_DEBUG("Getting module config: Telemetry\n"); + LOG_INFO("Getting module config: Telemetry\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_telemetry_tag; res.get_module_config_response.payload_variant.telemetry = moduleConfig.telemetry; break; case AdminMessage_ModuleConfigType_CANNEDMSG_CONFIG: - LOG_DEBUG("Getting module config: Canned Message\n"); + LOG_INFO("Getting module config: Canned Message\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_canned_message_tag; res.get_module_config_response.payload_variant.canned_message = moduleConfig.canned_message; break; case AdminMessage_ModuleConfigType_AUDIO_CONFIG: - LOG_DEBUG("Getting module config: Audio\n"); + LOG_INFO("Getting module config: Audio\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_audio_tag; res.get_module_config_response.payload_variant.audio = moduleConfig.audio; break; case AdminMessage_ModuleConfigType_REMOTEHARDWARE_CONFIG: - LOG_DEBUG("Getting module config: Remote Hardware\n"); + LOG_INFO("Getting module config: Remote Hardware\n"); res.get_module_config_response.which_payload_variant = ModuleConfig_remote_hardware_tag; res.get_module_config_response.payload_variant.remote_hardware = moduleConfig.remote_hardware; break; @@ -506,7 +506,7 @@ void AdminModule::handleGetChannel(const MeshPacket &req, uint32_t channelIndex) void AdminModule::reboot(int32_t seconds) { - LOG_DEBUG("Rebooting in %d seconds\n", seconds); + LOG_INFO("Rebooting in %d seconds\n", seconds); screen->startRebootScreen(); rebootAtMsec = (seconds < 0) ? 0 : (millis() + seconds * 1000); } @@ -514,10 +514,10 @@ void AdminModule::reboot(int32_t seconds) void AdminModule::saveChanges(int saveWhat, bool shouldReboot) { if (!hasOpenEditTransaction) { - LOG_DEBUG("Saving changes to disk\n"); + LOG_INFO("Saving changes to disk\n"); service.reloadConfig(saveWhat); // Calls saveToDisk among other things } else { - LOG_DEBUG("Delaying save of changes to disk until the open transaction is committed\n"); + LOG_INFO("Delaying save of changes to disk until the open transaction is committed\n"); } if (shouldReboot) { diff --git a/src/modules/CannedMessageModule.cpp b/src/modules/CannedMessageModule.cpp index f1a9e099ff..f1ae94e6c3 100644 --- a/src/modules/CannedMessageModule.cpp +++ b/src/modules/CannedMessageModule.cpp @@ -49,10 +49,10 @@ CannedMessageModule::CannedMessageModule() if (moduleConfig.canned_message.enabled) { this->loadProtoForModule(); if ((this->splitConfiguredMessages() <= 0) && (cardkb_found != CARDKB_ADDR)) { - LOG_DEBUG("CannedMessageModule: No messages are configured. Module is disabled\n"); + LOG_INFO("CannedMessageModule: No messages are configured. Module is disabled\n"); this->runState = CANNED_MESSAGE_RUN_STATE_DISABLED; } else { - LOG_DEBUG("CannedMessageModule is enabled\n"); + LOG_INFO("CannedMessageModule is enabled\n"); this->inputObserver.observe(inputBroker); } } @@ -198,7 +198,7 @@ void CannedMessageModule::sendText(NodeNum dest, const char *message, bool wantR p->decoded.payload.size++; } - LOG_DEBUG("Sending message id=%d, dest=%x, msg=%.*s\n", p->id, p->to, p->decoded.payload.size, p->decoded.payload.bytes); + LOG_INFO("Sending message id=%d, dest=%x, msg=%.*s\n", p->id, p->to, p->decoded.payload.size, p->decoded.payload.bytes); service.sendToMesh(p); } diff --git a/src/modules/ExternalNotificationModule.cpp b/src/modules/ExternalNotificationModule.cpp index cabed32e3c..f1f1fb2c1c 100644 --- a/src/modules/ExternalNotificationModule.cpp +++ b/src/modules/ExternalNotificationModule.cpp @@ -48,15 +48,15 @@ int32_t ExternalNotificationModule::runOnce() if (nagCycleCutoff < millis()) { #endif nagCycleCutoff = UINT32_MAX; - LOG_DEBUG("Turning off external notification: "); + LOG_INFO("Turning off external notification: "); for (int i = 0; i < 2; i++) { if (getExternal(i)) { setExternalOff(i); externalTurnedOn[i] = 0; - LOG_DEBUG("%d ", i); + LOG_INFO("%d ", i); } } - LOG_DEBUG("\n"); + LOG_INFO("\n"); return INT32_MAX; // save cycles till we're needed again } @@ -175,26 +175,26 @@ ExternalNotificationModule::ExternalNotificationModule() strncpy(rtttlConfig.ringtone, "a:d=8,o=5,b=125:4d#6,a#,2d#6,16p,g#,4a#,4d#.,p,16g,16a#,d#6,a#,f6,2d#6,16p,c#.6,16c6,16a#,g#.,2a#", sizeof(rtttlConfig.ringtone)); } - LOG_DEBUG("Initializing External Notification Module\n"); + LOG_INFO("Initializing External Notification Module\n"); output = moduleConfig.external_notification.output ? moduleConfig.external_notification.output : EXT_NOTIFICATION_MODULE_OUTPUT; // Set the direction of a pin - LOG_DEBUG("Using Pin %i in digital mode\n", output); + LOG_INFO("Using Pin %i in digital mode\n", output); pinMode(output, OUTPUT); setExternalOff(0); externalTurnedOn[0] = 0; if(moduleConfig.external_notification.output_vibra) { - LOG_DEBUG("Using Pin %i for vibra motor\n", moduleConfig.external_notification.output_vibra); + LOG_INFO("Using Pin %i for vibra motor\n", moduleConfig.external_notification.output_vibra); pinMode(moduleConfig.external_notification.output_vibra, OUTPUT); setExternalOff(1); externalTurnedOn[1] = 0; } if(moduleConfig.external_notification.output_buzzer) { if (!moduleConfig.external_notification.use_pwm) { - LOG_DEBUG("Using Pin %i for buzzer\n", moduleConfig.external_notification.output_buzzer); + LOG_INFO("Using Pin %i for buzzer\n", moduleConfig.external_notification.output_buzzer); pinMode(moduleConfig.external_notification.output_buzzer, OUTPUT); setExternalOff(2); externalTurnedOn[2] = 0; @@ -203,11 +203,11 @@ ExternalNotificationModule::ExternalNotificationModule() ? config.device.buzzer_gpio : PIN_BUZZER; // in PWM Mode we force the buzzer pin if it is set - LOG_DEBUG("Using Pin %i in PWM mode\n", config.device.buzzer_gpio); + LOG_INFO("Using Pin %i in PWM mode\n", config.device.buzzer_gpio); } } } else { - LOG_DEBUG("External Notification Module Disabled\n"); + LOG_INFO("External Notification Module Disabled\n"); enabled = false; } } @@ -229,7 +229,7 @@ ProcessMessage ExternalNotificationModule::handleReceived(const MeshPacket &mp) if (moduleConfig.external_notification.alert_bell) { if (containsBell) { - LOG_DEBUG("externalNotificationModule - Notification Bell\n"); + LOG_INFO("externalNotificationModule - Notification Bell\n"); setExternalOn(0); if (moduleConfig.external_notification.nag_timeout) { nagCycleCutoff = millis() + moduleConfig.external_notification.nag_timeout * 1000; @@ -241,7 +241,7 @@ ProcessMessage ExternalNotificationModule::handleReceived(const MeshPacket &mp) if (moduleConfig.external_notification.alert_bell_vibra) { if (containsBell) { - LOG_DEBUG("externalNotificationModule - Notification Bell (Vibra)\n"); + LOG_INFO("externalNotificationModule - Notification Bell (Vibra)\n"); setExternalOn(1); if (moduleConfig.external_notification.nag_timeout) { nagCycleCutoff = millis() + moduleConfig.external_notification.nag_timeout * 1000; @@ -253,7 +253,7 @@ ProcessMessage ExternalNotificationModule::handleReceived(const MeshPacket &mp) if (moduleConfig.external_notification.alert_bell_buzzer) { if (containsBell) { - LOG_DEBUG("externalNotificationModule - Notification Bell (Buzzer)\n"); + LOG_INFO("externalNotificationModule - Notification Bell (Buzzer)\n"); if (!moduleConfig.external_notification.use_pwm) { setExternalOn(2); } else { @@ -270,7 +270,7 @@ ProcessMessage ExternalNotificationModule::handleReceived(const MeshPacket &mp) } if (moduleConfig.external_notification.alert_message) { - LOG_DEBUG("externalNotificationModule - Notification Module\n"); + LOG_INFO("externalNotificationModule - Notification Module\n"); setExternalOn(0); if (moduleConfig.external_notification.nag_timeout) { nagCycleCutoff = millis() + moduleConfig.external_notification.nag_timeout * 1000; @@ -281,7 +281,7 @@ ProcessMessage ExternalNotificationModule::handleReceived(const MeshPacket &mp) if (!moduleConfig.external_notification.use_pwm) { if (moduleConfig.external_notification.alert_message_vibra) { - LOG_DEBUG("externalNotificationModule - Notification Module (Vibra)\n"); + LOG_INFO("externalNotificationModule - Notification Module (Vibra)\n"); setExternalOn(1); if (moduleConfig.external_notification.nag_timeout) { nagCycleCutoff = millis() + moduleConfig.external_notification.nag_timeout * 1000; @@ -291,7 +291,7 @@ ProcessMessage ExternalNotificationModule::handleReceived(const MeshPacket &mp) } if (moduleConfig.external_notification.alert_message_buzzer) { - LOG_DEBUG("externalNotificationModule - Notification Module (Buzzer)\n"); + LOG_INFO("externalNotificationModule - Notification Module (Buzzer)\n"); if (!moduleConfig.external_notification.use_pwm) { setExternalOn(2); } else { @@ -310,7 +310,7 @@ ProcessMessage ExternalNotificationModule::handleReceived(const MeshPacket &mp) } } else { - LOG_DEBUG("External Notification Module Disabled\n"); + LOG_INFO("External Notification Module Disabled\n"); } return ProcessMessage::CONTINUE; // Let others look at this message also if they want @@ -331,13 +331,13 @@ AdminMessageHandleResult ExternalNotificationModule::handleAdminMessageForModule switch (request->which_payload_variant) { case AdminMessage_get_ringtone_request_tag: - LOG_DEBUG("Client is getting ringtone\n"); + LOG_INFO("Client is getting ringtone\n"); this->handleGetRingtone(mp, response); result = AdminMessageHandleResult::HANDLED_WITH_RESPONSE; break; case AdminMessage_set_ringtone_message_tag: - LOG_DEBUG("Client is setting ringtone\n"); + LOG_INFO("Client is setting ringtone\n"); this->handleSetRingtone(request->set_canned_message_module_messages); result = AdminMessageHandleResult::HANDLED; break; @@ -351,7 +351,7 @@ AdminMessageHandleResult ExternalNotificationModule::handleAdminMessageForModule void ExternalNotificationModule::handleGetRingtone(const MeshPacket &req, AdminMessage *response) { - LOG_DEBUG("*** handleGetRingtone\n"); + LOG_INFO("*** handleGetRingtone\n"); assert(req.decoded.want_response); response->which_payload_variant = AdminMessage_get_ringtone_response_tag; @@ -366,7 +366,7 @@ void ExternalNotificationModule::handleSetRingtone(const char *from_msg) if (*from_msg) { changed |= strcmp(rtttlConfig.ringtone, from_msg); strcpy(rtttlConfig.ringtone, from_msg); - LOG_DEBUG("*** from_msg.text:%s\n", from_msg); + LOG_INFO("*** from_msg.text:%s\n", from_msg); } if (changed) { diff --git a/src/modules/NodeInfoModule.cpp b/src/modules/NodeInfoModule.cpp index b4e0547171..d8047c5f09 100644 --- a/src/modules/NodeInfoModule.cpp +++ b/src/modules/NodeInfoModule.cpp @@ -46,7 +46,7 @@ MeshPacket *NodeInfoModule::allocReply() { User &u = owner; - LOG_DEBUG("sending owner %s/%s/%s\n", u.id, u.long_name, u.short_name); + LOG_INFO("sending owner %s/%s/%s\n", u.id, u.long_name, u.short_name); return allocDataProtobuf(u); } @@ -65,7 +65,7 @@ int32_t NodeInfoModule::runOnce() bool requestReplies = currentGeneration != radioGeneration; currentGeneration = radioGeneration; - LOG_DEBUG("Sending our nodeinfo to mesh (wantReplies=%d)\n", requestReplies); + LOG_INFO("Sending our nodeinfo to mesh (wantReplies=%d)\n", requestReplies); sendOurNodeInfo(NODENUM_BROADCAST, requestReplies); // Send our info (don't request replies) return default_broadcast_interval_secs * 1000; diff --git a/src/modules/PositionModule.cpp b/src/modules/PositionModule.cpp index 2df3b029b4..6680eaba58 100644 --- a/src/modules/PositionModule.cpp +++ b/src/modules/PositionModule.cpp @@ -32,7 +32,7 @@ bool PositionModule::handleReceivedProtobuf(const MeshPacket &mp, Position *pptr } // Log packet size and list of fields - LOG_DEBUG("POSITION node=%08x l=%d %s%s%s%s%s%s%s%s%s%s%s%s%s\n", getFrom(&mp), mp.decoded.payload.size, + LOG_INFO("POSITION node=%08x l=%d %s%s%s%s%s%s%s%s%s%s%s%s%s\n", getFrom(&mp), mp.decoded.payload.size, p.latitude_i ? "LAT " : "", p.longitude_i ? "LON " : "", p.altitude ? "MSL " : "", p.altitude_hae ? "HAE " : "", p.altitude_geoidal_separation ? "GEO " : "", p.PDOP ? "PDOP " : "", p.HDOP ? "HDOP " : "", p.VDOP ? "VDOP " : "", p.sats_in_view ? "SIV " : "", p.fix_quality ? "FXQ " : "", p.fix_type ? "FXT " : "", p.timestamp ? "PTS " : "", @@ -109,12 +109,12 @@ MeshPacket *PositionModule::allocReply() // nodes shouldn't trust it anyways) Note: we allow a device with a local GPS to include the time, so that gpsless // devices can get time. if (getRTCQuality() < RTCQualityDevice) { - LOG_DEBUG("Stripping time %u from position send\n", p.time); + LOG_INFO("Stripping time %u from position send\n", p.time); p.time = 0; } else - LOG_DEBUG("Providing time to mesh %u\n", p.time); + LOG_INFO("Providing time to mesh %u\n", p.time); - LOG_DEBUG("Position reply: time=%i, latI=%i, lonI=-%i\n", p.time, p.latitude_i, p.longitude_i); + LOG_INFO("Position reply: time=%i, latI=%i, lonI=-%i\n", p.time, p.latitude_i, p.longitude_i); return allocDataProtobuf(p); } @@ -155,11 +155,11 @@ int32_t PositionModule::runOnce() bool requestReplies = currentGeneration != radioGeneration; currentGeneration = radioGeneration; - LOG_DEBUG("Sending pos@%x:6 to mesh (wantReplies=%d)\n", node->position.timestamp, requestReplies); + LOG_INFO("Sending pos@%x:6 to mesh (wantReplies=%d)\n", node->position.timestamp, requestReplies); sendOurPosition(NODENUM_BROADCAST, requestReplies); } } else { - LOG_DEBUG("Channel utilization is >40 percent. Skipping this opportunity to send.\n"); + LOG_WARN("Channel utilization is >40 percent. Skipping this opportunity to send.\n"); } } else if (config.position.position_broadcast_smart_enabled) { @@ -194,7 +194,7 @@ int32_t PositionModule::runOnce() bool requestReplies = currentGeneration != radioGeneration; currentGeneration = radioGeneration; - LOG_DEBUG("Sending smart pos@%x:6 to mesh (wantReplies=%d, d=%d, dtt=%d, tt=%d)\n", node2->position.timestamp, + LOG_INFO("Sending smart pos@%x:6 to mesh (wantReplies=%d, d=%d, dtt=%d, tt=%d)\n", node2->position.timestamp, requestReplies, distance, distanceTravelThreshold, timeTravel); sendOurPosition(NODENUM_BROADCAST, requestReplies); @@ -209,7 +209,7 @@ int32_t PositionModule::runOnce() } } } else { - LOG_DEBUG("Channel utilization is >25 percent. Skipping this opportunity to send.\n"); + LOG_WARN("Channel utilization is >25 percent. Skipping this opportunity to send.\n"); } } diff --git a/src/modules/RemoteHardwareModule.cpp b/src/modules/RemoteHardwareModule.cpp index 9958fbe394..70d90063e7 100644 --- a/src/modules/RemoteHardwareModule.cpp +++ b/src/modules/RemoteHardwareModule.cpp @@ -55,7 +55,7 @@ RemoteHardwareModule::RemoteHardwareModule() bool RemoteHardwareModule::handleReceivedProtobuf(const MeshPacket &req, HardwareMessage *pptr) { auto p = *pptr; - LOG_DEBUG("Received RemoteHardware typ=%d\n", p.type); + LOG_INFO("Received RemoteHardware typ=%d\n", p.type); switch (p.type) { case HardwareMessage_Type_WRITE_GPIOS: @@ -95,7 +95,7 @@ bool RemoteHardwareModule::handleReceivedProtobuf(const MeshPacket &req, Hardwar lastWatchMsec = 0; // Force a new publish soon previousWatch = ~watchGpios; // generate a 'previous' value which is guaranteed to not match (to force an initial publish) enabled = true; // Let our thread run at least once - LOG_DEBUG("Now watching GPIOs 0x%llx\n", watchGpios); + LOG_INFO("Now watching GPIOs 0x%llx\n", watchGpios); break; } @@ -104,7 +104,7 @@ bool RemoteHardwareModule::handleReceivedProtobuf(const MeshPacket &req, Hardwar break; // Ignore - we might see our own replies default: - LOG_DEBUG("Hardware operation %d not yet implemented! FIXME\n", p.type); + LOG_ERROR("Hardware operation %d not yet implemented! FIXME\n", p.type); break; } @@ -121,7 +121,7 @@ int32_t RemoteHardwareModule::runOnce() if (curVal != previousWatch) { previousWatch = curVal; - LOG_DEBUG("Broadcasting GPIOS 0x%llx changed!\n", curVal); + LOG_INFO("Broadcasting GPIOS 0x%llx changed!\n", curVal); // Something changed! Tell the world with a broadcast message HardwareMessage r = HardwareMessage_init_default; diff --git a/src/modules/ReplyModule.cpp b/src/modules/ReplyModule.cpp index cd0dbec3a1..bf4e691fb1 100644 --- a/src/modules/ReplyModule.cpp +++ b/src/modules/ReplyModule.cpp @@ -11,7 +11,7 @@ MeshPacket *ReplyModule::allocReply() auto req = *currentRequest; auto &p = req.decoded; // The incoming message is in p.payload - LOG_DEBUG("Received message from=0x%0x, id=%d, msg=%.*s\n", req.from, req.id, p.payload.size, p.payload.bytes); + LOG_INFO("Received message from=0x%0x, id=%d, msg=%.*s\n", req.from, req.id, p.payload.size, p.payload.bytes); screen->print("Sending reply\n"); diff --git a/src/modules/SerialModule.cpp b/src/modules/SerialModule.cpp index f3708a7041..704c123cda 100644 --- a/src/modules/SerialModule.cpp +++ b/src/modules/SerialModule.cpp @@ -109,7 +109,7 @@ int32_t SerialModule::runOnce() if (firstTime) { // Interface with the serial peripheral from in here. - LOG_DEBUG("Initializing serial peripheral interface\n"); + LOG_INFO("Initializing serial peripheral interface\n"); uint32_t baud = 0; @@ -213,14 +213,14 @@ int32_t SerialModule::runOnce() serialModuleRadio->sendPayload(); - LOG_DEBUG("Received: %s\n", serialStringChar); + LOG_INFO("Received: %s\n", serialStringChar); } } } return (10); } else { - LOG_DEBUG("Serial Module Disabled\n"); + LOG_INFO("Serial Module Disabled\n"); return INT32_MAX; } @@ -305,7 +305,7 @@ ProcessMessage SerialModuleRadio::handleReceived(const MeshPacket &mp) } } else { - LOG_DEBUG("Serial Module Disabled\n"); + LOG_INFO("Serial Module Disabled\n"); } return ProcessMessage::CONTINUE; // Let others look at this message also if they want } diff --git a/src/modules/Telemetry/DeviceTelemetry.cpp b/src/modules/Telemetry/DeviceTelemetry.cpp index 301aa1797d..109d8b5b1d 100644 --- a/src/modules/Telemetry/DeviceTelemetry.cpp +++ b/src/modules/Telemetry/DeviceTelemetry.cpp @@ -34,7 +34,7 @@ bool DeviceTelemetryModule::handleReceivedProtobuf(const MeshPacket &mp, Telemet if (t->which_variant == Telemetry_device_metrics_tag) { const char *sender = getSenderShortName(mp); - LOG_DEBUG("(Received from %s): air_util_tx=%f, channel_utilization=%f, battery_level=%i, voltage=%f\n", + LOG_INFO("(Received from %s): air_util_tx=%f, channel_utilization=%f, battery_level=%i, voltage=%f\n", sender, t->variant.device_metrics.air_util_tx, t->variant.device_metrics.channel_utilization, @@ -60,7 +60,7 @@ bool DeviceTelemetryModule::sendTelemetry(NodeNum dest, bool phoneOnly) t.variant.device_metrics.channel_utilization = myNodeInfo.channel_utilization; t.variant.device_metrics.voltage = powerStatus->getBatteryVoltageMv() / 1000.0; - LOG_DEBUG("(Sending): air_util_tx=%f, channel_utilization=%f, battery_level=%i, voltage=%f\n", + LOG_INFO("(Sending): air_util_tx=%f, channel_utilization=%f, battery_level=%i, voltage=%f\n", t.variant.device_metrics.air_util_tx, t.variant.device_metrics.channel_utilization, t.variant.device_metrics.battery_level, @@ -74,10 +74,10 @@ bool DeviceTelemetryModule::sendTelemetry(NodeNum dest, bool phoneOnly) lastMeasurementPacket = packetPool.allocCopy(*p); nodeDB.updateTelemetry(nodeDB.getNodeNum(), t, RX_SRC_LOCAL); if (phoneOnly) { - LOG_DEBUG("Sending packet to phone\n"); + LOG_INFO("Sending packet to phone\n"); service.sendToPhone(p); } else { - LOG_DEBUG("Sending packet to mesh\n"); + LOG_INFO("Sending packet to mesh\n"); service.sendToMesh(p, RX_SRC_LOCAL, true); } return true; diff --git a/src/modules/Telemetry/EnvironmentTelemetry.cpp b/src/modules/Telemetry/EnvironmentTelemetry.cpp index fa90dc7cf6..3aeef50b29 100644 --- a/src/modules/Telemetry/EnvironmentTelemetry.cpp +++ b/src/modules/Telemetry/EnvironmentTelemetry.cpp @@ -75,7 +75,7 @@ int32_t EnvironmentTelemetryModule::runOnce() firstTime = 0; if (moduleConfig.telemetry.environment_measurement_enabled) { - LOG_DEBUG("Environment Telemetry: Initializing\n"); + LOG_INFO("Environment Telemetry: Initializing\n"); // it's possible to have this module enabled, only for displaying values on the screen. // therefore, we should only enable the sensor loop if measurement is also enabled if (bmp280Sensor.hasSensor()) @@ -162,7 +162,7 @@ void EnvironmentTelemetryModule::drawFrame(OLEDDisplay *display, OLEDDisplayUiSt if (!pb_decode_from_bytes(p.payload.bytes, p.payload.size, &Telemetry_msg, &lastMeasurement)) { display->setFont(FONT_SMALL); display->drawString(x, y += fontHeight(FONT_MEDIUM), "Measurement Error"); - LOG_DEBUG("Unable to decode last packet"); + LOG_ERROR("Unable to decode last packet"); return; } @@ -187,7 +187,7 @@ bool EnvironmentTelemetryModule::handleReceivedProtobuf(const MeshPacket &mp, Te if (t->which_variant == Telemetry_environment_metrics_tag) { const char *sender = getSenderShortName(mp); - LOG_DEBUG("(Received from %s): barometric_pressure=%f, current=%f, gas_resistance=%f, relative_humidity=%f, temperature=%f, voltage=%f\n", + LOG_INFO("(Received from %s): barometric_pressure=%f, current=%f, gas_resistance=%f, relative_humidity=%f, temperature=%f, voltage=%f\n", sender, t->variant.environment_metrics.barometric_pressure, t->variant.environment_metrics.current, @@ -234,7 +234,7 @@ bool EnvironmentTelemetryModule::sendTelemetry(NodeNum dest, bool phoneOnly) if (ina260Sensor.hasSensor()) ina260Sensor.getMetrics(&m); - LOG_DEBUG("(Sending): barometric_pressure=%f, current=%f, gas_resistance=%f, relative_humidity=%f, temperature=%f, voltage=%f\n", + LOG_INFO("(Sending): barometric_pressure=%f, current=%f, gas_resistance=%f, relative_humidity=%f, temperature=%f, voltage=%f\n", m.variant.environment_metrics.barometric_pressure, m.variant.environment_metrics.current, m.variant.environment_metrics.gas_resistance, @@ -251,10 +251,10 @@ bool EnvironmentTelemetryModule::sendTelemetry(NodeNum dest, bool phoneOnly) lastMeasurementPacket = packetPool.allocCopy(*p); if (phoneOnly) { - LOG_DEBUG("Sending packet to phone\n"); + LOG_INFO("Sending packet to phone\n"); service.sendToPhone(p); } else { - LOG_DEBUG("Sending packet to mesh\n"); + LOG_INFO("Sending packet to mesh\n"); service.sendToMesh(p, RX_SRC_LOCAL, true); } return true; diff --git a/src/modules/Telemetry/Sensor/BME280Sensor.cpp b/src/modules/Telemetry/Sensor/BME280Sensor.cpp index e33c1e014e..26f48f89d0 100644 --- a/src/modules/Telemetry/Sensor/BME280Sensor.cpp +++ b/src/modules/Telemetry/Sensor/BME280Sensor.cpp @@ -11,7 +11,7 @@ BME280Sensor::BME280Sensor() : } int32_t BME280Sensor::runOnce() { - LOG_DEBUG("Init sensor: %s\n", sensorName); + LOG_INFO("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } diff --git a/src/modules/Telemetry/Sensor/BME680Sensor.cpp b/src/modules/Telemetry/Sensor/BME680Sensor.cpp index f07de0d8df..44690fbaa2 100644 --- a/src/modules/Telemetry/Sensor/BME680Sensor.cpp +++ b/src/modules/Telemetry/Sensor/BME680Sensor.cpp @@ -10,7 +10,7 @@ BME680Sensor::BME680Sensor() : } int32_t BME680Sensor::runOnce() { - LOG_DEBUG("Init sensor: %s\n", sensorName); + LOG_INFO("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } diff --git a/src/modules/Telemetry/Sensor/BMP280Sensor.cpp b/src/modules/Telemetry/Sensor/BMP280Sensor.cpp index 29a73e2821..eddc30649e 100644 --- a/src/modules/Telemetry/Sensor/BMP280Sensor.cpp +++ b/src/modules/Telemetry/Sensor/BMP280Sensor.cpp @@ -11,7 +11,7 @@ BMP280Sensor::BMP280Sensor() : } int32_t BMP280Sensor::runOnce() { - LOG_DEBUG("Init sensor: %s\n", sensorName); + LOG_INFO("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } diff --git a/src/modules/Telemetry/Sensor/INA219Sensor.cpp b/src/modules/Telemetry/Sensor/INA219Sensor.cpp index 9ae886f154..4a732e73da 100644 --- a/src/modules/Telemetry/Sensor/INA219Sensor.cpp +++ b/src/modules/Telemetry/Sensor/INA219Sensor.cpp @@ -10,7 +10,7 @@ INA219Sensor::INA219Sensor() : } int32_t INA219Sensor::runOnce() { - LOG_DEBUG("Init sensor: %s\n", sensorName); + LOG_INFO("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } diff --git a/src/modules/Telemetry/Sensor/INA260Sensor.cpp b/src/modules/Telemetry/Sensor/INA260Sensor.cpp index e648cd824d..5b3064e7df 100644 --- a/src/modules/Telemetry/Sensor/INA260Sensor.cpp +++ b/src/modules/Telemetry/Sensor/INA260Sensor.cpp @@ -10,7 +10,7 @@ INA260Sensor::INA260Sensor() : } int32_t INA260Sensor::runOnce() { - LOG_DEBUG("Init sensor: %s\n", sensorName); + LOG_INFO("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } diff --git a/src/modules/Telemetry/Sensor/LPS22HBSensor.cpp b/src/modules/Telemetry/Sensor/LPS22HBSensor.cpp index 295fccdfc0..1f75a9aa16 100644 --- a/src/modules/Telemetry/Sensor/LPS22HBSensor.cpp +++ b/src/modules/Telemetry/Sensor/LPS22HBSensor.cpp @@ -11,7 +11,7 @@ LPS22HBSensor::LPS22HBSensor() : } int32_t LPS22HBSensor::runOnce() { - LOG_DEBUG("Init sensor: %s\n", sensorName); + LOG_INFO("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } diff --git a/src/modules/Telemetry/Sensor/MCP9808Sensor.cpp b/src/modules/Telemetry/Sensor/MCP9808Sensor.cpp index 3f0cafdfee..4dd3be635f 100644 --- a/src/modules/Telemetry/Sensor/MCP9808Sensor.cpp +++ b/src/modules/Telemetry/Sensor/MCP9808Sensor.cpp @@ -10,7 +10,7 @@ MCP9808Sensor::MCP9808Sensor() : } int32_t MCP9808Sensor::runOnce() { - LOG_DEBUG("Init sensor: %s\n", sensorName); + LOG_INFO("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } diff --git a/src/modules/Telemetry/Sensor/SHT31Sensor.cpp b/src/modules/Telemetry/Sensor/SHT31Sensor.cpp index 4d367823dd..528d5a030f 100644 --- a/src/modules/Telemetry/Sensor/SHT31Sensor.cpp +++ b/src/modules/Telemetry/Sensor/SHT31Sensor.cpp @@ -10,7 +10,7 @@ SHT31Sensor::SHT31Sensor() : } int32_t SHT31Sensor::runOnce() { - LOG_DEBUG("Init sensor: %s\n", sensorName); + LOG_INFO("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } diff --git a/src/modules/Telemetry/Sensor/SHTC3Sensor.cpp b/src/modules/Telemetry/Sensor/SHTC3Sensor.cpp index b19d126924..3a20d37a14 100644 --- a/src/modules/Telemetry/Sensor/SHTC3Sensor.cpp +++ b/src/modules/Telemetry/Sensor/SHTC3Sensor.cpp @@ -10,7 +10,7 @@ SHTC3Sensor::SHTC3Sensor() : } int32_t SHTC3Sensor::runOnce() { - LOG_DEBUG("Init sensor: %s\n", sensorName); + LOG_INFO("Init sensor: %s\n", sensorName); if (!hasSensor()) { return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; } diff --git a/src/modules/Telemetry/Sensor/TelemetrySensor.h b/src/modules/Telemetry/Sensor/TelemetrySensor.h index 642c82b3a6..87f2d68ba0 100644 --- a/src/modules/Telemetry/Sensor/TelemetrySensor.h +++ b/src/modules/Telemetry/Sensor/TelemetrySensor.h @@ -21,10 +21,10 @@ class TelemetrySensor int32_t initI2CSensor() { if (!status) { - LOG_DEBUG("Could not connect to detected %s sensor.\n Removing from nodeTelemetrySensorsMap.\n", sensorName); + LOG_WARN("Could not connect to detected %s sensor.\n Removing from nodeTelemetrySensorsMap.\n", sensorName); nodeTelemetrySensorsMap[sensorType] = 0; } else { - LOG_DEBUG("Opened %s sensor on default i2c bus\n", sensorName); + LOG_INFO("Opened %s sensor on default i2c bus\n", sensorName); setup(); } return DEFAULT_SENSOR_MINIMUM_WAIT_TIME_BETWEEN_READS; diff --git a/src/modules/TextMessageModule.cpp b/src/modules/TextMessageModule.cpp index 7e7115b8d4..c5dcca95a3 100644 --- a/src/modules/TextMessageModule.cpp +++ b/src/modules/TextMessageModule.cpp @@ -8,7 +8,7 @@ TextMessageModule *textMessageModule; ProcessMessage TextMessageModule::handleReceived(const MeshPacket &mp) { auto &p = mp.decoded; - LOG_DEBUG("Received text msg from=0x%0x, id=0x%x, msg=%.*s\n", mp.from, mp.id, p.payload.size, p.payload.bytes); + LOG_INFO("Received text msg from=0x%0x, id=0x%x, msg=%.*s\n", mp.from, mp.id, p.payload.size, p.payload.bytes); // We only store/display messages destined for us. // Keep a copy of the most recent text message. diff --git a/src/modules/TraceRouteModule.cpp b/src/modules/TraceRouteModule.cpp index 4558c59574..ba35a2f400 100644 --- a/src/modules/TraceRouteModule.cpp +++ b/src/modules/TraceRouteModule.cpp @@ -50,12 +50,12 @@ void TraceRouteModule::appendMyID(RouteDiscovery* updated) void TraceRouteModule::printRoute(RouteDiscovery* r, uint32_t origin, uint32_t dest) { - LOG_DEBUG("Route traced:\n"); - LOG_DEBUG("0x%x --> ", origin); + LOG_INFO("Route traced:\n"); + LOG_INFO("0x%x --> ", origin); for (uint8_t i=0; iroute_count; i++) { - LOG_DEBUG("0x%x --> ", r->route[i]); + LOG_INFO("0x%x --> ", r->route[i]); } - if (dest != NODENUM_BROADCAST) LOG_DEBUG("0x%x\n", dest); else LOG_DEBUG("...\n"); + if (dest != NODENUM_BROADCAST) LOG_INFO("0x%x\n", dest); else LOG_INFO("...\n"); } diff --git a/src/modules/WaypointModule.cpp b/src/modules/WaypointModule.cpp index 9ab9a5879e..6be2ff51a6 100644 --- a/src/modules/WaypointModule.cpp +++ b/src/modules/WaypointModule.cpp @@ -8,7 +8,7 @@ WaypointModule *waypointModule; ProcessMessage WaypointModule::handleReceived(const MeshPacket &mp) { auto &p = mp.decoded; - LOG_DEBUG("Received waypoint msg from=0x%0x, id=0x%x, msg=%.*s\n", mp.from, mp.id, p.payload.size, p.payload.bytes); + LOG_INFO("Received waypoint msg from=0x%0x, id=0x%x, msg=%.*s\n", mp.from, mp.id, p.payload.size, p.payload.bytes); notifyObservers(&mp); diff --git a/src/modules/esp32/AudioModule.cpp b/src/modules/esp32/AudioModule.cpp index 8a9dbcf7f5..27d4b6ba41 100644 --- a/src/modules/esp32/AudioModule.cpp +++ b/src/modules/esp32/AudioModule.cpp @@ -71,7 +71,7 @@ void run_codec2(void* parameter) // 4 bytes of header in each frame hex c0 de c2 plus the bitrate memcpy(audioModule->tx_encode_frame,&audioModule->tx_header,sizeof(audioModule->tx_header)); - LOG_DEBUG("Starting codec2 task\n"); + LOG_INFO("Starting codec2 task\n"); while (true) { uint32_t tcount = ulTaskNotifyTake(pdFALSE, pdMS_TO_TICKS(10000)); @@ -86,7 +86,7 @@ void run_codec2(void* parameter) if (audioModule->tx_encode_frame_index == (audioModule->encode_frame_size + sizeof(audioModule->tx_header))) { - LOG_DEBUG("Sending %d codec2 bytes\n", audioModule->encode_frame_size); + LOG_INFO("Sending %d codec2 bytes\n", audioModule->encode_frame_size); audioModule->sendPayload(); audioModule->tx_encode_frame_index = sizeof(audioModule->tx_header); } @@ -127,7 +127,7 @@ AudioModule::AudioModule() : SinglePortModule("AudioModule", PortNum_AUDIO_APP), // moduleConfig.audio.ptt_pin = 39; if ((moduleConfig.audio.codec2_enabled) && (myRegion->audioPermitted)) { - LOG_DEBUG("Setting up codec2 in mode %u", (moduleConfig.audio.bitrate ? moduleConfig.audio.bitrate : AUDIO_MODULE_MODE) - 1); + LOG_INFO("Setting up codec2 in mode %u", (moduleConfig.audio.bitrate ? moduleConfig.audio.bitrate : AUDIO_MODULE_MODE) - 1); codec2 = codec2_create((moduleConfig.audio.bitrate ? moduleConfig.audio.bitrate : AUDIO_MODULE_MODE) - 1); memcpy(tx_header.magic,c2_magic,sizeof(c2_magic)); tx_header.mode = (moduleConfig.audio.bitrate ? moduleConfig.audio.bitrate : AUDIO_MODULE_MODE) - 1; @@ -136,10 +136,10 @@ AudioModule::AudioModule() : SinglePortModule("AudioModule", PortNum_AUDIO_APP), encode_frame_num = (Constants_DATA_PAYLOAD_LEN - sizeof(tx_header)) / encode_codec_size; encode_frame_size = encode_frame_num * encode_codec_size; // max 233 bytes + 4 header bytes adc_buffer_size = codec2_samples_per_frame(codec2); - LOG_DEBUG(" using %d frames of %d bytes for a total payload length of %d bytes\n", encode_frame_num, encode_codec_size, encode_frame_size); + LOG_INFO(" using %d frames of %d bytes for a total payload length of %d bytes\n", encode_frame_num, encode_codec_size, encode_frame_size); xTaskCreate(&run_codec2, "codec2_task", 30000, NULL, 5, &codec2HandlerTask); } else { - LOG_DEBUG("Codec2 disabled (AudioModule %d, Region %s, permitted %d)\n", moduleConfig.audio.codec2_enabled, myRegion->name, myRegion->audioPermitted); + LOG_INFO("Codec2 disabled (AudioModule %d, Region %s, permitted %d)\n", moduleConfig.audio.codec2_enabled, myRegion->name, myRegion->audioPermitted); } } @@ -173,7 +173,7 @@ int32_t AudioModule::runOnce() esp_err_t res; if (firstTime) { // Set up I2S Processor configuration. This will produce 16bit samples at 8 kHz instead of 12 from the ADC - LOG_DEBUG("Initializing I2S SD: %d DIN: %d WS: %d SCK: %d\n", moduleConfig.audio.i2s_sd, moduleConfig.audio.i2s_din, moduleConfig.audio.i2s_ws, moduleConfig.audio.i2s_sck); + LOG_INFO("Initializing I2S SD: %d DIN: %d WS: %d SCK: %d\n", moduleConfig.audio.i2s_sd, moduleConfig.audio.i2s_din, moduleConfig.audio.i2s_ws, moduleConfig.audio.i2s_sck); i2s_config_t i2s_config = { .mode = (i2s_mode_t)(I2S_MODE_MASTER | (moduleConfig.audio.i2s_sd ? I2S_MODE_RX : 0) | (moduleConfig.audio.i2s_din ? I2S_MODE_TX : 0)), .sample_rate = 8000, @@ -189,7 +189,7 @@ int32_t AudioModule::runOnce() }; res = i2s_driver_install(I2S_PORT, &i2s_config, 0, NULL); if(res != ESP_OK) - LOG_DEBUG("Failed to install I2S driver: %d\n", res); + LOG_ERROR("Failed to install I2S driver: %d\n", res); const i2s_pin_config_t pin_config = { .bck_io_num = moduleConfig.audio.i2s_sck, @@ -199,16 +199,16 @@ int32_t AudioModule::runOnce() }; res = i2s_set_pin(I2S_PORT, &pin_config); if(res != ESP_OK) - LOG_DEBUG("Failed to set I2S pin config: %d\n", res); + LOG_ERROR("Failed to set I2S pin config: %d\n", res); res = i2s_start(I2S_PORT); if(res != ESP_OK) - LOG_DEBUG("Failed to start I2S: %d\n", res); + LOG_ERROR("Failed to start I2S: %d\n", res); radio_state = RadioState::rx; // Configure PTT input - LOG_DEBUG("Initializing PTT on Pin %u\n", moduleConfig.audio.ptt_pin ? moduleConfig.audio.ptt_pin : PTT_PIN); + LOG_INFO("Initializing PTT on Pin %u\n", moduleConfig.audio.ptt_pin ? moduleConfig.audio.ptt_pin : PTT_PIN); pinMode(moduleConfig.audio.ptt_pin ? moduleConfig.audio.ptt_pin : PTT_PIN, INPUT); firstTime = false; @@ -217,17 +217,17 @@ int32_t AudioModule::runOnce() // Check if PTT is pressed. TODO hook that into Onebutton/Interrupt drive. if (digitalRead(moduleConfig.audio.ptt_pin ? moduleConfig.audio.ptt_pin : PTT_PIN) == HIGH) { if (radio_state == RadioState::rx) { - LOG_DEBUG("PTT pressed, switching to TX\n"); + LOG_INFO("PTT pressed, switching to TX\n"); radio_state = RadioState::tx; e.frameChanged = true; this->notifyObservers(&e); } } else { if (radio_state == RadioState::tx) { - LOG_DEBUG("PTT released, switching to RX\n"); + LOG_INFO("PTT released, switching to RX\n"); if (tx_encode_frame_index > sizeof(tx_header)) { // Send the incomplete frame - LOG_DEBUG("Sending %d codec2 bytes (incomplete)\n", tx_encode_frame_index); + LOG_INFO("Sending %d codec2 bytes (incomplete)\n", tx_encode_frame_index); sendPayload(); } tx_encode_frame_index = sizeof(tx_header); @@ -258,7 +258,7 @@ int32_t AudioModule::runOnce() } return 100; } else { - LOG_DEBUG("Audio Module Disabled\n"); + LOG_INFO("Audio Module Disabled\n"); return INT32_MAX; } diff --git a/src/modules/esp32/RangeTestModule.cpp b/src/modules/esp32/RangeTestModule.cpp index e8e9f62dd3..4cc27833b1 100644 --- a/src/modules/esp32/RangeTestModule.cpp +++ b/src/modules/esp32/RangeTestModule.cpp @@ -53,10 +53,10 @@ int32_t RangeTestModule::runOnce() firstTime = 0; if (moduleConfig.range_test.sender) { - LOG_DEBUG("Initializing Range Test Module -- Sender\n"); + LOG_INFO("Initializing Range Test Module -- Sender\n"); return (5000); // Sending first message 5 seconds after initilization. } else { - LOG_DEBUG("Initializing Range Test Module -- Receiver\n"); + LOG_INFO("Initializing Range Test Module -- Receiver\n"); return (INT32_MAX); // This thread does not need to run as a receiver } @@ -65,19 +65,19 @@ int32_t RangeTestModule::runOnce() if (moduleConfig.range_test.sender) { // If sender - LOG_DEBUG("Range Test Module - Sending heartbeat every %d ms\n", (senderHeartbeat)); + LOG_INFO("Range Test Module - Sending heartbeat every %d ms\n", (senderHeartbeat)); - LOG_DEBUG("gpsStatus->getLatitude() %d\n", gpsStatus->getLatitude()); - LOG_DEBUG("gpsStatus->getLongitude() %d\n", gpsStatus->getLongitude()); - LOG_DEBUG("gpsStatus->getHasLock() %d\n", gpsStatus->getHasLock()); - LOG_DEBUG("gpsStatus->getDOP() %d\n", gpsStatus->getDOP()); - LOG_DEBUG("fixed_position() %d\n", config.position.fixed_position); + LOG_INFO("gpsStatus->getLatitude() %d\n", gpsStatus->getLatitude()); + LOG_INFO("gpsStatus->getLongitude() %d\n", gpsStatus->getLongitude()); + LOG_INFO("gpsStatus->getHasLock() %d\n", gpsStatus->getHasLock()); + LOG_INFO("gpsStatus->getDOP() %d\n", gpsStatus->getDOP()); + LOG_INFO("fixed_position() %d\n", config.position.fixed_position); // Only send packets if the channel is less than 25% utilized. if (airTime->channelUtilizationPercent() < 25) { rangeTestModuleRadio->sendPayload(); } else { - LOG_DEBUG("rangeTest - Channel utilization is >25 percent. Skipping this opportunity to send.\n"); + LOG_WARN("RangeTest - Channel utilization is >25 percent. Skipping this opportunity to send.\n"); } return (senderHeartbeat); @@ -88,9 +88,8 @@ int32_t RangeTestModule::runOnce() } - } else { - LOG_DEBUG("Range Test Module - Disabled\n"); + LOG_INFO("Range Test Module - Disabled\n"); } #endif @@ -136,7 +135,7 @@ ProcessMessage RangeTestModuleRadio::handleReceived(const MeshPacket &mp) /* auto &p = mp.decoded; LOG_DEBUG("Received text msg self=0x%0x, from=0x%0x, to=0x%0x, id=%d, msg=%.*s\n", - nodeDB.getNodeNum(), mp.from, mp.to, mp.id, p.payload.size, p.payload.bytes); + LOG_INFO.getNodeNum(), mp.from, mp.to, mp.id, p.payload.size, p.payload.bytes); */ if (getFrom(&mp) != nodeDB.getNodeNum()) { @@ -174,7 +173,7 @@ ProcessMessage RangeTestModuleRadio::handleReceived(const MeshPacket &mp) } } else { - LOG_DEBUG("Range Test Module Disabled\n"); + LOG_INFO("Range Test Module Disabled\n"); } #endif @@ -229,16 +228,16 @@ bool RangeTestModuleRadio::appendFile(const MeshPacket &mp) File fileToWrite = FSCom.open("/static/rangetest.csv", FILE_WRITE); if (!fileToWrite) { - LOG_DEBUG("There was an error opening the file for writing\n"); + LOG_ERROR("There was an error opening the file for writing\n"); return 0; } // Print the CSV header if (fileToWrite.println( "time,from,sender name,sender lat,sender long,rx lat,rx long,rx elevation,rx snr,distance,hop limit,payload")) { - LOG_DEBUG("File was written\n"); + LOG_INFO("File was written\n"); } else { - LOG_DEBUG("File write failed\n"); + LOG_ERROR("File write failed\n"); } fileToWrite.close(); @@ -248,7 +247,7 @@ bool RangeTestModuleRadio::appendFile(const MeshPacket &mp) File fileToAppend = FSCom.open("/static/rangetest.csv", FILE_APPEND); if (!fileToAppend) { - LOG_DEBUG("There was an error opening the file for appending\n"); + LOG_ERROR("There was an error opening the file for appending\n"); return 0; } diff --git a/src/modules/esp32/StoreForwardModule.cpp b/src/modules/esp32/StoreForwardModule.cpp index 524aa06709..5378d2c4da 100644 --- a/src/modules/esp32/StoreForwardModule.cpp +++ b/src/modules/esp32/StoreForwardModule.cpp @@ -28,20 +28,20 @@ int32_t StoreForwardModule::runOnce() StoreAndForward sf = StoreAndForward_init_zero; sf.rr = StoreAndForward_RequestResponse_ROUTER_PING; storeForwardModule->sendMessage(this->busyTo, sf); - LOG_DEBUG("*** S&F - Done. (ROUTER_PING)\n"); + LOG_INFO("*** S&F - Done. (ROUTER_PING)\n"); this->packetHistoryTXQueue_index = 0; this->busy = false; } else { this->packetHistoryTXQueue_index++; } } else { - LOG_DEBUG("*** Channel utilization is too high. Retrying later.\n"); + LOG_WARN("*** Channel utilization is too high. Retrying later.\n"); } LOG_DEBUG("*** SF bitrate = %f bytes / sec\n", myNodeInfo.bitrate); } else if ((millis() - lastHeartbeat > (heartbeatInterval * 1000)) && (airTime->channelUtilizationPercent() < polite_channel_util_percent)) { lastHeartbeat = millis(); - LOG_DEBUG("*** Sending heartbeat\n"); + LOG_INFO("*** Sending heartbeat\n"); StoreAndForward sf = StoreAndForward_init_zero; sf.rr = StoreAndForward_RequestResponse_ROUTER_HEARTBEAT; sf.which_variant = StoreAndForward_heartbeat_tag; @@ -87,11 +87,11 @@ void StoreForwardModule::historySend(uint32_t msAgo, uint32_t to) uint32_t queueSize = storeForwardModule->historyQueueCreate(msAgo, to); if (queueSize) { - LOG_DEBUG ("*** S&F - Sending %u message(s)\n", queueSize); + LOG_INFO("*** S&F - Sending %u message(s)\n", queueSize); this->busy = true; // runOnce() will pickup the next steps once busy = true. this->busyTo = to; } else { - LOG_DEBUG ("*** S&F - No history to send\n"); + LOG_INFO("*** S&F - No history to send\n"); } StoreAndForward sf = StoreAndForward_init_zero; sf.rr = StoreAndForward_RequestResponse_ROUTER_HISTORY; @@ -164,7 +164,7 @@ MeshPacket *StoreForwardModule::allocReply() void StoreForwardModule::sendPayload(NodeNum dest, uint32_t packetHistory_index) { - LOG_DEBUG("*** Sending S&F Payload\n"); + LOG_INFO("*** Sending S&F Payload\n"); MeshPacket *p = allocReply(); p->to = dest; @@ -241,7 +241,7 @@ ProcessMessage StoreForwardModule::handleReceived(const MeshPacket &mp) if (mp.decoded.portnum == PortNum_TEXT_MESSAGE_APP) { storeForwardModule->historyAdd(mp); - LOG_DEBUG("*** S&F stored. Message history contains %u records now.\n", this->packetHistoryCurrent); + LOG_INFO("*** S&F stored. Message history contains %u records now.\n", this->packetHistoryCurrent); } else if (mp.decoded.portnum == PortNum_STORE_FORWARD_APP) { auto &p = mp.decoded; @@ -251,7 +251,7 @@ ProcessMessage StoreForwardModule::handleReceived(const MeshPacket &mp) if (pb_decode_from_bytes(p.payload.bytes, p.payload.size, &StoreAndForward_msg, &scratch)) { decoded = &scratch; } else { - LOG_DEBUG("Error decoding protobuf module!\n"); + LOG_ERROR("Error decoding protobuf module!\n"); // if we can't decode it, nobody can process it! return ProcessMessage::STOP; } @@ -281,7 +281,7 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo if(is_server) { // stop sending stuff, the client wants to abort or has another error if ((this->busy) && (this->busyTo == getFrom(&mp))) { - LOG_DEBUG("*** Client in ERROR or ABORT requested\n"); + LOG_ERROR("*** Client in ERROR or ABORT requested\n"); this->packetHistoryTXQueue_index = 0; this->busy = false; } @@ -291,11 +291,11 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo case StoreAndForward_RequestResponse_CLIENT_HISTORY: if(is_server) { requests_history++; - LOG_DEBUG("*** Client Request to send HISTORY\n"); + LOG_INFO("*** Client Request to send HISTORY\n"); // Send the last 60 minutes of messages. if (this->busy) { storeForwardModule->sendMessage(getFrom(&mp), StoreAndForward_RequestResponse_ROUTER_BUSY); - LOG_DEBUG("*** S&F - Busy. Try again shortly.\n"); + LOG_INFO("*** S&F - Busy. Try again shortly.\n"); } else { if ((p->which_variant == StoreAndForward_history_tag) && (p->variant.history.window > 0)){ storeForwardModule->historySend(p->variant.history.window * 60000, getFrom(&mp)); // window is in minutes @@ -308,7 +308,7 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo case StoreAndForward_RequestResponse_CLIENT_PING: if(is_server) { - LOG_DEBUG("*** StoreAndForward_RequestResponse_CLIENT_PING\n"); + LOG_INFO("*** StoreAndForward_RequestResponse_CLIENT_PING\n"); // respond with a ROUTER PONG storeForwardModule->sendMessage(getFrom(&mp), StoreAndForward_RequestResponse_ROUTER_PONG); } @@ -316,7 +316,7 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo case StoreAndForward_RequestResponse_CLIENT_PONG: if(is_server) { - LOG_DEBUG("*** StoreAndForward_RequestResponse_CLIENT_PONG\n"); + LOG_INFO("*** StoreAndForward_RequestResponse_CLIENT_PONG\n"); // The Client is alive, update NodeDB nodeDB.updateFrom(mp); } @@ -324,10 +324,10 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo case StoreAndForward_RequestResponse_CLIENT_STATS: if(is_server) { - LOG_DEBUG("*** Client Request to send STATS\n"); + LOG_INFO("*** Client Request to send STATS\n"); if (this->busy) { storeForwardModule->sendMessage(getFrom(&mp), StoreAndForward_RequestResponse_ROUTER_BUSY); - LOG_DEBUG("*** S&F - Busy. Try again shortly.\n"); + LOG_INFO("*** S&F - Busy. Try again shortly.\n"); } else { storeForwardModule->statsSend(getFrom(&mp)); } @@ -352,7 +352,7 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo heartbeatInterval = p->variant.heartbeat.period; } lastHeartbeat = millis(); - LOG_DEBUG("*** StoreAndForward Heartbeat received\n"); + LOG_INFO("*** StoreAndForward Heartbeat received\n"); } break; @@ -386,7 +386,7 @@ bool StoreForwardModule::handleReceivedProtobuf(const MeshPacket &mp, StoreAndFo // These fields only have informational purpose on a client. Fill them to consume later. if (p->which_variant == StoreAndForward_history_tag) { this->historyReturnWindow = p->variant.history.window / 60000; - LOG_DEBUG("*** Router Response HISTORY - Sending %d messages from last %d minutes\n", p->variant.history.history_messages, this->historyReturnWindow); + LOG_INFO("*** Router Response HISTORY - Sending %d messages from last %d minutes\n", p->variant.history.history_messages, this->historyReturnWindow); } } break; @@ -418,7 +418,7 @@ StoreForwardModule::StoreForwardModule() // Router if ((config.device.role == Config_DeviceConfig_Role_ROUTER) || (config.device.role == Config_DeviceConfig_Role_ROUTER_CLIENT)) { - LOG_DEBUG("*** Initializing Store & Forward Module in Router mode\n"); + LOG_INFO("*** Initializing Store & Forward Module in Router mode\n"); if (ESP.getPsramSize() > 0) { if (ESP.getFreePsram() >= 1024 * 1024) { @@ -444,19 +444,19 @@ StoreForwardModule::StoreForwardModule() this->populatePSRAM(); is_server = true; } else { - LOG_DEBUG("*** Device has less than 1M of PSRAM free.\n"); - LOG_DEBUG("*** Store & Forward Module - disabling server.\n"); + LOG_INFO("*** Device has less than 1M of PSRAM free.\n"); + LOG_INFO("*** Store & Forward Module - disabling server.\n"); } } else { - LOG_DEBUG("*** Device doesn't have PSRAM.\n"); - LOG_DEBUG("*** Store & Forward Module - disabling server.\n"); + LOG_INFO("*** Device doesn't have PSRAM.\n"); + LOG_INFO("*** Store & Forward Module - disabling server.\n"); } // Client } if ((config.device.role == Config_DeviceConfig_Role_CLIENT) || (config.device.role == Config_DeviceConfig_Role_ROUTER_CLIENT)) { is_client = true; - LOG_DEBUG("*** Initializing Store & Forward Module in Client mode\n"); + LOG_INFO("*** Initializing Store & Forward Module in Client mode\n"); } } #endif diff --git a/src/mqtt/MQTT.cpp b/src/mqtt/MQTT.cpp index 33122d091b..b5550d3ffa 100644 --- a/src/mqtt/MQTT.cpp +++ b/src/mqtt/MQTT.cpp @@ -42,7 +42,7 @@ void MQTT::onPublish(char *topic, byte *payload, unsigned int length) payloadStr[length] = 0; // null terminated string JSONValue *json_value = JSON::Parse(payloadStr); if (json_value != NULL) { - LOG_DEBUG("JSON Received on MQTT, parsing..\n"); + LOG_INFO("JSON Received on MQTT, parsing..\n"); // check if it is a valid envelope JSONObject json; json = json_value->AsObject(); @@ -50,7 +50,7 @@ void MQTT::onPublish(char *topic, byte *payload, unsigned int length) // this is a valid envelope if (json["payload"]->IsString() && json["type"]->IsString() && (json["sender"]->AsString().compare(owner.id) != 0)) { std::string jsonPayloadStr = json["payload"]->AsString(); - LOG_DEBUG("JSON payload %s, length %u\n", jsonPayloadStr.c_str(), jsonPayloadStr.length()); + LOG_INFO("JSON payload %s, length %u\n", jsonPayloadStr.c_str(), jsonPayloadStr.length()); // construct protobuf data packet using TEXT_MESSAGE, send it to the mesh MeshPacket *p = router->allocForSending(); @@ -61,7 +61,7 @@ void MQTT::onPublish(char *topic, byte *payload, unsigned int length) MeshPacket *packet = packetPool.allocCopy(*p); service.sendToMesh(packet, RX_SRC_LOCAL); } else { - LOG_DEBUG("Received MQTT json payload too long, dropping\n"); + LOG_WARN("Received MQTT json payload too long, dropping\n"); } } else { LOG_DEBUG("JSON Ignoring downlink message we originally sent.\n"); @@ -87,23 +87,23 @@ void MQTT::onPublish(char *topic, byte *payload, unsigned int length) LOG_DEBUG("JSON Ignoring downlink message we originally sent.\n"); } } else{ - LOG_DEBUG("JSON Received payload on MQTT but not a valid envelope\n"); + LOG_ERROR("JSON Received payload on MQTT but not a valid envelope\n"); } } else { // no json, this is an invalid payload - LOG_DEBUG("Invalid MQTT service envelope, topic %s, len %u!\n", topic, length); + LOG_ERROR("Invalid MQTT service envelope, topic %s, len %u!\n", topic, length); } delete json_value; } else { if (!pb_decode_from_bytes(payload, length, &ServiceEnvelope_msg, &e)) { - LOG_DEBUG("Invalid MQTT service envelope, topic %s, len %u!\n", topic, length); + LOG_ERROR("Invalid MQTT service envelope, topic %s, len %u!\n", topic, length); return; }else { if (strcmp(e.gateway_id, owner.id) == 0) - LOG_DEBUG("Ignoring downlink message we originally sent.\n"); + LOG_INFO("Ignoring downlink message we originally sent.\n"); else { if (e.packet) { - LOG_DEBUG("Received MQTT topic %s, len=%u\n", topic, length); + LOG_INFO("Received MQTT topic %s, len=%u\n", topic, length); MeshPacket *p = packetPool.allocCopy(*e.packet); // ignore messages sent by us or if we don't have the channel key @@ -166,22 +166,22 @@ void MQTT::reconnect() } pubSub.setServer(serverAddr, serverPort); - LOG_DEBUG("Connecting to MQTT server %s, port: %d, username: %s, password: %s\n", serverAddr, serverPort, mqttUsername, mqttPassword); + LOG_INFO("Connecting to MQTT server %s, port: %d, username: %s, password: %s\n", serverAddr, serverPort, mqttUsername, mqttPassword); auto myStatus = (statusTopic + owner.id); bool connected = pubSub.connect(owner.id, mqttUsername, mqttPassword, myStatus.c_str(), 1, true, "offline"); if (connected) { - LOG_DEBUG("MQTT connected\n"); + LOG_INFO("MQTT connected\n"); enabled = true; // Start running background process again runASAP = true; reconnectCount = 0; /// FIXME, include more information in the status text bool ok = pubSub.publish(myStatus.c_str(), "online", true); - LOG_DEBUG("published %d\n", ok); + LOG_INFO("published %d\n", ok); sendSubscriptions(); } else { - LOG_DEBUG("Failed to contact MQTT server (%d/10)...\n",reconnectCount); + LOG_ERROR("Failed to contact MQTT server (%d/10)...\n",reconnectCount); #if HAS_WIFI && !defined(ARCH_PORTDUINO) if (reconnectCount > 9) { needReconnect = true; @@ -200,11 +200,11 @@ void MQTT::sendSubscriptions() auto &ch = channels.getByIndex(i); if (ch.settings.downlink_enabled) { String topic = cryptTopic + channels.getGlobalId(i) + "/#"; - LOG_DEBUG("Subscribing to %s\n", topic.c_str()); + LOG_INFO("Subscribing to %s\n", topic.c_str()); pubSub.subscribe(topic.c_str(), 1); // FIXME, is QOS 1 right? if (moduleConfig.mqtt.json_enabled == true) { String topicDecoded = jsonTopic + channels.getGlobalId(i) + "/#"; - LOG_DEBUG("Subscribing to %s\n", topicDecoded.c_str()); + LOG_INFO("Subscribing to %s\n", topicDecoded.c_str()); pubSub.subscribe(topicDecoded.c_str(), 1); // FIXME, is QOS 1 right? } } @@ -254,7 +254,7 @@ int32_t MQTT::runOnce() size_t numBytes = pb_encode_to_bytes(bytes, sizeof(bytes), &ServiceEnvelope_msg, env); String topic = cryptTopic + env->channel_id + "/" + owner.id; - LOG_DEBUG("publish %s, %u bytes from queue\n", topic.c_str(), numBytes); + LOG_INFO("publish %s, %u bytes from queue\n", topic.c_str(), numBytes); pubSub.publish(topic.c_str(), bytes, numBytes, false); @@ -264,7 +264,7 @@ int32_t MQTT::runOnce() auto jsonString = this->downstreamPacketToJson(env->packet); if (jsonString.length() != 0) { String topicJson = jsonTopic + env->channel_id + "/" + owner.id; - LOG_DEBUG("JSON publish message to %s, %u bytes: %s\n", topicJson.c_str(), jsonString.length(), jsonString.c_str()); + LOG_INFO("JSON publish message to %s, %u bytes: %s\n", topicJson.c_str(), jsonString.length(), jsonString.c_str()); pubSub.publish(topicJson.c_str(), jsonString.c_str(), false); } } @@ -279,7 +279,7 @@ int32_t MQTT::runOnce() } else { // we are connected to server, check often for new requests on the TCP port if (!wantConnection) { - LOG_DEBUG("MQTT link not needed, dropping\n"); + LOG_INFO("MQTT link not needed, dropping\n"); pubSub.disconnect(); } @@ -317,14 +317,14 @@ void MQTT::onSend(const MeshPacket &mp, ChannelIndex chIndex) auto jsonString = this->downstreamPacketToJson((MeshPacket *)&mp); if (jsonString.length() != 0) { String topicJson = jsonTopic + channelId + "/" + owner.id; - LOG_DEBUG("JSON publish message to %s, %u bytes: %s\n", topicJson.c_str(), jsonString.length(), jsonString.c_str()); + LOG_INFO("JSON publish message to %s, %u bytes: %s\n", topicJson.c_str(), jsonString.length(), jsonString.c_str()); pubSub.publish(topicJson.c_str(), jsonString.c_str(), false); } } } else { - LOG_DEBUG("MQTT not connected, queueing packet\n"); + LOG_INFO("MQTT not connected, queueing packet\n"); if (mqttQueue.numFree() == 0) { - LOG_DEBUG("NOTE: MQTT queue is full, discarding oldest\n"); + LOG_WARN("NOTE: MQTT queue is full, discarding oldest\n"); ServiceEnvelope *d = mqttQueue.dequeuePtr(0); if (d) mqttPool.release(d); @@ -357,13 +357,13 @@ std::string MQTT::downstreamPacketToJson(MeshPacket *mp) // check if this is a JSON payload JSONValue *json_value = JSON::Parse(payloadStr); if (json_value != NULL) { - LOG_DEBUG("text message payload is of type json\n"); + LOG_INFO("text message payload is of type json\n"); // if it is, then we can just use the json object jsonObj["payload"] = json_value; } else { // if it isn't, then we need to create a json object // with the string as the value - LOG_DEBUG("text message payload is of type plaintext\n"); + LOG_INFO("text message payload is of type plaintext\n"); msgPayload["text"] = new JSONValue(payloadStr); jsonObj["payload"] = new JSONValue(msgPayload); } @@ -392,7 +392,7 @@ std::string MQTT::downstreamPacketToJson(MeshPacket *mp) } jsonObj["payload"] = new JSONValue(msgPayload); } else - LOG_DEBUG("Error decoding protobuf for telemetry message!\n"); + LOG_ERROR("Error decoding protobuf for telemetry message!\n"); }; break; } @@ -410,7 +410,7 @@ std::string MQTT::downstreamPacketToJson(MeshPacket *mp) msgPayload["hardware"] = new JSONValue(decoded->hw_model); jsonObj["payload"] = new JSONValue(msgPayload); } else - LOG_DEBUG("Error decoding protobuf for nodeinfo message!\n"); + LOG_ERROR("Error decoding protobuf for nodeinfo message!\n"); }; break; } @@ -429,7 +429,7 @@ std::string MQTT::downstreamPacketToJson(MeshPacket *mp) if((int)decoded->altitude){msgPayload["altitude"] = new JSONValue((int)decoded->altitude);} jsonObj["payload"] = new JSONValue(msgPayload); } else { - LOG_DEBUG("Error decoding protobuf for position message!\n"); + LOG_ERROR("Error decoding protobuf for position message!\n"); } }; break; @@ -452,7 +452,7 @@ std::string MQTT::downstreamPacketToJson(MeshPacket *mp) msgPayload["longitude_i"] = new JSONValue((int)decoded->longitude_i); jsonObj["payload"] = new JSONValue(msgPayload); } else { - LOG_DEBUG("Error decoding protobuf for position message!\n"); + LOG_ERROR("Error decoding protobuf for position message!\n"); } }; break; @@ -474,7 +474,7 @@ std::string MQTT::downstreamPacketToJson(MeshPacket *mp) JSONValue *value = new JSONValue(jsonObj); std::string jsonStr = value->Stringify(); - LOG_DEBUG("serialized json message: %s\n", jsonStr.c_str()); + LOG_INFO("serialized json message: %s\n", jsonStr.c_str()); delete value; return jsonStr; diff --git a/src/nimble/NimbleBluetooth.cpp b/src/nimble/NimbleBluetooth.cpp index ae33e47026..78bf135fe5 100644 --- a/src/nimble/NimbleBluetooth.cpp +++ b/src/nimble/NimbleBluetooth.cpp @@ -22,7 +22,7 @@ class BluetoothPhoneAPI : public PhoneAPI { PhoneAPI::onNowHasData(fromRadioNum); - LOG_DEBUG("BLE notify fromNum\n"); + LOG_INFO("BLE notify fromNum\n"); uint8_t val[4]; put_le32(val, fromRadioNum); @@ -46,7 +46,7 @@ static BluetoothPhoneAPI *bluetoothPhoneAPI; class NimbleBluetoothToRadioCallback : public NimBLECharacteristicCallbacks { virtual void onWrite(NimBLECharacteristic *pCharacteristic) { - LOG_DEBUG("To Radio onwrite\n"); + LOG_INFO("To Radio onwrite\n"); auto val = pCharacteristic->getValue(); bluetoothPhoneAPI->handleToRadio(val.data(), val.length()); @@ -56,7 +56,7 @@ class NimbleBluetoothToRadioCallback : public NimBLECharacteristicCallbacks class NimbleBluetoothFromRadioCallback : public NimBLECharacteristicCallbacks { virtual void onRead(NimBLECharacteristic *pCharacteristic) { - LOG_DEBUG("From Radio onread\n"); + LOG_INFO("From Radio onread\n"); uint8_t fromRadioBytes[FromRadio_size]; size_t numBytes = bluetoothPhoneAPI->getFromRadio(fromRadioBytes); @@ -72,11 +72,11 @@ class NimbleBluetoothServerCallback : public NimBLEServerCallbacks uint32_t passkey = config.bluetooth.fixed_pin; if (config.bluetooth.mode == Config_BluetoothConfig_PairingMode_RANDOM_PIN) { - LOG_DEBUG("Using random passkey\n"); + LOG_INFO("Using random passkey\n"); // This is the passkey to be entered on peer - we pick a number >100,000 to ensure 6 digits passkey = random(100000, 999999); } - LOG_DEBUG("*** Enter passkey %d on the peer side ***\n", passkey); + LOG_INFO("*** Enter passkey %d on the peer side ***\n", passkey); powerFSM.trigger(EVENT_BLUETOOTH_PAIR); screen->startBluetoothPinScreen(passkey); @@ -87,7 +87,7 @@ class NimbleBluetoothServerCallback : public NimBLEServerCallbacks virtual void onAuthenticationComplete(ble_gap_conn_desc *desc) { - LOG_DEBUG("BLE authentication complete\n"); + LOG_INFO("BLE authentication complete\n"); if (passkeyShowing) { passkeyShowing = false; @@ -98,7 +98,7 @@ class NimbleBluetoothServerCallback : public NimBLEServerCallbacks virtual void onDisconnect(NimBLEServer* pServer, ble_gap_conn_desc *desc) { - LOG_DEBUG("BLE disconnect\n"); + LOG_INFO("BLE disconnect\n"); } }; @@ -108,7 +108,7 @@ static NimbleBluetoothFromRadioCallback *fromRadioCallbacks; void NimbleBluetooth::shutdown() { // Shutdown bluetooth for minimum power draw - LOG_DEBUG("Disable bluetooth\n"); + LOG_INFO("Disable bluetooth\n"); //Bluefruit.Advertising.stop(); NimBLEAdvertising *pAdvertising = NimBLEDevice::getAdvertising(); pAdvertising->reset(); @@ -125,7 +125,7 @@ void NimbleBluetooth::setup() // Uncomment for testing // NimbleBluetooth::clearBonds(); - LOG_DEBUG("Initialise the NimBLE bluetooth module\n"); + LOG_INFO("Initialise the NimBLE bluetooth module\n"); NimBLEDevice::init(getDeviceName()); NimBLEDevice::setPower(ESP_PWR_LVL_P9); @@ -186,7 +186,7 @@ void updateBatteryLevel(uint8_t level) void NimbleBluetooth::clearBonds() { - LOG_DEBUG("Clearing bluetooth bonds!\n"); + LOG_INFO("Clearing bluetooth bonds!\n"); NimBLEDevice::deleteAllBonds(); } diff --git a/src/platform/esp32/SimpleAllocator.cpp b/src/platform/esp32/SimpleAllocator.cpp index 4855e8edf2..9e2a0c7d21 100644 --- a/src/platform/esp32/SimpleAllocator.cpp +++ b/src/platform/esp32/SimpleAllocator.cpp @@ -9,7 +9,7 @@ void *SimpleAllocator::alloc(size_t size) assert(nextFree + size <= sizeof(bytes)); void *res = &bytes[nextFree]; nextFree += size; - Serial.printf("Total simple allocs %u\n", nextFree); + LOG_DEBUG("Total simple allocs %u\n", nextFree); return res; } @@ -52,7 +52,7 @@ void *operator new(size_t sz) throw(std::bad_alloc) void operator delete(void *ptr) throw() { if (activeAllocator) - Serial.println("Warning: leaking an active allocator object"); // We don't properly handle this yet + LOG_DEBUG("Warning: leaking an active allocator object\n"); // We don't properly handle this yet else free(ptr); } diff --git a/src/platform/nrf52/NRF52Bluetooth.cpp b/src/platform/nrf52/NRF52Bluetooth.cpp index 950d6b7a46..7bbc1a7bba 100644 --- a/src/platform/nrf52/NRF52Bluetooth.cpp +++ b/src/platform/nrf52/NRF52Bluetooth.cpp @@ -33,7 +33,7 @@ class BluetoothPhoneAPI : public PhoneAPI { PhoneAPI::onNowHasData(fromRadioNum); - LOG_DEBUG("BLE notify fromNum\n"); + LOG_INFO("BLE notify fromNum\n"); fromNum.notify32(fromRadioNum); } @@ -55,7 +55,7 @@ void onConnect(uint16_t conn_handle) char central_name[32] = {0}; connection->getPeerName(central_name, sizeof(central_name)); - LOG_DEBUG("BLE Connected to %s\n", central_name); + LOG_INFO("BLE Connected to %s\n", central_name); } /** @@ -66,21 +66,21 @@ void onConnect(uint16_t conn_handle) void onDisconnect(uint16_t conn_handle, uint8_t reason) { // FIXME - we currently assume only one active connection - LOG_DEBUG("BLE Disconnected, reason = 0x%x\n", reason); + LOG_INFO("BLE Disconnected, reason = 0x%x\n", reason); } void onCccd(uint16_t conn_hdl, BLECharacteristic *chr, uint16_t cccd_value) { // Display the raw request packet - LOG_DEBUG("CCCD Updated: %u\n", cccd_value); + LOG_INFO("CCCD Updated: %u\n", cccd_value); // Check the characteristic this CCCD update is associated with in case // this handler is used for multiple CCCD records. if (chr->uuid == fromNum.uuid) { if (chr->notifyEnabled(conn_hdl)) { - LOG_DEBUG("fromNum 'Notify' enabled\n"); + LOG_INFO("fromNum 'Notify' enabled\n"); } else { - LOG_DEBUG("fromNum 'Notify' disabled\n"); + LOG_INFO("fromNum 'Notify' disabled\n"); } } } @@ -135,14 +135,14 @@ void onFromRadioAuthorize(uint16_t conn_hdl, BLECharacteristic *chr, ble_gatts_e // or make empty if the queue is empty fromRadio.write(fromRadioBytes, numBytes); } else { - // LOG_DEBUG("Ignoring successor read\n"); + // LOG_INFO("Ignoring successor read\n"); } authorizeRead(conn_hdl); } void onToRadioWrite(uint16_t conn_hdl, BLECharacteristic *chr, uint8_t *data, uint16_t len) { - LOG_DEBUG("toRadioWriteCb data %p, len %u\n", data, len); + LOG_INFO("toRadioWriteCb data %p, len %u\n", data, len); bluetoothPhoneAPI->handleToRadio(data, len); } @@ -152,7 +152,7 @@ void onToRadioWrite(uint16_t conn_hdl, BLECharacteristic *chr, uint8_t *data, ui */ void onFromNumAuthorize(uint16_t conn_hdl, BLECharacteristic *chr, ble_gatts_evt_read_t *request) { - LOG_DEBUG("fromNumAuthorizeCb\n"); + LOG_INFO("fromNumAuthorizeCb\n"); authorizeRead(conn_hdl); } @@ -204,14 +204,14 @@ static uint32_t configuredPasskey; void NRF52Bluetooth::shutdown() { // Shutdown bluetooth for minimum power draw - LOG_DEBUG("Disable NRF52 bluetooth\n"); + LOG_INFO("Disable NRF52 bluetooth\n"); Bluefruit.Advertising.stop(); } void NRF52Bluetooth::setup() { // Initialise the Bluefruit module - LOG_DEBUG("Initialize the Bluefruit nRF52 module\n"); + LOG_INFO("Initialize the Bluefruit nRF52 module\n"); Bluefruit.autoConnLed(false); Bluefruit.configPrphBandwidth(BANDWIDTH_MAX); Bluefruit.begin(); @@ -225,7 +225,7 @@ void NRF52Bluetooth::setup() configuredPasskey = config.bluetooth.mode == Config_BluetoothConfig_PairingMode_FIXED_PIN ? config.bluetooth.fixed_pin : random(100000, 999999); auto pinString = std::to_string(configuredPasskey); - LOG_DEBUG("Bluetooth pin set to '%i'\n", configuredPasskey); + LOG_INFO("Bluetooth pin set to '%i'\n", configuredPasskey); Bluefruit.Security.setPIN(pinString.c_str()); Bluefruit.Security.setIOCaps(true, false, false); Bluefruit.Security.setPairPasskeyCallback(NRF52Bluetooth::onPairingPasskey); @@ -248,30 +248,30 @@ void NRF52Bluetooth::setup() bledfu.begin(); // Install the DFU helper // Configure and Start the Device Information Service - LOG_DEBUG("Configuring the Device Information Service\n"); + LOG_INFO("Configuring the Device Information Service\n"); bledis.setModel(optstr(HW_VERSION)); bledis.setFirmwareRev(optstr(APP_VERSION)); bledis.begin(); // Start the BLE Battery Service and set it to 100% - LOG_DEBUG("Configuring the Battery Service\n"); + LOG_INFO("Configuring the Battery Service\n"); blebas.begin(); blebas.write(0); // Unknown battery level for now // Setup the Heart Rate Monitor service using // BLEService and BLECharacteristic classes - LOG_DEBUG("Configuring the Mesh bluetooth service\n"); + LOG_INFO("Configuring the Mesh bluetooth service\n"); setupMeshService(); // Supposedly debugging works with soft device if you disable advertising if (isSoftDeviceAllowed) { // Setup the advertising packet(s) - LOG_DEBUG("Setting up the advertising payload(s)\n"); + LOG_INFO("Setting up the advertising payload(s)\n"); startAdv(); - LOG_DEBUG("Advertising\n"); + LOG_INFO("Advertising\n"); } } @@ -283,7 +283,7 @@ void updateBatteryLevel(uint8_t level) void NRF52Bluetooth::clearBonds() { - LOG_DEBUG("Clearing bluetooth bonds!\n"); + LOG_INFO("Clearing bluetooth bonds!\n"); bond_print_list(BLE_GAP_ROLE_PERIPH); bond_print_list(BLE_GAP_ROLE_CENTRAL); @@ -293,12 +293,12 @@ void NRF52Bluetooth::clearBonds() void NRF52Bluetooth::onConnectionSecured(uint16_t conn_handle) { - LOG_DEBUG("BLE connection secured\n"); + LOG_INFO("BLE connection secured\n"); } bool NRF52Bluetooth::onPairingPasskey(uint16_t conn_handle, uint8_t const passkey[6], bool match_request) { - LOG_DEBUG("BLE pairing process started with passkey %.3s %.3s\n", passkey, passkey+3); + LOG_INFO("BLE pairing process started with passkey %.3s %.3s\n", passkey, passkey+3); screen->startBluetoothPinScreen(configuredPasskey); if (match_request) @@ -309,16 +309,16 @@ bool NRF52Bluetooth::onPairingPasskey(uint16_t conn_handle, uint8_t const passke if (!Bluefruit.connected(conn_handle)) break; } } - LOG_DEBUG("BLE passkey pairing: match_request=%i\n", match_request); + LOG_INFO("BLE passkey pairing: match_request=%i\n", match_request); return true; } void NRF52Bluetooth::onPairingCompleted(uint16_t conn_handle, uint8_t auth_status) { if (auth_status == BLE_GAP_SEC_STATUS_SUCCESS) - LOG_DEBUG("BLE pairing success\n"); + LOG_INFO("BLE pairing success\n"); else - LOG_DEBUG("BLE pairing failed\n"); + LOG_INFO("BLE pairing failed\n"); screen->stopBluetoothPinScreen(); } diff --git a/src/platform/nrf52/main-nrf52.cpp b/src/platform/nrf52/main-nrf52.cpp index c53c548b52..9a942a6067 100644 --- a/src/platform/nrf52/main-nrf52.cpp +++ b/src/platform/nrf52/main-nrf52.cpp @@ -32,7 +32,7 @@ bool loopCanSleep() { // handle standard gcc assert failures void __attribute__((noreturn)) __assert_func(const char *file, int line, const char *func, const char *failedexpr) { - LOG_DEBUG("assert failed %s: %d, %s, test=%s\n", file, line, func, failedexpr); + LOG_ERROR("assert failed %s: %d, %s, test=%s\n", file, line, func, failedexpr); // debugger_break(); FIXME doesn't work, possibly not for segger // Reboot cpu NVIC_SystemReset(); @@ -73,7 +73,7 @@ void setBluetoothEnable(bool on) if (on) { if (!nrf52Bluetooth) { if (!useSoftDevice) - LOG_DEBUG("DISABLING NRF52 BLUETOOTH WHILE DEBUGGING\n"); + LOG_INFO("DISABLING NRF52 BLUETOOTH WHILE DEBUGGING\n"); else { nrf52Bluetooth = new NRF52Bluetooth(); nrf52Bluetooth->setup(); @@ -142,7 +142,7 @@ void nrf52Setup() #ifdef BQ25703A_ADDR auto *bq = new BQ25713(); if (!bq->setup()) - LOG_DEBUG("ERROR! Charge controller init failed\n"); + LOG_ERROR("ERROR! Charge controller init failed\n"); #endif // Init random seed @@ -178,8 +178,7 @@ void cpuDeepSleep(uint64_t msecToWake) auto ok = sd_power_system_off(); if (ok != NRF_SUCCESS) { - LOG_DEBUG("FIXME: Ignoring soft device (EasyDMA pending?) and forcing " - "system-off!\n"); + LOG_ERROR("FIXME: Ignoring soft device (EasyDMA pending?) and forcing system-off!\n"); NRF_POWER->SYSTEMOFF = 1; } diff --git a/src/platform/portduino/SimRadio.cpp b/src/platform/portduino/SimRadio.cpp index 016b910459..87800de221 100644 --- a/src/platform/portduino/SimRadio.cpp +++ b/src/platform/portduino/SimRadio.cpp @@ -108,9 +108,9 @@ bool SimRadio::canSendImmediately() if (busyTx || busyRx) { if (busyTx) - LOG_DEBUG("Can not send yet, busyTx\n"); + LOG_WARN("Can not send yet, busyTx\n"); if (busyRx) - LOG_DEBUG("Can not send yet, busyRx\n"); + LOG_WARN("Can not send yet, busyRx\n"); return false; } else return true; @@ -199,7 +199,7 @@ void SimRadio::startSend(MeshPacket * txp) memcpy(&c.data.bytes, p->decoded.payload.bytes, p->decoded.payload.size); c.data.size = p->decoded.payload.size; } else { - LOG_DEBUG("Payload size is larger than compressed message allows! Sending empty payload.\n"); + LOG_WARN("Payload size is larger than compressed message allows! Sending empty payload.\n"); } p->decoded.payload.size = pb_encode_to_bytes(p->decoded.payload.bytes, sizeof(p->decoded.payload.bytes), &Compressed_msg, &c); p->decoded.portnum = PortNum_SIMULATOR_APP; diff --git a/src/shutdown.h b/src/shutdown.h index 23f5d72520..7a57d789a9 100644 --- a/src/shutdown.h +++ b/src/shutdown.h @@ -7,14 +7,14 @@ void powerCommandsCheck() { if (rebootAtMsec && millis() > rebootAtMsec) { - LOG_DEBUG("Rebooting\n"); + LOG_INFO("Rebooting\n"); #if defined(ARCH_ESP32) ESP.restart(); #elif defined(ARCH_NRF52) NVIC_SystemReset(); #else rebootAtMsec = -1; - LOG_DEBUG("FIXME implement reboot for this platform. Skipping for now.\n"); + LOG_WARN("FIXME implement reboot for this platform. Skipping for now.\n"); #endif } @@ -35,7 +35,7 @@ void powerCommandsCheck() #endif if (shutdownAtMsec && millis() > shutdownAtMsec) { - LOG_DEBUG("Shutting down from admin command\n"); + LOG_INFO("Shutting down from admin command\n"); #ifdef HAS_PMU if (pmu_found == true) { playShutdownMelody(); @@ -45,7 +45,7 @@ void powerCommandsCheck() playShutdownMelody(); power->shutdown(); #else - LOG_DEBUG("FIXME implement shutdown for this platform"); + LOG_WARN("FIXME implement shutdown for this platform"); #endif } } diff --git a/src/sleep.cpp b/src/sleep.cpp index ee38da6994..c85eec3ffa 100644 --- a/src/sleep.cpp +++ b/src/sleep.cpp @@ -90,7 +90,7 @@ void setLed(bool ledOn) void setGPSPower(bool on) { - LOG_DEBUG("Setting GPS power=%d\n", on); + LOG_INFO("Setting GPS power=%d\n", on); #ifdef HAS_PMU if (pmu_found && PMU){ @@ -136,7 +136,7 @@ void initDeepSleep() if (wakeCause == ESP_SLEEP_WAKEUP_TIMER) reason = "timeout"; - LOG_DEBUG("booted, wake cause %d (boot count %d), reset_reason=%s\n", wakeCause, bootCount, reason); + LOG_INFO("Booted, wake cause %d (boot count %d), reset_reason=%s\n", wakeCause, bootCount, reason); #endif } @@ -174,13 +174,13 @@ void doGPSpowersave(bool on) #ifdef HAS_PMU if (on) { - LOG_DEBUG("Turning GPS back on\n"); + LOG_INFO("Turning GPS back on\n"); gps->forceWake(1); setGPSPower(1); } else { - LOG_DEBUG("Turning off GPS chip\n"); + LOG_INFO("Turning off GPS chip\n"); notifyGPSSleep.notifyObservers(NULL); setGPSPower(0); } @@ -188,12 +188,12 @@ void doGPSpowersave(bool on) #ifdef PIN_GPS_WAKE if (on) { - LOG_DEBUG("Waking GPS"); + LOG_INFO("Waking GPS"); gps->forceWake(1); } else { - LOG_DEBUG("GPS entering sleep"); + LOG_INFO("GPS entering sleep"); notifyGPSSleep.notifyObservers(NULL); } #endif @@ -201,7 +201,7 @@ void doGPSpowersave(bool on) void doDeepSleep(uint64_t msecToWake) { - LOG_DEBUG("Entering deep sleep for %lu seconds\n", msecToWake / 1000); + LOG_INFO("Entering deep sleep for %lu seconds\n", msecToWake / 1000); // not using wifi yet, but once we are this is needed to shutoff the radio hw // esp_wifi_stop(); @@ -310,7 +310,7 @@ esp_sleep_wakeup_cause_t doLightSleep(uint64_t sleepMsec) // FIXME, use a more r esp_sleep_wakeup_cause_t cause = esp_sleep_get_wakeup_cause(); #ifdef BUTTON_PIN if (cause == ESP_SLEEP_WAKEUP_GPIO) - LOG_DEBUG("Exit light sleep gpio: btn=%d\n", !digitalRead(BUTTON_PIN)); + LOG_INFO("Exit light sleep gpio: btn=%d\n", !digitalRead(BUTTON_PIN)); #endif return cause; From ef1fb877ba806f118a53869ac05f8b4d5b47501a Mon Sep 17 00:00:00 2001 From: Ben Meadors Date: Fri, 30 Dec 2022 10:47:31 -0600 Subject: [PATCH 6/7] Prefix log levels --- src/DebugConfiguration.h | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/src/DebugConfiguration.h b/src/DebugConfiguration.h index cae83cb182..389a35d812 100644 --- a/src/DebugConfiguration.h +++ b/src/DebugConfiguration.h @@ -13,11 +13,11 @@ #define SERIAL_BAUD 115200 // Serial debug baud rate #endif -#define LOG_LEVEL_DEBUG "DEBUG" -#define LOG_LEVEL_INFO "INFO " -#define LOG_LEVEL_WARN "WARN " -#define LOG_LEVEL_ERROR "ERROR" -#define LOG_LEVEL_TRACE "TRACE" +#define MESHTASTIC_LOG_LEVEL_DEBUG "DEBUG" +#define MESHTASTIC_LOG_LEVEL_INFO "INFO " +#define MESHTASTIC_LOG_LEVEL_WARN "WARN " +#define MESHTASTIC_LOG_LEVEL_ERROR "ERROR" +#define MESHTASTIC_LOG_LEVEL_TRACE "TRACE" #include "SerialConsole.h" @@ -30,11 +30,11 @@ #define LOG_ERROR(...) SEGGER_RTT_printf(0, __VA_ARGS__) #else #ifdef DEBUG_PORT -#define LOG_DEBUG(...) DEBUG_PORT.log(LOG_LEVEL_DEBUG, __VA_ARGS__) -#define LOG_INFO(...) DEBUG_PORT.log(LOG_LEVEL_INFO, __VA_ARGS__) -#define LOG_WARN(...) DEBUG_PORT.log(LOG_LEVEL_WARN, __VA_ARGS__) -#define LOG_ERROR(...) DEBUG_PORT.log(LOG_LEVEL_ERROR, __VA_ARGS__) -#define LOG_TRACE(...) DEBUG_PORT.log(LOG_TRACE, __VA_ARGS__) +#define LOG_DEBUG(...) DEBUG_PORT.log(MESHTASTIC_LOG_LEVEL_DEBUG, __VA_ARGS__) +#define LOG_INFO(...) DEBUG_PORT.log(MESHTASTIC_LOG_LEVEL_INFO, __VA_ARGS__) +#define LOG_WARN(...) DEBUG_PORT.log(MESHTASTIC_LOG_LEVEL_WARN, __VA_ARGS__) +#define LOG_ERROR(...) DEBUG_PORT.log(MESHTASTIC_LOG_LEVEL_ERROR, __VA_ARGS__) +#define LOG_TRACE(...) DEBUG_PORT.log(MESHTASTIC_LOG_TRACE, __VA_ARGS__) #else #define LOG_DEBUG(...) #define LOG_INFO(...) From 3d3aba584efb991edbd62bfe5e435a35e281d02f Mon Sep 17 00:00:00 2001 From: Ben Meadors Date: Fri, 30 Dec 2022 10:56:57 -0600 Subject: [PATCH 7/7] Include --- src/platform/esp32/SimpleAllocator.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/platform/esp32/SimpleAllocator.cpp b/src/platform/esp32/SimpleAllocator.cpp index 9e2a0c7d21..0fb6677d20 100644 --- a/src/platform/esp32/SimpleAllocator.cpp +++ b/src/platform/esp32/SimpleAllocator.cpp @@ -1,6 +1,6 @@ -#include "SimpleAllocator.h" #include "assert.h" - +#include "configuration.h" +#include "SimpleAllocator.h" SimpleAllocator::SimpleAllocator() { reset(); }