From d26d96fdffb75fce9ab63065adeea24b6472d8c9 Mon Sep 17 00:00:00 2001 From: thankthemaker Date: Sun, 15 Oct 2023 21:23:57 +0200 Subject: [PATCH] Fix: Give semaphore also on error --- src/BleServer.cpp | 7 ++++--- src/CanDevice.cpp | 1 + 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/src/BleServer.cpp b/src/BleServer.cpp index cc421fc..3b2d452 100644 --- a/src/BleServer.cpp +++ b/src/BleServer.cpp @@ -26,6 +26,7 @@ std::string updateBuffer; unsigned long bleLoop = 0; unsigned long loopTimeSum = 0; unsigned long loopCount = 0; +unsigned int bleWait = 5; BleServer::BleServer() = default; @@ -186,7 +187,7 @@ void BleServer::loop(VescData *vescData, unsigned long loopTime, unsigned long m vescBuffer.clear(); } pCharacteristicVescTx->notify(); - delay(1); // bluetooth stack will go into congestion, if too many packets are sent + delay(bleWait); // bluetooth stack will go into congestion, if too many packets are sent } } } @@ -347,7 +348,7 @@ void BleServer::onWrite(BLECharacteristic *pCharacteristic) { Logger::notice(LOG_TAG_BLESERVER, buf); } } - delay(1); // needed to give BLE stack some time + delay(bleWait); // needed to give BLE stack some time } //NimBLECharacteristicCallbacks::onSubscribe @@ -379,7 +380,7 @@ void BleServer::sendValue(NimBLECharacteristic *pCharacteristic, std::string key pCharacteristic->setValue(ss.str()); pCharacteristic->notify(); ss.str(""); - delay(1); + delay(bleWait); } static boolean isStringType(String a) { return true; } diff --git a/src/CanDevice.cpp b/src/CanDevice.cpp index 224e2f4..99b4be9 100644 --- a/src/CanDevice.cpp +++ b/src/CanDevice.cpp @@ -44,6 +44,7 @@ boolean CanDevice::sendCanFrame(const twai_message_t *p_frame) { //Queue message for transmission if (twai_transmit(p_frame, pdMS_TO_TICKS(10)) != ESP_OK) { printf("Failed to queue message for transmission\n"); + xSemaphoreGive(mutex_v); return false; } xSemaphoreGive(mutex_v);