From a5a70ac4b0e26232c3ada08a2ccf92ab60b420a2 Mon Sep 17 00:00:00 2001 From: h2zero Date: Mon, 6 Jan 2025 15:21:55 -0700 Subject: [PATCH] Fix crash when retrieving descriptors. If more than one descriptor is found the task would be released beofore the process completed causing a race condition. --- src/NimBLERemoteCharacteristic.cpp | 9 ++------- src/NimBLERemoteService.cpp | 5 ++++- 2 files changed, 6 insertions(+), 8 deletions(-) diff --git a/src/NimBLERemoteCharacteristic.cpp b/src/NimBLERemoteCharacteristic.cpp index c1715f3..b9c16c7 100644 --- a/src/NimBLERemoteCharacteristic.cpp +++ b/src/NimBLERemoteCharacteristic.cpp @@ -72,14 +72,8 @@ int NimBLERemoteCharacteristic::descriptorDiscCB( const auto pChr = (NimBLERemoteCharacteristic*)pTaskData->m_pInstance; const NimBLEUUID* uuidFilter = filter->uuid; - if (error->status == BLE_HS_ENOTCONN) { - NIMBLE_LOGE(LOG_TAG, "<< Descriptor Discovery; Not connected"); - NimBLEUtils::taskRelease(*pTaskData, error->status); - return error->status; - } - if (pChr->getHandle() != chr_val_handle) { - rc = BLE_HS_EDONE; // descriptor not for this characteristic + return 0; // Descriptor not for this characteristic } if (rc == 0) { @@ -92,6 +86,7 @@ int NimBLERemoteCharacteristic::descriptorDiscCB( } pChr->m_vDescriptors.push_back(new NimBLERemoteDescriptor(pChr, dsc)); + return 0; } NimBLEUtils::taskRelease(*pTaskData, rc); diff --git a/src/NimBLERemoteService.cpp b/src/NimBLERemoteService.cpp index c5fe0ff..c131af7 100644 --- a/src/NimBLERemoteService.cpp +++ b/src/NimBLERemoteService.cpp @@ -147,7 +147,10 @@ int NimBLERemoteService::characteristicDiscCB(uint16_t conn_handle, const ble_gatt_error* error, const ble_gatt_chr* chr, void* arg) { - NIMBLE_LOGD(LOG_TAG, "Characteristic Discovery >>"); + NIMBLE_LOGD(LOG_TAG, + "Characteristic Discovery >> status: %d handle: %d", + error->status, + (error->status == 0) ? chr->def_handle : -1); auto pTaskData = (NimBLETaskData*)arg; const auto pSvc = (NimBLERemoteService*)pTaskData->m_pInstance;