From 279066366b8ecfde18ecb826a79146a26bb1aa29 Mon Sep 17 00:00:00 2001 From: Arkadiusz Bokowy Date: Fri, 7 Oct 2022 00:16:15 +0200 Subject: [PATCH] [Tizen] Release BLE when no longer needed (#23032) * [Tizen] Release BLE when no longer needed clang-tidy: modernize redundant void * [Linux] Check for error when registering GATT --- src/platform/Linux/BLEManagerImpl.cpp | 1 + src/platform/Tizen/BLEManagerImpl.cpp | 26 +++++++++++++--------- src/platform/Tizen/BLEManagerImpl.h | 31 ++++++++++++++------------- 3 files changed, 33 insertions(+), 25 deletions(-) diff --git a/src/platform/Linux/BLEManagerImpl.cpp b/src/platform/Linux/BLEManagerImpl.cpp index 426f6ca0b01f8d..348c552f30818c 100644 --- a/src/platform/Linux/BLEManagerImpl.cpp +++ b/src/platform/Linux/BLEManagerImpl.cpp @@ -570,6 +570,7 @@ void BLEManagerImpl::DriveBLEState() if (!mIsCentral && mServiceMode == ConnectivityManager::kCHIPoBLEServiceMode_Enabled && !mFlags.Has(Flags::kAppRegistered)) { err = BluezGattsAppRegister(mpEndpoint); + SuccessOrExit(err); mFlags.Set(Flags::kControlOpInProgress); ExitNow(); } diff --git a/src/platform/Tizen/BLEManagerImpl.cpp b/src/platform/Tizen/BLEManagerImpl.cpp index 693ffb5665e053..8faed467de1463 100644 --- a/src/platform/Tizen/BLEManagerImpl.cpp +++ b/src/platform/Tizen/BLEManagerImpl.cpp @@ -484,7 +484,7 @@ void BLEManagerImpl::OnChipDeviceScanned(void * device, const chip::Ble::ChipBLE ConnectHandler(deviceInfo->remote_address); } -void BLEManagerImpl::OnChipScanComplete(void) +void BLEManagerImpl::OnChipScanComplete() { if (mBLEScanConfig.mBleScanState != BleScanState::kScanForDiscriminator && mBLEScanConfig.mBleScanState != BleScanState::kScanForAddress) @@ -579,7 +579,7 @@ int BLEManagerImpl::RegisterGATTServer() return ret; } -int BLEManagerImpl::StartAdvertising() +int BLEManagerImpl::StartBLEAdvertising() { int ret = BT_ERROR_NONE; CHIP_ERROR err = CHIP_NO_ERROR; @@ -649,7 +649,7 @@ int BLEManagerImpl::StartAdvertising() return ret; } -int BLEManagerImpl::StopAdvertising() +int BLEManagerImpl::StopBLEAdvertising() { int ret = BT_ERROR_NONE; @@ -664,7 +664,7 @@ int BLEManagerImpl::StopAdvertising() return ret; } -void BLEManagerImpl::InitConnectionData(void) +void BLEManagerImpl::InitConnectionData() { /* Initialize Hashmap */ if (!mConnectionMap) @@ -872,13 +872,13 @@ void BLEManagerImpl::DriveBLEState() { if (!mFlags.Has(Flags::kAdvertising)) { - ret = StartAdvertising(); + ret = StartBLEAdvertising(); VerifyOrExit(ret == BT_ERROR_NONE, ChipLogError(DeviceLayer, "Start Advertising Failed. ret: %d", ret)); } else if (mFlags.Has(Flags::kAdvertisingRefreshNeeded)) { ChipLogProgress(DeviceLayer, "Advertising Refreshed Needed. Stop Advertising"); - ret = StopAdvertising(); + ret = StopBLEAdvertising(); VerifyOrExit(ret == BT_ERROR_NONE, ChipLogError(DeviceLayer, "Stop Advertising Failed. ret: %d", ret)); } } @@ -886,7 +886,7 @@ void BLEManagerImpl::DriveBLEState() { ChipLogProgress(DeviceLayer, "Stop Advertising"); - ret = StopAdvertising(); + ret = StopBLEAdvertising(); VerifyOrExit(ret == BT_ERROR_NONE, ChipLogError(DeviceLayer, "Stop Advertising Failed. ret: %d", ret)); ret = bt_adapter_le_destroy_advertiser(mAdvertiser); @@ -906,7 +906,7 @@ void BLEManagerImpl::DriveBLEState(intptr_t arg) sInstance.DriveBLEState(); } -CHIP_ERROR BLEManagerImpl::_Init(void) +CHIP_ERROR BLEManagerImpl::_Init() { CHIP_ERROR err; bool ret; @@ -926,6 +926,12 @@ CHIP_ERROR BLEManagerImpl::_Init(void) return err; } +void BLEManagerImpl::_Shutdown() +{ + int ret = bt_deinitialize(); + VerifyOrReturn(ret == BT_ERROR_NONE, ChipLogError(DeviceLayer, "bt_deinitialize() failed. ret: %d", ret)); +} + CHIP_ERROR BLEManagerImpl::_SetAdvertisingEnabled(bool val) { mFlags.Set(Flags::kAdvertisingEnabled, val); @@ -994,7 +1000,7 @@ CHIP_ERROR BLEManagerImpl::_SetDeviceName(const char * deviceName) return err; } -uint16_t BLEManagerImpl::_NumConnections(void) +uint16_t BLEManagerImpl::_NumConnections() { return 0; } @@ -1006,7 +1012,7 @@ CHIP_ERROR BLEManagerImpl::ConfigureBle(uint32_t aAdapterId, bool aIsCentral) return CHIP_NO_ERROR; } -void BLEManagerImpl::CleanScanConfig(void) +void BLEManagerImpl::CleanScanConfig() { if (mBLEScanConfig.mBleScanState == BleScanState::kConnecting) chip::DeviceLayer::SystemLayer().CancelTimer(HandleConnectionTimeout, nullptr); diff --git a/src/platform/Tizen/BLEManagerImpl.h b/src/platform/Tizen/BLEManagerImpl.h index 8866263fafbc7e..30bff7b9102934 100644 --- a/src/platform/Tizen/BLEManagerImpl.h +++ b/src/platform/Tizen/BLEManagerImpl.h @@ -86,18 +86,19 @@ class BLEManagerImpl final : public BLEManager, private: // ===== Members that implement the BLEManager internal interface. - CHIP_ERROR _Init(void); - void _Shutdown() {} - bool _IsAdvertisingEnabled(void); + CHIP_ERROR _Init(); + void _Shutdown(); + bool _IsAdvertisingEnabled(); CHIP_ERROR _SetAdvertisingEnabled(bool val); - bool _IsAdvertising(void); + bool _IsAdvertising(); CHIP_ERROR _SetAdvertisingMode(BLEAdvertisingMode mode); CHIP_ERROR _GetDeviceName(char * buf, size_t bufSize); CHIP_ERROR _SetDeviceName(const char * deviceName); - uint16_t _NumConnections(void); + uint16_t _NumConnections(); + void _OnPlatformEvent(const ChipDeviceEvent * event); void HandlePlatformSpecificBLEEvent(const ChipDeviceEvent * event); - BleLayer * _GetBleLayer(void); + BleLayer * _GetBleLayer(); // ===== Members that implement virtual methods on BlePlatformDelegate. @@ -131,8 +132,8 @@ class BLEManagerImpl final : public BLEManager, // ===== Members for internal use by the following friends. - friend BLEManager & BLEMgr(void); - friend BLEManagerImpl & BLEMgrImpl(void); + friend BLEManager & BLEMgr(); + friend BLEManagerImpl & BLEMgrImpl(); static BLEManagerImpl sInstance; @@ -172,7 +173,7 @@ class BLEManagerImpl final : public BLEManager, static void CharacteristicNotificationCb(bt_gatt_h characteristic, char * value, int len, void * userData); // ==== Connection. - void InitConnectionData(void); + void InitConnectionData(); void AddConnectionData(const char * remoteAddr); void RemoveConnectionData(const char * remoteAddr); @@ -202,10 +203,10 @@ class BLEManagerImpl final : public BLEManager, void NotifySubscribeOpComplete(BLE_CONNECTION_OBJECT conId, bool isSubscribed); void NotifyBLENotificationReceived(System::PacketBufferHandle & buf, BLE_CONNECTION_OBJECT conId); - int RegisterGATTServer(void); - int StartAdvertising(void); - int StopAdvertising(void); - void CleanScanConfig(void); + int RegisterGATTServer(); + int StartBLEAdvertising(); + int StopBLEAdvertising(); + void CleanScanConfig(); CHIPoBLEServiceMode mServiceMode; BitFlags mFlags; @@ -230,7 +231,7 @@ class BLEManagerImpl final : public BLEManager, * Internal components should use this to access features of the BLEManager object * that are common to all platforms. */ -inline BLEManager & BLEMgr(void) +inline BLEManager & BLEMgr() { return BLEManagerImpl::sInstance; } @@ -241,7 +242,7 @@ inline BLEManager & BLEMgr(void) * Internal components can use this to gain access to features of the BLEManager * that are specific to the Tizen platforms. */ -inline BLEManagerImpl & BLEMgrImpl(void) +inline BLEManagerImpl & BLEMgrImpl() { return BLEManagerImpl::sInstance; }