summaryrefslogtreecommitdiff
path: root/src/components/ble/HeartRateService.h
diff options
context:
space:
mode:
authorJean-François Milants <jf@codingfield.com>2021-10-17 06:23:01 (GMT)
committerJean-François Milants <jf@codingfield.com>2021-10-17 06:23:01 (GMT)
commitd1f50157c7e0c471ae0e260fdca82fc472635079 (patch)
tree5ff50524ec689b5472d04405fd54a983161ff04d /src/components/ble/HeartRateService.h
parentbf83493c8db1ef8afab34a10d0253c0208304484 (diff)
MotionService : fix typo and characteristic array size + send notification only if the host subscribed to them.
Diffstat (limited to 'src/components/ble/HeartRateService.h')
-rw-r--r--src/components/ble/HeartRateService.h7
1 files changed, 6 insertions, 1 deletions
diff --git a/src/components/ble/HeartRateService.h b/src/components/ble/HeartRateService.h
index 0b16703..4e4a5a4 100644
--- a/src/components/ble/HeartRateService.h
+++ b/src/components/ble/HeartRateService.h
@@ -2,6 +2,7 @@
#define min // workaround: nimble's min/max macros conflict with libstdc++
#define max
#include <host/ble_gap.h>
+#include <atomic>
#undef max
#undef min
@@ -18,6 +19,9 @@ namespace Pinetime {
int OnHeartRateRequested(uint16_t connectionHandle, uint16_t attributeHandle, ble_gatt_access_ctxt* context);
void OnNewHeartRateValue(uint8_t hearRateValue);
+ void SubscribeNotification(uint16_t connectionHandle, uint16_t attributeHandle);
+ void UnsubscribeNotification(uint16_t connectionHandle, uint16_t attributeHandle);
+
private:
Pinetime::System::SystemTask& system;
Controllers::HeartRateController& heartRateController;
@@ -28,10 +32,11 @@ namespace Pinetime {
static constexpr ble_uuid16_t heartRateMeasurementUuid {.u {.type = BLE_UUID_TYPE_16}, .value = heartRateMeasurementId};
- struct ble_gatt_chr_def characteristicDefinition[3];
+ struct ble_gatt_chr_def characteristicDefinition[2];
struct ble_gatt_svc_def serviceDefinition[2];
uint16_t heartRateMeasurementHandle;
+ std::atomic_bool heartRateMeasurementNotificationEnable {false};
};
}
}