Skip to content
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
fix ble end on mbed portenta boards for successfully ble restart
  • Loading branch information
fabik111 authored and pennam committed Apr 9, 2025
commit bbc2baa1a8e25307e19664f13e7ad1bcbd526e6c
8 changes: 8 additions & 0 deletions src/utility/HCICordioTransport.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@
#include "CordioHCICustomDriver.h"

extern BLE_NAMESPACE::CordioHCIDriver& ble_cordio_get_hci_driver();
extern "C" void hciTrSerialRxIncoming(uint8_t *pBuf, uint8_t len);

namespace BLE_NAMESPACE {
struct CordioHCIHook {
Expand Down Expand Up @@ -236,6 +237,13 @@ void HCICordioTransportClass::end()
delete bleLoopThread;
bleLoopThread = NULL;
}
// Reset the callback with the mbed-os default handler to properly handle the following CYW43xxx chip initializations and begins
CordioHCIHook::setDataReceivedHandler(hciTrSerialRxIncoming);

#if (defined(ARDUINO_PORTENTA_H7_M4) || defined(ARDUINO_PORTENTA_H7_M7) || defined(ARDUINO_NICLA_VISION) || defined(ARDUINO_GIGA) || defined(ARDUINO_OPTA)) && !defined(CUSTOM_HCI_DRIVER)
BLE &ble = BLE::Instance();
ble.shutdown();
#endif

#if !defined(TARGET_STM32H7)
CordioHCIHook::getDriver().terminate();
Expand Down
Loading