HW layer for the Nucleo board, it only work with old BLE_API

Dependents:   Hello_BLE F446RE-BLE

Fork of X_NUCLEO_IDB0XA1 by ST

Revision:
10:814262eb0746
Parent:
6:08cfc94b5f49
Child:
11:87ddcfa4fa48
--- a/BlueNRGGap.cpp	Fri Aug 01 14:25:23 2014 +0000
+++ b/BlueNRGGap.cpp	Mon Aug 04 08:48:24 2014 +0000
@@ -16,9 +16,13 @@
 
 #include "BlueNRGDevice.h"
 #include "mbed.h"
+#include "Payload.h"
 
 //Local Variables
-const uint8_t *device_name;
+const char *local_name = NULL;
+uint8_t local_name_length = 0;
+
+Serial pc1(USBTX, USBRX); // tx, rx. For obtaining logs on terminal
 
 /**************************************************************************/
 /*!
@@ -65,17 +69,74 @@
     }
 
     /* Make sure we have a payload! */
-    if (advData.getPayloadLen() == 0) {
+    if (advData.getPayloadLen() <= 0) {
         return BLE_ERROR_PARAM_OUT_OF_RANGE;
+    } else { //set the advData here in some local variable so that startAdvertising can use it.
+        Payload load(advData.getPayload(), advData.getPayloadLen());
+        
+        for(uint8_t index=0; index<load.getPayloadUnitCount(); index++) {
+            //UnitPayload unitLoad = load.getPayLoadAtIndex(index);
+            switch(load.getIDAtIndex(index)) {
+                case GapAdvertisingData::FLAGS:                              /* ref *Flags */
+                break;
+                case GapAdvertisingData::INCOMPLETE_LIST_16BIT_SERVICE_IDS:  /**< Incomplete list of 16-bit Service IDs */
+                break;
+                case GapAdvertisingData::COMPLETE_LIST_16BIT_SERVICE_IDS:    /**< Complete list of 16-bit Service IDs */
+                break;
+                case GapAdvertisingData::INCOMPLETE_LIST_32BIT_SERVICE_IDS:  /**< Incomplete list of 32-bit Service IDs (not relevant for Bluetooth 4.0) */
+                break;
+                case GapAdvertisingData::COMPLETE_LIST_32BIT_SERVICE_IDS:    /**< Complete list of 32-bit Service IDs (not relevant for Bluetooth 4.0) */
+                break;
+                case GapAdvertisingData::INCOMPLETE_LIST_128BIT_SERVICE_IDS: /**< Incomplete list of 128-bit Service IDs */
+                break;
+                case GapAdvertisingData::COMPLETE_LIST_128BIT_SERVICE_IDS:   /**< Complete list of 128-bit Service IDs */
+                break;
+                case GapAdvertisingData::SHORTENED_LOCAL_NAME:               /**< Shortened Local Name */
+                break;
+                case GapAdvertisingData::COMPLETE_LOCAL_NAME:                /**< Complete Local Name */
+                    const char *device_name = NULL;
+                    device_name = (const char*)load.getDataAtIndex(index);  // to be set later when startAdvertising() is called
+                    //const char* local_name = NULL;
+                    if(device_name != NULL) {  
+                        pc1.printf("Advertising type: COMPLETE_LOCAL_NAME\n");
+                        char *namePtr = new char[1+sizeof(device_name)];
+                        namePtr[0] = AD_TYPE_COMPLETE_LOCAL_NAME;
+                        pc1.printf("now setting name to: %s...\n", device_name);
+                        
+                        int i=0;
+                        while(device_name[i]!=0) {
+                            namePtr[i+1] = device_name[i];
+                            pc1.printf("%c\n", namePtr[i+1]);
+                            i++;
+                            }
+                        local_name_length = i;
+                        pc1.printf("device_name length=%d", local_name_length);
+                        //const char* local_name = (const char*)namePtr;  
+                    }                
+                    break;
+                
+                case GapAdvertisingData::TX_POWER_LEVEL:                     /**< TX Power Level (in dBm) */
+                break;
+                case GapAdvertisingData::DEVICE_ID:                          /**< Device ID */
+                break;
+                case GapAdvertisingData::SLAVE_CONNECTION_INTERVAL_RANGE:    /**< Slave :Connection Interval Range */
+                break;
+                case GapAdvertisingData::SERVICE_DATA:                       /**< Service Data */
+                break;
+                case GapAdvertisingData::APPEARANCE:                         /**< \ref Appearance */
+                break;
+                case GapAdvertisingData::ADVERTISING_INTERVAL:               /**< Advertising Interval */
+                // taken care of in startAdvertising(params)
+                break;
+                case GapAdvertisingData::MANUFACTURER_SPECIFIC_DATA:        /**< Manufacturer Specific Data */                                
+                break;
+                                
+            }
     }
+        //const uint8_t *payload = advData.getPayload();
 
-    //set the advData here in some local variable so that startAdvertising can use it.
-    if (advData.getPayloadLen() > 0) {
-        const uint8_t *payload = advData.getPayload();
-        device_name = advData.getPayload();
     }
     
-    
     return BLE_ERROR_NONE;
 }
 
@@ -139,8 +200,7 @@
   //const char local_name[] = {AD_TYPE_COMPLETE_LOCAL_NAME,device_name[27],device_name[28],device_name[29],device_name[30], device_name[31],
    //                                                     device_name[32], device_name[33], device_name[34], device_name[35], device_name[36]};
   
-  const char local_name[] = {AD_TYPE_COMPLETE_LOCAL_NAME,device_name[13],device_name[14],device_name[15],device_name[16], device_name[17],
-                                                       device_name[18], device_name[19], device_name[20], device_name[21], device_name[22]};
+
   
   //const char local_name[] = {AD_TYPE_COMPLETE_LOCAL_NAME,device_name[27],device_name[28]};
   const LongUUID_t HRM_SERVICE_UUID_128 = {0x18, 0x0D};
@@ -151,8 +211,19 @@
                         Local_Name_Length, local_name, service_uuid_length, service_uuid_list, Slave_conn_intvl_min, Slave_conn_intvl_max);*/
   /*LINK_LAYER.H DESCRIBES THE ADVERTISING TYPES*/ 
                                 
-  ret = aci_gap_set_discoverable(params.getAdvertisingType(), params.getInterval(), 0, PUBLIC_ADDR, NO_WHITE_LIST_USE,
-                                 11 /*Length of the local_name[] array*/, local_name, 0, NULL, 0, 0);
+        
+  ret = aci_gap_set_discoverable(params.getAdvertisingType(), // Advertising_Event_Type
+                                params.getInterval(),   // Adv_Interval_Max
+                                0,   // Adv_Interval_Min
+                                PUBLIC_ADDR, // Address_Type
+                                NO_WHITE_LIST_USE,  // Adv_Filter_Policy
+                                local_name_length, // Local_Name_Length
+                                local_name, // Local_Name
+                                0,  //Service_Uuid_Length
+                                NULL, //Service_Uuid_List
+                                0, // Slave_Conn_Interval_Min
+                                0);  // Slave_Conn_Interval_Max
+                       
   state.advertising = 1;
   
     return BLE_ERROR_NONE;