Heart Rate Monitor example for the BLE API using nRF51822 native mode drivers

Dependencies:   BLE_API mbed nRF51822

Fork of BLE_HeartRate by Bluetooth Low Energy

Revision:
3:24e2b056d229
Parent:
0:87a7fc231fae
Child:
4:12890f3c62eb
--- a/main.cpp	Thu Apr 03 01:09:02 2014 +0000
+++ b/main.cpp	Wed May 21 14:39:35 2014 +0100
@@ -17,43 +17,56 @@
 #include "mbed.h"
 #include "nRF51822n.h"
 
-nRF51822n   nrf;                /* BLE radio driver */
+nRF51822n  nrf;                 /* BLE radio driver */
 
-DigitalOut  led1(LED1);
-DigitalOut  led2(LED2);
-Ticker      flipper;
-Serial      pc(USBTX,USBRX);
+DigitalOut led1(LED1);
+DigitalOut led2(LED2);
+Ticker     flipper;
+Serial     pc(USBTX, USBRX);
 
 /* Battery Level Service */
-uint8_t            batt = 72;     /* Battery level */
+uint8_t            batt      = 72; /* Battery level */
 uint8_t            read_batt = 0; /* Variable to hold battery level reads */
-GattService        battService ( GattService::UUID_BATTERY_SERVICE );
-GattCharacteristic battLevel   ( GattCharacteristic::UUID_BATTERY_LEVEL_CHAR, 1, 1,
-                                 GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_NOTIFY |
-                                 GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_READ);
+GattService        battService (GattService::UUID_BATTERY_SERVICE);
+GattCharacteristic battLevel   (GattCharacteristic::UUID_BATTERY_LEVEL_CHAR,
+                                1,
+                                1,
+                                GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_NOTIFY |
+                                GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_READ);
 
 /* Heart Rate Service */
 /* Service:  https://developer.bluetooth.org/gatt/services/Pages/ServiceViewer.aspx?u=org.bluetooth.service.heart_rate.xml */
 /* HRM Char: https://developer.bluetooth.org/gatt/characteristics/Pages/CharacteristicViewer.aspx?u=org.bluetooth.characteristic.heart_rate_measurement.xml */
 /* Location: https://developer.bluetooth.org/gatt/characteristics/Pages/CharacteristicViewer.aspx?u=org.bluetooth.characteristic.body_sensor_location.xml */
-GattService        hrmService    ( GattService::UUID_HEART_RATE_SERVICE );
-GattCharacteristic hrmRate       ( GattCharacteristic::UUID_HEART_RATE_MEASUREMENT_CHAR, 2, 3, GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_NOTIFY );
-GattCharacteristic hrmLocation   ( GattCharacteristic::UUID_BODY_SENSOR_LOCATION_CHAR, 1, 1, GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_READ );
+GattService        hrmService    (GattService::UUID_HEART_RATE_SERVICE);
+GattCharacteristic hrmRate       (
+    GattCharacteristic::UUID_HEART_RATE_MEASUREMENT_CHAR,
+    2,
+    3,
+    GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_NOTIFY);
+GattCharacteristic hrmLocation   (
+    GattCharacteristic::UUID_BODY_SENSOR_LOCATION_CHAR,
+    1,
+    1,
+    GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_READ);
 
 /* Device Information service */
-uint8_t            deviceName[4] = { 'm', 'b', 'e', 'd' };
-GattService        deviceInformationService ( GattService::UUID_DEVICE_INFORMATION_SERVICE );
-GattCharacteristic deviceManufacturer ( GattCharacteristic::UUID_MANUFACTURER_NAME_STRING_CHAR,
-                                        sizeof(deviceName), sizeof(deviceName),
-                                        GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_READ);
+uint8_t deviceName[4] = {'m', 'b', 'e', 'd'};
+GattService        deviceInformationService (
+    GattService::UUID_DEVICE_INFORMATION_SERVICE);
+GattCharacteristic deviceManufacturer (
+    GattCharacteristic::UUID_MANUFACTURER_NAME_STRING_CHAR,
+    sizeof(deviceName),
+    sizeof(deviceName),
+    GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_READ);
 
 /* Advertising data and parameters */
-GapAdvertisingData   advData;
-GapAdvertisingData   scanResponse;
-GapAdvertisingParams advParams ( GapAdvertisingParams::ADV_CONNECTABLE_UNDIRECTED );
-uint16_t             uuid16_list[] = { GattService::UUID_BATTERY_SERVICE, 
-                                       GattService::UUID_DEVICE_INFORMATION_SERVICE,
-                                       GattService::UUID_HEART_RATE_SERVICE };
+GapAdvertisingData advData;
+GapAdvertisingData scanResponse;
+GapAdvertisingParams advParams (GapAdvertisingParams::ADV_CONNECTABLE_UNDIRECTED);
+uint16_t           uuid16_list[] = {GattService::UUID_BATTERY_SERVICE,
+                                    GattService::UUID_DEVICE_INFORMATION_SERVICE,
+                                    GattService::UUID_HEART_RATE_SERVICE};
 
 void tickerCallback(void);
 
