InfiniTime.git

commit 4fddf931147537b79bfaf0c8d6878958a6fc9965

Author: mark9064 <30447455+mark9064@users.noreply.github.com>

Advertise HR service

 src/components/ble/DfuService.h | 8 ++++----
 src/components/ble/HeartRateService.h | 6 +++---
 src/components/ble/NimbleController.cpp | 5 ++++-
 src/components/ble/NimbleController.h | 4 ----


diff --git a/src/components/ble/DfuService.h b/src/components/ble/DfuService.h
index b56911b905b37f3f7996295cee66424a13fc7b98..6652cdc1cb3529f2f1cf6b01dd8bcb4f373a309b 100644
--- a/src/components/ble/DfuService.h
+++ b/src/components/ble/DfuService.h
@@ -77,6 +77,10 @@         void WriteMagicNumber();
         uint16_t ComputeCrc(uint8_t const* p_data, uint32_t size, uint16_t const* p_crc);
       };
 
+      static constexpr ble_uuid128_t serviceUuid {
+        .u {.type = BLE_UUID_TYPE_128},
+        .value = {0x23, 0xD1, 0xBC, 0xEA, 0x5F, 0x78, 0x23, 0x15, 0xDE, 0xEF, 0x12, 0x12, 0x30, 0x15, 0x00, 0x00}};
+
     private:
       Pinetime::System::SystemTask& systemTask;
       Pinetime::Controllers::Ble& bleController;
@@ -89,10 +93,6 @@       static constexpr uint16_t controlPointCharacteristicId {0x1531};
       static constexpr uint16_t revisionCharacteristicId {0x1534};
 
       uint16_t revision {0x0008};
-
-      static constexpr ble_uuid128_t serviceUuid {
-        .u {.type = BLE_UUID_TYPE_128},
-        .value = {0x23, 0xD1, 0xBC, 0xEA, 0x5F, 0x78, 0x23, 0x15, 0xDE, 0xEF, 0x12, 0x12, 0x30, 0x15, 0x00, 0x00}};
 
       static constexpr ble_uuid128_t packetCharacteristicUuid {
         .u {.type = BLE_UUID_TYPE_128},




diff --git a/src/components/ble/HeartRateService.h b/src/components/ble/HeartRateService.h
index 3f32fd0971a561a4e8c3f8cda72f8bd50d42dd97..ca8f10fb8d5aa40537c6297ee15709314224f51f 100644
--- a/src/components/ble/HeartRateService.h
+++ b/src/components/ble/HeartRateService.h
@@ -21,13 +21,13 @@
       void SubscribeNotification(uint16_t attributeHandle);
       void UnsubscribeNotification(uint16_t attributeHandle);
 
+      static constexpr uint16_t heartRateServiceId {0x180D};
+      static constexpr ble_uuid16_t heartRateServiceUuid {.u {.type = BLE_UUID_TYPE_16}, .value = heartRateServiceId};
+
     private:
       NimbleController& nimble;
       Controllers::HeartRateController& heartRateController;
-      static constexpr uint16_t heartRateServiceId {0x180D};
       static constexpr uint16_t heartRateMeasurementId {0x2A37};
-
-      static constexpr ble_uuid16_t heartRateServiceUuid {.u {.type = BLE_UUID_TYPE_16}, .value = heartRateServiceId};
 
       static constexpr ble_uuid16_t heartRateMeasurementUuid {.u {.type = BLE_UUID_TYPE_16}, .value = heartRateMeasurementId};
 




diff --git a/src/components/ble/NimbleController.cpp b/src/components/ble/NimbleController.cpp
index 2e7f8003e7b5d92c12c0187f61300bcd3fef0727..f1411a3e5dce0368524f04b3077339e5bfafd8c8 100644
--- a/src/components/ble/NimbleController.cpp
+++ b/src/components/ble/NimbleController.cpp
@@ -158,7 +158,10 @@     adv_params.itvl_max = 1651;
   }
 
   fields.flags = BLE_HS_ADV_F_DISC_GEN | BLE_HS_ADV_F_BREDR_UNSUP;
-  fields.uuids128 = &dfuServiceUuid;
+  fields.uuids16 = &HeartRateService::heartRateServiceUuid;
+  fields.num_uuids16 = 1;
+  fields.uuids16_is_complete = 1;
+  fields.uuids128 = &DfuService::serviceUuid;
   fields.num_uuids128 = 1;
   fields.uuids128_is_complete = 1;
   fields.tx_pwr_lvl = BLE_HS_ADV_TX_PWR_LVL_AUTO;




diff --git a/src/components/ble/NimbleController.h b/src/components/ble/NimbleController.h
index 29a395ea51f540d1b95b220a0ace02da1c501947..597ef0cc341de4003132b0220bc48d73cd15d1d3 100644
--- a/src/components/ble/NimbleController.h
+++ b/src/components/ble/NimbleController.h
@@ -112,10 +112,6 @@       uint8_t addrType;
       uint16_t connectionHandle = BLE_HS_CONN_HANDLE_NONE;
       uint8_t fastAdvCount = 0;
       uint8_t bondId[16] = {0};
-
-      ble_uuid128_t dfuServiceUuid {
-        .u {.type = BLE_UUID_TYPE_128},
-        .value = {0x23, 0xD1, 0xBC, 0xEA, 0x5F, 0x78, 0x23, 0x15, 0xDE, 0xEF, 0x12, 0x12, 0x30, 0x15, 0x00, 0x00}};
     };
 
     static NimbleController* nptr;