@@ -65,12 +78,12 @@
 /**************************************************************************/
 class GapEventHandler : public GapEvents
 {
-    virtual void onTimeout(void) 
+    virtual void onTimeout(void)
     {
         pc.printf("Advertising Timeout!\n\r");
         // Restart the advertising process with a much slower interval,
         // only start advertising again after a button press, etc.
-    }    
+    }
 
     virtual void onConnected(void)
     {
@@ -95,21 +108,19 @@
 {
     //virtual void onDataSent(uint16_t charHandle) {}
     //virtual void onDataWritten(uint16_t charHandle) {}
-    
+
     virtual void onUpdatesEnabled(uint16_t charHandle)
     {
-      if (charHandle == hrmRate.handle)
-      {
-        pc.printf("Heart rate notify enabled\n\r");
-      }
+        if (charHandle == hrmRate.handle) {
+            pc.printf("Heart rate notify enabled\n\r");
+        }
     }
 
     virtual void onUpdatesDisabled(uint16_t charHandle)
     {
-      if (charHandle == hrmRate.handle)
-      {
-        pc.printf("Heart rate notify disabled\n\r");
-      }
+        if (charHandle == hrmRate.handle) {
+            pc.printf("Heart rate notify disabled\n\r");
+        }
     }
 
     //virtual void onConfirmationReceived(uint16_t charHandle) {}
@@ -124,10 +135,10 @@
 {
     *(uint32_t *)0x40000504 = 0xC007FFDF;
     *(uint32_t *)0x40006C18 = 0x00008000;
-    
+
     /* Setup blinky: led1 is toggled in main, led2 is toggled via Ticker */
-    led1=1;
-    led2=1;
+    led1 = 1;
+    led2 = 1;
     flipper.attach(&tickerCallback, 1.0);
 
     /* Setup the local GAP/GATT event handlers */
@@ -143,8 +154,8 @@
 
     /* Add BLE-Only flag and complete service list to the advertising data */
     advData.addFlags(GapAdvertisingData::BREDR_NOT_SUPPORTED);
-    advData.addData(GapAdvertisingData::COMPLETE_LIST_16BIT_SERVICE_IDS, 
-                   (uint8_t*)uuid16_list, sizeof(uuid16_list));
+    advData.addData(GapAdvertisingData::COMPLETE_LIST_16BIT_SERVICE_IDS,
+                    (uint8_t *)uuid16_list, sizeof(uuid16_list));
     advData.addAppearance(GapAdvertisingData::HEART_RATE_SENSOR_HEART_RATE_BELT);
     nrf.getGap().setAdvertisingData(advData, scanResponse);
 
@@ -155,51 +166,61 @@
     /* Add the Device Information service */
     deviceInformationService.addCharacteristic(deviceManufacturer);
     nrf.getGattServer().addService(deviceInformationService);
-    
+
     /* Add the Heart Rate service */
     hrmService.addCharacteristic(hrmRate);
     hrmService.addCharacteristic(hrmLocation);
     nrf.getGattServer().addService(hrmService);
-    
+
     /* Start advertising (make sure you've added all your data first) */
     nrf.getGap().startAdvertising(advParams);
-    
-    /* Wait until we are connected to a central device before updating anything */
+
+    /* Wait until we are connected to a central device before updating
+     * anything */
     pc.printf("Waiting for a connection ...");
-    while(!nrf.getGap().state.connected)
-    {
+    while (!nrf.getGap().state.connected) {
     }
     pc.printf("Connected!\n\r");
-    
+
     /* Now that we're live, update the battery level characteristic, and */
     /* change the device manufacturer characteristic to 'mbed' */
-    nrf.getGattServer().updateValue(battLevel.handle, (uint8_t*)&batt, sizeof(batt));
-    nrf.getGattServer().updateValue(deviceManufacturer.handle, deviceName, sizeof(deviceName));
+    nrf.getGattServer().updateValue(battLevel.handle, (uint8_t *)&batt,
+                                    sizeof(batt));
+    nrf.getGattServer().updateValue(deviceManufacturer.handle,
+                                    deviceName,
+                                    sizeof(deviceName));
 
     /* Set the heart rate monitor location (one time only) */
     /* See --> https://developer.bluetooth.org/gatt/characteristics/Pages/CharacteristicViewer.aspx?u=org.bluetooth.characteristic.body_sensor_location.xml */
     uint8_t location = 0x03; /* Finger */
     uint8_t hrmCounter = 100;
-    nrf.getGattServer().updateValue(hrmLocation.handle, (uint8_t*)&location, sizeof(location));
+    nrf.getGattServer().updateValue(hrmLocation.handle,
+                                    (uint8_t *)&location,
+                                    sizeof(location));
 
     /* Do blinky on LED1 while we're waiting for BLE events */
-    for (;;)
-    {
-      led1 = !led1;
-      wait(1);
-      
-      /* Update battery level */
-      batt++;
-      if (batt > 100) batt = 72;
-      nrf.getGattServer().updateValue(battLevel.handle, (uint8_t*)&batt, sizeof(batt));
+    for (;; ) {
+        led1 = !led1;
+        wait(1);
+
+        /* Update battery level */
+        batt++;
+        if (batt > 100) {
+            batt = 72;
+        }
+        nrf.getGattServer().updateValue(battLevel.handle,
+                                        (uint8_t *)&batt,
+                                        sizeof(batt));
 
       /* Update the HRM measurement */
       /* First byte = 8-bit values, no extra info, Second byte = uint8_t HRM value */
       /* See --> https://developer.bluetooth.org/gatt/characteristics/Pages/CharacteristicViewer.aspx?u=org.bluetooth.characteristic.heart_rate_measurement.xml */
-      hrmCounter++;
-      if (hrmCounter == 175) hrmCounter = 100;
-      uint8_t bpm[2] = { 0x00, hrmCounter };
-      nrf.getGattServer().updateValue(hrmRate.handle, bpm, sizeof(bpm));
+        hrmCounter++;
+        if (hrmCounter == 175) {
+            hrmCounter = 100;
+        }
+        uint8_t bpm[2] = {0x00, hrmCounter};
+        nrf.getGattServer().updateValue(hrmRate.handle, bpm, sizeof(bpm));
     }
 }