Fork of ble-x-nucleo-idb0xa1 with changes required by BleStarMbed

Dependents:   ble-star-mbed

Committer:
lorevee
Date:
Tue Feb 20 11:07:16 2018 +0000
Revision:
0:ac0b0725c6fa
Initial commit

Who changed what in which revision?

UserRevisionLine numberNew contents of line
lorevee 0:ac0b0725c6fa 1 /* mbed Microcontroller Library
lorevee 0:ac0b0725c6fa 2 * Copyright (c) 2006-2013 ARM Limited
lorevee 0:ac0b0725c6fa 3 *
lorevee 0:ac0b0725c6fa 4 * Licensed under the Apache License, Version 2.0 (the "License");
lorevee 0:ac0b0725c6fa 5 * you may not use this file except in compliance with the License.
lorevee 0:ac0b0725c6fa 6 * You may obtain a copy of the License at
lorevee 0:ac0b0725c6fa 7 *
lorevee 0:ac0b0725c6fa 8 * http://www.apache.org/licenses/LICENSE-2.0
lorevee 0:ac0b0725c6fa 9 *
lorevee 0:ac0b0725c6fa 10 * Unless required by applicable law or agreed to in writing, software
lorevee 0:ac0b0725c6fa 11 * distributed under the License is distributed on an "AS IS" BASIS,
lorevee 0:ac0b0725c6fa 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
lorevee 0:ac0b0725c6fa 13 * See the License for the specific language governing permissions and
lorevee 0:ac0b0725c6fa 14 * limitations under the License.
lorevee 0:ac0b0725c6fa 15 */
lorevee 0:ac0b0725c6fa 16
lorevee 0:ac0b0725c6fa 17
lorevee 0:ac0b0725c6fa 18 /**
lorevee 0:ac0b0725c6fa 19 ******************************************************************************
lorevee 0:ac0b0725c6fa 20 * @file btle.cpp
lorevee 0:ac0b0725c6fa 21 * @author STMicroelectronics
lorevee 0:ac0b0725c6fa 22 * @brief Implementation BlueNRG Init and helper functions.
lorevee 0:ac0b0725c6fa 23 ******************************************************************************
lorevee 0:ac0b0725c6fa 24 * @copy
lorevee 0:ac0b0725c6fa 25 *
lorevee 0:ac0b0725c6fa 26 * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
lorevee 0:ac0b0725c6fa 27 * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
lorevee 0:ac0b0725c6fa 28 * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
lorevee 0:ac0b0725c6fa 29 * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
lorevee 0:ac0b0725c6fa 30 * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
lorevee 0:ac0b0725c6fa 31 * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
lorevee 0:ac0b0725c6fa 32 *
lorevee 0:ac0b0725c6fa 33 * <h2><center>&copy; COPYRIGHT 2013 STMicroelectronics</center></h2>
lorevee 0:ac0b0725c6fa 34 */
lorevee 0:ac0b0725c6fa 35
lorevee 0:ac0b0725c6fa 36
lorevee 0:ac0b0725c6fa 37 #include "btle.h"
lorevee 0:ac0b0725c6fa 38 #include "ble/Gap.h"
lorevee 0:ac0b0725c6fa 39 #include "ble/GapEvents.h"
lorevee 0:ac0b0725c6fa 40 #include "BlueNRGGap.h"
lorevee 0:ac0b0725c6fa 41 #include "BlueNRGGattServer.h"
lorevee 0:ac0b0725c6fa 42 #include "BlueNRGGattClient.h"
lorevee 0:ac0b0725c6fa 43 #include "ble_utils.h"
lorevee 0:ac0b0725c6fa 44
lorevee 0:ac0b0725c6fa 45 #include "bluenrg_targets.h"
lorevee 0:ac0b0725c6fa 46
lorevee 0:ac0b0725c6fa 47 #ifdef __cplusplus
lorevee 0:ac0b0725c6fa 48 extern "C" {
lorevee 0:ac0b0725c6fa 49 #endif
lorevee 0:ac0b0725c6fa 50
lorevee 0:ac0b0725c6fa 51
lorevee 0:ac0b0725c6fa 52 /* C File Includes ------------------------------------------------------------------*/
lorevee 0:ac0b0725c6fa 53 #include <stdio.h>
lorevee 0:ac0b0725c6fa 54 #include <string.h>
lorevee 0:ac0b0725c6fa 55 #include "ble_hci.h"
lorevee 0:ac0b0725c6fa 56 #include "ble_hci_const.h"
lorevee 0:ac0b0725c6fa 57 #include "bluenrg_aci.h"
lorevee 0:ac0b0725c6fa 58 #include "bluenrg_hal_aci.h"
lorevee 0:ac0b0725c6fa 59 #include "bluenrg_gap.h"
lorevee 0:ac0b0725c6fa 60 #include "bluenrg_utils.h"
lorevee 0:ac0b0725c6fa 61
lorevee 0:ac0b0725c6fa 62 #include "ble_hal_types.h"
lorevee 0:ac0b0725c6fa 63 #include "ble_hal.h"
lorevee 0:ac0b0725c6fa 64 #include "ble_gp_timer.h"
lorevee 0:ac0b0725c6fa 65 #include "ble_osal.h"
lorevee 0:ac0b0725c6fa 66 #include "ble_sm.h"
lorevee 0:ac0b0725c6fa 67 #include "ble_debug.h"
lorevee 0:ac0b0725c6fa 68
lorevee 0:ac0b0725c6fa 69 #ifdef __cplusplus
lorevee 0:ac0b0725c6fa 70 }
lorevee 0:ac0b0725c6fa 71 #endif
lorevee 0:ac0b0725c6fa 72
lorevee 0:ac0b0725c6fa 73 #define IDB04A1 0
lorevee 0:ac0b0725c6fa 74 #define IDB05A1 1
lorevee 0:ac0b0725c6fa 75
lorevee 0:ac0b0725c6fa 76 /* See file 'bluenrg_targets.h' for details regarding the BLUENRG_STACK_MODE */
lorevee 0:ac0b0725c6fa 77 #define STACK_MODE BLUENRG_STACK_MODE
lorevee 0:ac0b0725c6fa 78
lorevee 0:ac0b0725c6fa 79 void HCI_Input(tHciDataPacket * hciReadPacket);
lorevee 0:ac0b0725c6fa 80
lorevee 0:ac0b0725c6fa 81 uint16_t g_gap_service_handle = 0;
lorevee 0:ac0b0725c6fa 82 uint16_t g_appearance_char_handle = 0;
lorevee 0:ac0b0725c6fa 83 uint16_t g_device_name_char_handle = 0;
lorevee 0:ac0b0725c6fa 84 uint16_t g_preferred_connection_parameters_char_handle = 0;
lorevee 0:ac0b0725c6fa 85
lorevee 0:ac0b0725c6fa 86 /* Private variables ---------------------------------------------------------*/
lorevee 0:ac0b0725c6fa 87 volatile uint8_t set_connectable = 1;
lorevee 0:ac0b0725c6fa 88
lorevee 0:ac0b0725c6fa 89 static char versionString[32];
lorevee 0:ac0b0725c6fa 90 uint8_t bnrg_expansion_board = IDB04A1; /* at startup, suppose the X-NUCLEO-IDB04A1 is used */
lorevee 0:ac0b0725c6fa 91
lorevee 0:ac0b0725c6fa 92 /**************************************************************************/
lorevee 0:ac0b0725c6fa 93 /*!
lorevee 0:ac0b0725c6fa 94 @brief Init the BTLE stack with the specified role
lorevee 0:ac0b0725c6fa 95 @returns void
lorevee 0:ac0b0725c6fa 96 */
lorevee 0:ac0b0725c6fa 97 /**************************************************************************/
lorevee 0:ac0b0725c6fa 98 void btleInit(void)
lorevee 0:ac0b0725c6fa 99 {
lorevee 0:ac0b0725c6fa 100 PRINTF("btleInit>>\n\r");
lorevee 0:ac0b0725c6fa 101
lorevee 0:ac0b0725c6fa 102 int ret;
lorevee 0:ac0b0725c6fa 103 uint8_t hwVersion;
lorevee 0:ac0b0725c6fa 104 uint16_t fwVersion;
lorevee 0:ac0b0725c6fa 105 uint16_t service_handle, dev_name_char_handle, appearance_char_handle;
lorevee 0:ac0b0725c6fa 106
lorevee 0:ac0b0725c6fa 107 /* Reset BlueNRG SPI interface */
lorevee 0:ac0b0725c6fa 108 BlueNRG_RST();
lorevee 0:ac0b0725c6fa 109
lorevee 0:ac0b0725c6fa 110 /* get the BlueNRG HW and FW versions */
lorevee 0:ac0b0725c6fa 111 getBlueNRGVersion(&hwVersion, &fwVersion);
lorevee 0:ac0b0725c6fa 112
lorevee 0:ac0b0725c6fa 113 /*
lorevee 0:ac0b0725c6fa 114 * Reset BlueNRG again otherwise we won't
lorevee 0:ac0b0725c6fa 115 * be able to change its MAC address.
lorevee 0:ac0b0725c6fa 116 * aci_hal_write_config_data() must be the first
lorevee 0:ac0b0725c6fa 117 * command after reset otherwise it will fail.
lorevee 0:ac0b0725c6fa 118 */
lorevee 0:ac0b0725c6fa 119 BlueNRG_RST();
lorevee 0:ac0b0725c6fa 120
lorevee 0:ac0b0725c6fa 121 if (hwVersion > 0x30) { /* X-NUCLEO-IDB05A1 expansion board is used */
lorevee 0:ac0b0725c6fa 122 bnrg_expansion_board = IDB05A1;
lorevee 0:ac0b0725c6fa 123 }
lorevee 0:ac0b0725c6fa 124
lorevee 0:ac0b0725c6fa 125 /* set BLE version string */
lorevee 0:ac0b0725c6fa 126 setVersionString(hwVersion, fwVersion);
lorevee 0:ac0b0725c6fa 127
lorevee 0:ac0b0725c6fa 128 if (bnrg_expansion_board == IDB05A1) {
lorevee 0:ac0b0725c6fa 129 uint8_t stackMode = STACK_MODE;
lorevee 0:ac0b0725c6fa 130 ret = aci_hal_write_config_data(CONFIG_DATA_MODE_OFFSET,
lorevee 0:ac0b0725c6fa 131 CONFIG_DATA_MODE_LEN,
lorevee 0:ac0b0725c6fa 132 &stackMode);
lorevee 0:ac0b0725c6fa 133 }
lorevee 0:ac0b0725c6fa 134
lorevee 0:ac0b0725c6fa 135 ret = aci_gatt_init();
lorevee 0:ac0b0725c6fa 136 if(ret != BLE_STATUS_SUCCESS){
lorevee 0:ac0b0725c6fa 137 PRINTF("GATT_Init failed.\n");
lorevee 0:ac0b0725c6fa 138 }
lorevee 0:ac0b0725c6fa 139 if (bnrg_expansion_board == IDB05A1) {
lorevee 0:ac0b0725c6fa 140 ret = aci_gap_init_IDB05A1(GAP_PERIPHERAL_ROLE_IDB05A1|GAP_CENTRAL_ROLE_IDB05A1|GAP_OBSERVER_ROLE_IDB05A1,
lorevee 0:ac0b0725c6fa 141 0,
lorevee 0:ac0b0725c6fa 142 0x18,
lorevee 0:ac0b0725c6fa 143 &service_handle,
lorevee 0:ac0b0725c6fa 144 &dev_name_char_handle,
lorevee 0:ac0b0725c6fa 145 &appearance_char_handle);
lorevee 0:ac0b0725c6fa 146 } else {
lorevee 0:ac0b0725c6fa 147 // IDB04A1 is configured as peripheral by default
lorevee 0:ac0b0725c6fa 148 ret = aci_gap_init_IDB04A1(GAP_PERIPHERAL_ROLE_IDB04A1, &service_handle, &dev_name_char_handle, &appearance_char_handle);
lorevee 0:ac0b0725c6fa 149 }
lorevee 0:ac0b0725c6fa 150
lorevee 0:ac0b0725c6fa 151 // read the default static address and inject it into the GAP object
lorevee 0:ac0b0725c6fa 152 {
lorevee 0:ac0b0725c6fa 153 Gap::Address_t BLE_address_BE = { 0 };
lorevee 0:ac0b0725c6fa 154 uint8_t data_len_out;
lorevee 0:ac0b0725c6fa 155 aci_hal_read_config_data(CONFIG_DATA_RANDOM_ADDRESS, BDADDR_SIZE, &data_len_out, BLE_address_BE);
lorevee 0:ac0b0725c6fa 156 // FIXME error handling of this function
lorevee 0:ac0b0725c6fa 157 BlueNRGGap::getInstance().setAddress(BLEProtocol::AddressType::RANDOM_STATIC, BLE_address_BE);
lorevee 0:ac0b0725c6fa 158 }
lorevee 0:ac0b0725c6fa 159
lorevee 0:ac0b0725c6fa 160 if(ret != BLE_STATUS_SUCCESS){
lorevee 0:ac0b0725c6fa 161 PRINTF("GAP_Init failed.\n");
lorevee 0:ac0b0725c6fa 162 }
lorevee 0:ac0b0725c6fa 163
lorevee 0:ac0b0725c6fa 164 //FIXME: Security and passkey set by default
lorevee 0:ac0b0725c6fa 165 ret = aci_gap_set_auth_requirement(MITM_PROTECTION_REQUIRED,
lorevee 0:ac0b0725c6fa 166 OOB_AUTH_DATA_ABSENT,
lorevee 0:ac0b0725c6fa 167 NULL,
lorevee 0:ac0b0725c6fa 168 7,
lorevee 0:ac0b0725c6fa 169 16,
lorevee 0:ac0b0725c6fa 170 USE_FIXED_PIN_FOR_PAIRING,
lorevee 0:ac0b0725c6fa 171 123456,
lorevee 0:ac0b0725c6fa 172 BONDING);
lorevee 0:ac0b0725c6fa 173 if (ret != BLE_STATUS_SUCCESS) {
lorevee 0:ac0b0725c6fa 174 PRINTF("Auth Req set failed.\n");
lorevee 0:ac0b0725c6fa 175 }
lorevee 0:ac0b0725c6fa 176
lorevee 0:ac0b0725c6fa 177 aci_hal_set_tx_power_level(1,4);
lorevee 0:ac0b0725c6fa 178
lorevee 0:ac0b0725c6fa 179 g_gap_service_handle = service_handle;
lorevee 0:ac0b0725c6fa 180 g_appearance_char_handle = appearance_char_handle;
lorevee 0:ac0b0725c6fa 181 g_device_name_char_handle = dev_name_char_handle;
lorevee 0:ac0b0725c6fa 182 //Device Name is set from Accumulate Adv Data Payload or through setDeviceName API
lorevee 0:ac0b0725c6fa 183 /*ret = aci_gatt_update_char_value(service_handle, dev_name_char_handle, 0,
lorevee 0:ac0b0725c6fa 184 strlen(name), (tHalUint8 *)name);*/
lorevee 0:ac0b0725c6fa 185
lorevee 0:ac0b0725c6fa 186 signalEventsToProcess();
lorevee 0:ac0b0725c6fa 187 // update the peripheral preferred conenction parameters handle
lorevee 0:ac0b0725c6fa 188 // This value is hardcoded at the moment.
lorevee 0:ac0b0725c6fa 189 g_preferred_connection_parameters_char_handle = 10;
lorevee 0:ac0b0725c6fa 190
lorevee 0:ac0b0725c6fa 191 return;
lorevee 0:ac0b0725c6fa 192 }
lorevee 0:ac0b0725c6fa 193
lorevee 0:ac0b0725c6fa 194 /**************************************************************************/
lorevee 0:ac0b0725c6fa 195 /*!
lorevee 0:ac0b0725c6fa 196 @brief mbedOS
lorevee 0:ac0b0725c6fa 197
lorevee 0:ac0b0725c6fa 198 @param[in] void
lorevee 0:ac0b0725c6fa 199
lorevee 0:ac0b0725c6fa 200 @returns
lorevee 0:ac0b0725c6fa 201 */
lorevee 0:ac0b0725c6fa 202 /**************************************************************************/
lorevee 0:ac0b0725c6fa 203 int btle_handler_pending = 0;
lorevee 0:ac0b0725c6fa 204
lorevee 0:ac0b0725c6fa 205 void btle_handler(void)
lorevee 0:ac0b0725c6fa 206 {
lorevee 0:ac0b0725c6fa 207 btle_handler_pending = 0;
lorevee 0:ac0b0725c6fa 208 BlueNRGGap::getInstance().Process();
lorevee 0:ac0b0725c6fa 209 HCI_HandleSPI();
lorevee 0:ac0b0725c6fa 210 HCI_Process();
lorevee 0:ac0b0725c6fa 211 }
lorevee 0:ac0b0725c6fa 212
lorevee 0:ac0b0725c6fa 213 /* set BLE Version string */
lorevee 0:ac0b0725c6fa 214 void setVersionString(uint8_t hwVersion, uint16_t fwVersion)
lorevee 0:ac0b0725c6fa 215 {
lorevee 0:ac0b0725c6fa 216 if(bnrg_expansion_board == IDB04A1 || bnrg_expansion_board == IDB05A1) {
lorevee 0:ac0b0725c6fa 217 snprintf(versionString, sizeof(versionString), "ST BLE4.1 HW v%u.%u FW v%u.%u",
lorevee 0:ac0b0725c6fa 218 hwVersion>>4, (hwVersion&0x0F),
lorevee 0:ac0b0725c6fa 219 fwVersion>>8, (fwVersion&0x00F0)>>4);
lorevee 0:ac0b0725c6fa 220 } else {
lorevee 0:ac0b0725c6fa 221 snprintf(versionString, sizeof(versionString), "ST (unknown spec)");
lorevee 0:ac0b0725c6fa 222 }
lorevee 0:ac0b0725c6fa 223 }
lorevee 0:ac0b0725c6fa 224
lorevee 0:ac0b0725c6fa 225 /* get BLE Version string */
lorevee 0:ac0b0725c6fa 226 const char* getVersionString(void)
lorevee 0:ac0b0725c6fa 227 {
lorevee 0:ac0b0725c6fa 228 return versionString;
lorevee 0:ac0b0725c6fa 229 }
lorevee 0:ac0b0725c6fa 230
lorevee 0:ac0b0725c6fa 231 tBleStatus btleStartRadioScan(uint8_t scan_type,
lorevee 0:ac0b0725c6fa 232 uint16_t scan_interval,
lorevee 0:ac0b0725c6fa 233 uint16_t scan_window,
lorevee 0:ac0b0725c6fa 234 uint8_t own_address_type)
lorevee 0:ac0b0725c6fa 235 {
lorevee 0:ac0b0725c6fa 236 tBleStatus ret;
lorevee 0:ac0b0725c6fa 237
lorevee 0:ac0b0725c6fa 238 // Observer role is not supported by X-NUCLEO-IDB04A1, return BLE_ERROR_NOT_IMPLEMENTED
lorevee 0:ac0b0725c6fa 239 if(bnrg_expansion_board == IDB05A1) {
lorevee 0:ac0b0725c6fa 240 PRINTF("scan_interval=%d scan_window=%d\n\r", scan_interval, scan_window);
lorevee 0:ac0b0725c6fa 241 PRINTF("scan_type=%d own_address_type=%d\n\r", scan_type, own_address_type);
lorevee 0:ac0b0725c6fa 242 ret = aci_gap_start_observation_procedure(scan_interval,
lorevee 0:ac0b0725c6fa 243 scan_window,
lorevee 0:ac0b0725c6fa 244 scan_type,
lorevee 0:ac0b0725c6fa 245 own_address_type,
lorevee 0:ac0b0725c6fa 246 1); // 1 to filter duplicates
lorevee 0:ac0b0725c6fa 247 } else {
lorevee 0:ac0b0725c6fa 248 ret = BLE_STATUS_INVALID_CID;
lorevee 0:ac0b0725c6fa 249 }
lorevee 0:ac0b0725c6fa 250
lorevee 0:ac0b0725c6fa 251 return ret;
lorevee 0:ac0b0725c6fa 252
lorevee 0:ac0b0725c6fa 253 }
lorevee 0:ac0b0725c6fa 254
lorevee 0:ac0b0725c6fa 255 /*!
lorevee 0:ac0b0725c6fa 256 @brief Not Used
lorevee 0:ac0b0725c6fa 257
lorevee 0:ac0b0725c6fa 258 @param[in] void
lorevee 0:ac0b0725c6fa 259
lorevee 0:ac0b0725c6fa 260 @returns
lorevee 0:ac0b0725c6fa 261 */
lorevee 0:ac0b0725c6fa 262 void SPI_Poll(void)
lorevee 0:ac0b0725c6fa 263 {
lorevee 0:ac0b0725c6fa 264 //HAL_GPIO_EXTI_Callback_Poll(BNRG_SPI_EXTI_PIN);
lorevee 0:ac0b0725c6fa 265 return;
lorevee 0:ac0b0725c6fa 266 }
lorevee 0:ac0b0725c6fa 267
lorevee 0:ac0b0725c6fa 268 void Attribute_Modified_CB(evt_blue_aci *blue_evt)
lorevee 0:ac0b0725c6fa 269 {
lorevee 0:ac0b0725c6fa 270 uint16_t conn_handle;
lorevee 0:ac0b0725c6fa 271 uint16_t attr_handle;
lorevee 0:ac0b0725c6fa 272 uint8_t data_length;
lorevee 0:ac0b0725c6fa 273 uint8_t *att_data;
lorevee 0:ac0b0725c6fa 274 uint8_t offset;
lorevee 0:ac0b0725c6fa 275
lorevee 0:ac0b0725c6fa 276 if (bnrg_expansion_board == IDB05A1) {
lorevee 0:ac0b0725c6fa 277 evt_gatt_attr_modified_IDB05A1 *evt = (evt_gatt_attr_modified_IDB05A1*)blue_evt->data;
lorevee 0:ac0b0725c6fa 278 conn_handle = evt->conn_handle;
lorevee 0:ac0b0725c6fa 279 attr_handle = evt->attr_handle;
lorevee 0:ac0b0725c6fa 280 data_length = evt->data_length;
lorevee 0:ac0b0725c6fa 281 att_data = evt->att_data;
lorevee 0:ac0b0725c6fa 282 offset = evt->offset;
lorevee 0:ac0b0725c6fa 283 } else {
lorevee 0:ac0b0725c6fa 284 evt_gatt_attr_modified_IDB04A1 *evt = (evt_gatt_attr_modified_IDB04A1*)blue_evt->data;
lorevee 0:ac0b0725c6fa 285 conn_handle = evt->conn_handle;
lorevee 0:ac0b0725c6fa 286 attr_handle = evt->attr_handle;
lorevee 0:ac0b0725c6fa 287 data_length = evt->data_length;
lorevee 0:ac0b0725c6fa 288 att_data = evt->att_data;
lorevee 0:ac0b0725c6fa 289 offset = 0;
lorevee 0:ac0b0725c6fa 290 }
lorevee 0:ac0b0725c6fa 291
lorevee 0:ac0b0725c6fa 292 //Extract the GattCharacteristic from p_characteristics[] and find the properties mask
lorevee 0:ac0b0725c6fa 293 GattCharacteristic *p_char = BlueNRGGattServer::getInstance().getCharacteristicFromHandle(attr_handle);
lorevee 0:ac0b0725c6fa 294 if(p_char!=NULL) {
lorevee 0:ac0b0725c6fa 295 GattAttribute::Handle_t charHandle = p_char->getValueAttribute().getHandle()-BlueNRGGattServer::CHAR_VALUE_HANDLE;
lorevee 0:ac0b0725c6fa 296 BlueNRGGattServer::HandleEnum_t currentHandle = BlueNRGGattServer::CHAR_HANDLE;
lorevee 0:ac0b0725c6fa 297 PRINTF("CharHandle %d, length: %d, Data: %d\n\r", charHandle, data_length, (uint16_t)att_data[0]);
lorevee 0:ac0b0725c6fa 298 PRINTF("getProperties 0x%x\n\r",p_char->getProperties());
lorevee 0:ac0b0725c6fa 299
lorevee 0:ac0b0725c6fa 300 if(attr_handle == charHandle+BlueNRGGattServer::CHAR_VALUE_HANDLE) {
lorevee 0:ac0b0725c6fa 301 currentHandle = BlueNRGGattServer::CHAR_VALUE_HANDLE;
lorevee 0:ac0b0725c6fa 302 }
lorevee 0:ac0b0725c6fa 303
lorevee 0:ac0b0725c6fa 304 if(attr_handle == charHandle+BlueNRGGattServer::CHAR_DESC_HANDLE) {
lorevee 0:ac0b0725c6fa 305 currentHandle = BlueNRGGattServer::CHAR_DESC_HANDLE;
lorevee 0:ac0b0725c6fa 306 }
lorevee 0:ac0b0725c6fa 307 PRINTF("currentHandle %d\n\r", currentHandle);
lorevee 0:ac0b0725c6fa 308
lorevee 0:ac0b0725c6fa 309
lorevee 0:ac0b0725c6fa 310
lorevee 0:ac0b0725c6fa 311
lorevee 0:ac0b0725c6fa 312
lorevee 0:ac0b0725c6fa 313
lorevee 0:ac0b0725c6fa 314 //Check if attr handle property is WRITEABLE, in the case generate GATT_EVENT_DATA_WRITTEN Event
lorevee 0:ac0b0725c6fa 315 if((currentHandle == BlueNRGGattServer::CHAR_VALUE_HANDLE)) {
lorevee 0:ac0b0725c6fa 316
lorevee 0:ac0b0725c6fa 317 PRINTF("*****WRITE CASE\n\r");
lorevee 0:ac0b0725c6fa 318
lorevee 0:ac0b0725c6fa 319 GattWriteCallbackParams writeParams;
lorevee 0:ac0b0725c6fa 320 writeParams.connHandle = conn_handle;
lorevee 0:ac0b0725c6fa 321 writeParams.handle = p_char->getValueAttribute().getHandle();
lorevee 0:ac0b0725c6fa 322 writeParams.writeOp = GattWriteCallbackParams::OP_WRITE_REQ;//Where to find this property in BLUENRG?
lorevee 0:ac0b0725c6fa 323 writeParams.len = data_length;
lorevee 0:ac0b0725c6fa 324 writeParams.data = att_data;
lorevee 0:ac0b0725c6fa 325 writeParams.offset = offset;
lorevee 0:ac0b0725c6fa 326
lorevee 0:ac0b0725c6fa 327 //BlueNRGGattServer::getInstance().handleEvent(GattServerEvents::GATT_EVENT_DATA_WRITTEN, attr_handle);
lorevee 0:ac0b0725c6fa 328 //Write the actual Data to the Attr Handle? (uint8_1[])att_data contains the data
lorevee 0:ac0b0725c6fa 329 if ((p_char->getValueAttribute().getValuePtr() != NULL) && (p_char->getValueAttribute().getLength() > 0)) {
lorevee 0:ac0b0725c6fa 330 BlueNRGGattServer::getInstance().write(
lorevee 0:ac0b0725c6fa 331 p_char->getValueAttribute().getHandle(),
lorevee 0:ac0b0725c6fa 332 (uint8_t*)att_data,
lorevee 0:ac0b0725c6fa 333 data_length,
lorevee 0:ac0b0725c6fa 334 false
lorevee 0:ac0b0725c6fa 335 );
lorevee 0:ac0b0725c6fa 336 }
lorevee 0:ac0b0725c6fa 337
lorevee 0:ac0b0725c6fa 338 BlueNRGGattServer::getInstance().HCIDataWrittenEvent(&writeParams);
lorevee 0:ac0b0725c6fa 339 } else {
lorevee 0:ac0b0725c6fa 340 PRINTF("*****WRITE DESCRIPTOR CASE\n\r");
lorevee 0:ac0b0725c6fa 341
lorevee 0:ac0b0725c6fa 342 GattWriteCallbackParams writeParams;
lorevee 0:ac0b0725c6fa 343 writeParams.connHandle = conn_handle;
lorevee 0:ac0b0725c6fa 344 writeParams.handle = attr_handle;
lorevee 0:ac0b0725c6fa 345 writeParams.writeOp = GattWriteCallbackParams::OP_WRITE_REQ;//Where to find this property in BLUENRG?
lorevee 0:ac0b0725c6fa 346 writeParams.len = data_length;
lorevee 0:ac0b0725c6fa 347 writeParams.data = att_data;
lorevee 0:ac0b0725c6fa 348 writeParams.offset = offset;
lorevee 0:ac0b0725c6fa 349
lorevee 0:ac0b0725c6fa 350 BlueNRGGattServer::getInstance().HCIDataWrittenEvent(&writeParams);
lorevee 0:ac0b0725c6fa 351
lorevee 0:ac0b0725c6fa 352 }//WRITE
lorevee 0:ac0b0725c6fa 353
lorevee 0:ac0b0725c6fa 354 }//if-pChar
lorevee 0:ac0b0725c6fa 355 }
lorevee 0:ac0b0725c6fa 356
lorevee 0:ac0b0725c6fa 357 #ifdef __cplusplus
lorevee 0:ac0b0725c6fa 358 extern "C" {
lorevee 0:ac0b0725c6fa 359 #endif
lorevee 0:ac0b0725c6fa 360
lorevee 0:ac0b0725c6fa 361 /**************************************************************************/
lorevee 0:ac0b0725c6fa 362 /*!
lorevee 0:ac0b0725c6fa 363 @brief Handle HCI Stack Event
lorevee 0:ac0b0725c6fa 364
lorevee 0:ac0b0725c6fa 365 @param[in] pckt
lorevee 0:ac0b0725c6fa 366 Event Packet sent by the stack to be decoded
lorevee 0:ac0b0725c6fa 367
lorevee 0:ac0b0725c6fa 368 @returns
lorevee 0:ac0b0725c6fa 369 */
lorevee 0:ac0b0725c6fa 370 /**************************************************************************/
lorevee 0:ac0b0725c6fa 371 extern void HCI_Event_CB(void *pckt) {
lorevee 0:ac0b0725c6fa 372 hci_uart_pckt *hci_pckt = (hci_uart_pckt*)pckt;
lorevee 0:ac0b0725c6fa 373 hci_event_pckt *event_pckt = (hci_event_pckt*)hci_pckt->data;
lorevee 0:ac0b0725c6fa 374
lorevee 0:ac0b0725c6fa 375 if(hci_pckt->type != HCI_EVENT_PKT)
lorevee 0:ac0b0725c6fa 376 return;
lorevee 0:ac0b0725c6fa 377
lorevee 0:ac0b0725c6fa 378 switch(event_pckt->evt){
lorevee 0:ac0b0725c6fa 379
lorevee 0:ac0b0725c6fa 380 case EVT_DISCONN_COMPLETE:
lorevee 0:ac0b0725c6fa 381 {
lorevee 0:ac0b0725c6fa 382 PRINTF("EVT_DISCONN_COMPLETE\n");
lorevee 0:ac0b0725c6fa 383
lorevee 0:ac0b0725c6fa 384 evt_disconn_complete *evt = (evt_disconn_complete*)event_pckt->data;
lorevee 0:ac0b0725c6fa 385 BlueNRGGattClient::getInstance().removeGattConnectionClient(evt->handle, evt->reason);
lorevee 0:ac0b0725c6fa 386 BlueNRGGap::getInstance().processDisconnectionEvent(evt->handle, (Gap::DisconnectionReason_t)evt->reason);
lorevee 0:ac0b0725c6fa 387 }
lorevee 0:ac0b0725c6fa 388 break;
lorevee 0:ac0b0725c6fa 389
lorevee 0:ac0b0725c6fa 390 case EVT_LE_META_EVENT:
lorevee 0:ac0b0725c6fa 391 {
lorevee 0:ac0b0725c6fa 392 PRINTF("EVT_LE_META_EVENT\n");
lorevee 0:ac0b0725c6fa 393
lorevee 0:ac0b0725c6fa 394 evt_le_meta_event *evt = (evt_le_meta_event *)event_pckt->data;
lorevee 0:ac0b0725c6fa 395
lorevee 0:ac0b0725c6fa 396 switch(evt->subevent){
lorevee 0:ac0b0725c6fa 397
lorevee 0:ac0b0725c6fa 398 case EVT_LE_CONN_COMPLETE:
lorevee 0:ac0b0725c6fa 399 {
lorevee 0:ac0b0725c6fa 400 PRINTF("EVT_LE_CONN_COMPLETE\n");
lorevee 0:ac0b0725c6fa 401 Gap::Address_t ownAddr;
lorevee 0:ac0b0725c6fa 402 Gap::AddressType_t ownAddrType;
lorevee 0:ac0b0725c6fa 403 BlueNRGGap::getInstance().getAddress(&ownAddrType, ownAddr);
lorevee 0:ac0b0725c6fa 404
lorevee 0:ac0b0725c6fa 405 Gap::AddressType_t peerAddrType = BLEProtocol::AddressType::RANDOM_STATIC;
lorevee 0:ac0b0725c6fa 406 Gap::Role_t role;
lorevee 0:ac0b0725c6fa 407
lorevee 0:ac0b0725c6fa 408 evt_le_connection_complete *cc = (evt_le_connection_complete *)evt->data;
lorevee 0:ac0b0725c6fa 409
lorevee 0:ac0b0725c6fa 410 BlueNRGGap::getInstance().setConnectionHandle(cc->handle);
lorevee 0:ac0b0725c6fa 411 BlueNRGGap::ConnectionParams_t connectionParams = {
lorevee 0:ac0b0725c6fa 412 /* minConnectionInterval = */ cc->interval,
lorevee 0:ac0b0725c6fa 413 /* maxConnectionInterval = */ cc->interval,
lorevee 0:ac0b0725c6fa 414 /* slaveLatency = */ cc->latency,
lorevee 0:ac0b0725c6fa 415 /* connectionSupervisionTimeout = */ cc->supervision_timeout
lorevee 0:ac0b0725c6fa 416 };
lorevee 0:ac0b0725c6fa 417
lorevee 0:ac0b0725c6fa 418 BlueNRGGap::getInstance().setConnectionInterval(cc->interval);
lorevee 0:ac0b0725c6fa 419
lorevee 0:ac0b0725c6fa 420 switch (cc->peer_bdaddr_type) {
lorevee 0:ac0b0725c6fa 421 case PUBLIC_ADDR:
lorevee 0:ac0b0725c6fa 422 peerAddrType = BLEProtocol::AddressType::PUBLIC;
lorevee 0:ac0b0725c6fa 423 break;
lorevee 0:ac0b0725c6fa 424 case STATIC_RANDOM_ADDR:
lorevee 0:ac0b0725c6fa 425 peerAddrType = BLEProtocol::AddressType::RANDOM_STATIC;
lorevee 0:ac0b0725c6fa 426 break;
lorevee 0:ac0b0725c6fa 427 case RESOLVABLE_PRIVATE_ADDR:
lorevee 0:ac0b0725c6fa 428 peerAddrType = BLEProtocol::AddressType::RANDOM_PRIVATE_RESOLVABLE;
lorevee 0:ac0b0725c6fa 429 break;
lorevee 0:ac0b0725c6fa 430 case NON_RESOLVABLE_PRIVATE_ADDR:
lorevee 0:ac0b0725c6fa 431 peerAddrType = BLEProtocol::AddressType::RANDOM_PRIVATE_NON_RESOLVABLE;
lorevee 0:ac0b0725c6fa 432 break;
lorevee 0:ac0b0725c6fa 433 }
lorevee 0:ac0b0725c6fa 434 //PRINTF("EVT_LE_CONN_COMPLETE LL role=%d\n", cc->role);
lorevee 0:ac0b0725c6fa 435 switch (cc->role) {
lorevee 0:ac0b0725c6fa 436 case 0: //master
lorevee 0:ac0b0725c6fa 437 role = Gap::CENTRAL;
lorevee 0:ac0b0725c6fa 438 break;
lorevee 0:ac0b0725c6fa 439 case 1:
lorevee 0:ac0b0725c6fa 440 role = Gap::PERIPHERAL;
lorevee 0:ac0b0725c6fa 441 break;
lorevee 0:ac0b0725c6fa 442 default:
lorevee 0:ac0b0725c6fa 443 role = Gap::PERIPHERAL;
lorevee 0:ac0b0725c6fa 444 break;
lorevee 0:ac0b0725c6fa 445 }
lorevee 0:ac0b0725c6fa 446 BlueNRGGattClient::getInstance().createGattConnectionClient(cc->handle);
lorevee 0:ac0b0725c6fa 447
lorevee 0:ac0b0725c6fa 448 BlueNRGGap::getInstance().setGapRole(role);
lorevee 0:ac0b0725c6fa 449
lorevee 0:ac0b0725c6fa 450 BlueNRGGap::getInstance().processConnectionEvent(cc->handle,
lorevee 0:ac0b0725c6fa 451 role,
lorevee 0:ac0b0725c6fa 452 peerAddrType,
lorevee 0:ac0b0725c6fa 453 cc->peer_bdaddr,
lorevee 0:ac0b0725c6fa 454 ownAddrType,
lorevee 0:ac0b0725c6fa 455 ownAddr,
lorevee 0:ac0b0725c6fa 456 &connectionParams);
lorevee 0:ac0b0725c6fa 457 }
lorevee 0:ac0b0725c6fa 458 break;
lorevee 0:ac0b0725c6fa 459
lorevee 0:ac0b0725c6fa 460 case EVT_LE_ADVERTISING_REPORT:
lorevee 0:ac0b0725c6fa 461 PRINTF("EVT_LE_ADVERTISING_REPORT\n\r");
lorevee 0:ac0b0725c6fa 462 /* FIXME: comment this otherwise it will be obscure and error prone if BlueNRG FW will be updated */
lorevee 0:ac0b0725c6fa 463 // This event is generated only by X-NUCLEO-IDB05A1 version but not by X-NUCLEO-IDB04A1 (which generates DEVICE_FOUND EVT)
lorevee 0:ac0b0725c6fa 464 // Formally the structure related to both events are identical except that for the ADV REPORT
lorevee 0:ac0b0725c6fa 465 // there is one more field (number of reports) which is not forwarded to upper layer.
lorevee 0:ac0b0725c6fa 466 // Thus we need to move one byte over (((uint8_t*)evt->data)+1) before persing the ADV REPORT.
lorevee 0:ac0b0725c6fa 467 le_advertising_info *pr = (le_advertising_info*) (((uint8_t*)evt->data)+1);
lorevee 0:ac0b0725c6fa 468 PRINTF("EVT_LE_ADVERTISING_REPORT evt_type=%d\n\r", pr->evt_type);
lorevee 0:ac0b0725c6fa 469
lorevee 0:ac0b0725c6fa 470 BlueNRGGap::getInstance().Discovery_CB(BlueNRGGap::DEVICE_FOUND,
lorevee 0:ac0b0725c6fa 471 pr->evt_type,
lorevee 0:ac0b0725c6fa 472 pr->bdaddr_type,
lorevee 0:ac0b0725c6fa 473 pr->bdaddr,
lorevee 0:ac0b0725c6fa 474 &pr->data_length,
lorevee 0:ac0b0725c6fa 475 &pr->data_RSSI[0],
lorevee 0:ac0b0725c6fa 476 &pr->data_RSSI[pr->data_length]);
lorevee 0:ac0b0725c6fa 477 break;
lorevee 0:ac0b0725c6fa 478 }
lorevee 0:ac0b0725c6fa 479 }
lorevee 0:ac0b0725c6fa 480 break;
lorevee 0:ac0b0725c6fa 481
lorevee 0:ac0b0725c6fa 482 case EVT_VENDOR:
lorevee 0:ac0b0725c6fa 483 {
lorevee 0:ac0b0725c6fa 484 evt_blue_aci *blue_evt = (evt_blue_aci*)event_pckt->data;
lorevee 0:ac0b0725c6fa 485 //PRINTF("EVT_VENDOR %d\n", blue_evt->ecode);
lorevee 0:ac0b0725c6fa 486
lorevee 0:ac0b0725c6fa 487 switch(blue_evt->ecode){
lorevee 0:ac0b0725c6fa 488
lorevee 0:ac0b0725c6fa 489 case EVT_BLUE_GATT_WRITE_PERMIT_REQ:
lorevee 0:ac0b0725c6fa 490 {
lorevee 0:ac0b0725c6fa 491 PRINTF("EVT_BLUE_GATT_WRITE_PERMIT_REQ\r\n");
lorevee 0:ac0b0725c6fa 492 evt_gatt_write_permit_req* write_req = (evt_gatt_write_permit_req*)blue_evt->data;
lorevee 0:ac0b0725c6fa 493
lorevee 0:ac0b0725c6fa 494 // ask the local server if the write operation is authorized
lorevee 0:ac0b0725c6fa 495 uint8_t err_code = BlueNRGGattServer::getInstance().Write_Request_CB(
lorevee 0:ac0b0725c6fa 496 write_req->conn_handle,
lorevee 0:ac0b0725c6fa 497 write_req->attr_handle,
lorevee 0:ac0b0725c6fa 498 write_req->data_length,
lorevee 0:ac0b0725c6fa 499 write_req->data
lorevee 0:ac0b0725c6fa 500 );
lorevee 0:ac0b0725c6fa 501 uint8_t write_status = err_code == 0 ? 0 : 1;
lorevee 0:ac0b0725c6fa 502
lorevee 0:ac0b0725c6fa 503 // reply to the shield
lorevee 0:ac0b0725c6fa 504 aci_gatt_write_response(
lorevee 0:ac0b0725c6fa 505 write_req->conn_handle,
lorevee 0:ac0b0725c6fa 506 write_req->attr_handle,
lorevee 0:ac0b0725c6fa 507 write_status,
lorevee 0:ac0b0725c6fa 508 err_code,
lorevee 0:ac0b0725c6fa 509 write_req->data_length,
lorevee 0:ac0b0725c6fa 510 write_req->data
lorevee 0:ac0b0725c6fa 511 );
lorevee 0:ac0b0725c6fa 512 }
lorevee 0:ac0b0725c6fa 513 break;
lorevee 0:ac0b0725c6fa 514
lorevee 0:ac0b0725c6fa 515 case EVT_BLUE_GATT_READ_PERMIT_REQ:
lorevee 0:ac0b0725c6fa 516 {
lorevee 0:ac0b0725c6fa 517 PRINTF("EVT_BLUE_GATT_READ_PERMIT_REQ_OK\n\r");
lorevee 0:ac0b0725c6fa 518 evt_gatt_read_permit_req *pr = (evt_gatt_read_permit_req*)blue_evt->data;
lorevee 0:ac0b0725c6fa 519 PRINTF("EVT_BLUE_GATT_READ_PERMIT_REQ_OK pr->attr_handle=%u\n\r", pr->attr_handle);
lorevee 0:ac0b0725c6fa 520 BlueNRGGattServer::getInstance().Read_Request_CB(pr->attr_handle);
lorevee 0:ac0b0725c6fa 521 }
lorevee 0:ac0b0725c6fa 522 break;
lorevee 0:ac0b0725c6fa 523
lorevee 0:ac0b0725c6fa 524 case EVT_BLUE_GATT_ATTRIBUTE_MODIFIED:
lorevee 0:ac0b0725c6fa 525 {
lorevee 0:ac0b0725c6fa 526 PRINTF("EVT_BLUE_GATT_ATTRIBUTE_MODIFIED\n\r");
lorevee 0:ac0b0725c6fa 527 /* this callback is invoked when a GATT attribute is modified
lorevee 0:ac0b0725c6fa 528 extract callback data and pass to suitable handler function */
lorevee 0:ac0b0725c6fa 529 Attribute_Modified_CB(blue_evt);
lorevee 0:ac0b0725c6fa 530 }
lorevee 0:ac0b0725c6fa 531 break;
lorevee 0:ac0b0725c6fa 532
lorevee 0:ac0b0725c6fa 533 //Any cases for Data Sent Notifications?
lorevee 0:ac0b0725c6fa 534 case EVT_BLUE_GATT_NOTIFICATION:
lorevee 0:ac0b0725c6fa 535 {
lorevee 0:ac0b0725c6fa 536 PRINTF("EVT_BLUE_GATT_NOTIFICATION");
lorevee 0:ac0b0725c6fa 537
lorevee 0:ac0b0725c6fa 538 evt_gatt_attr_notification *notification = (evt_gatt_attr_notification*)blue_evt->data;
lorevee 0:ac0b0725c6fa 539
lorevee 0:ac0b0725c6fa 540 GattHVXCallbackParams params;
lorevee 0:ac0b0725c6fa 541 params.connHandle = notification->conn_handle;
lorevee 0:ac0b0725c6fa 542 params.handle = notification->attr_handle;
lorevee 0:ac0b0725c6fa 543 params.type = BLE_HVX_NOTIFICATION;
lorevee 0:ac0b0725c6fa 544 params.len = notification->event_data_length - 2;
lorevee 0:ac0b0725c6fa 545 params.data = notification->attr_value;
lorevee 0:ac0b0725c6fa 546
lorevee 0:ac0b0725c6fa 547 BlueNRGGattClient::getInstance().processHVXEvent(&params);
lorevee 0:ac0b0725c6fa 548 }
lorevee 0:ac0b0725c6fa 549 break;
lorevee 0:ac0b0725c6fa 550
lorevee 0:ac0b0725c6fa 551 case EVT_BLUE_GATT_INDICATION:
lorevee 0:ac0b0725c6fa 552 {
lorevee 0:ac0b0725c6fa 553 PRINTF("EVT_BLUE_GATT_INDICATION");
lorevee 0:ac0b0725c6fa 554 evt_gatt_indication *indication = (evt_gatt_indication*)blue_evt->data;
lorevee 0:ac0b0725c6fa 555
lorevee 0:ac0b0725c6fa 556 GattHVXCallbackParams params;
lorevee 0:ac0b0725c6fa 557 params.connHandle = indication->conn_handle;
lorevee 0:ac0b0725c6fa 558 params.handle = indication->attr_handle;
lorevee 0:ac0b0725c6fa 559 params.type = BLE_HVX_INDICATION;
lorevee 0:ac0b0725c6fa 560 params.len = indication->event_data_length - 2;
lorevee 0:ac0b0725c6fa 561 params.data = indication->attr_value;
lorevee 0:ac0b0725c6fa 562
lorevee 0:ac0b0725c6fa 563 BlueNRGGattClient::getInstance().processHVXEvent(&params);
lorevee 0:ac0b0725c6fa 564 aci_gatt_confirm_indication(params.connHandle);
lorevee 0:ac0b0725c6fa 565 }
lorevee 0:ac0b0725c6fa 566 break;
lorevee 0:ac0b0725c6fa 567
lorevee 0:ac0b0725c6fa 568 case EVT_BLUE_ATT_READ_BY_GROUP_TYPE_RESP:
lorevee 0:ac0b0725c6fa 569 {
lorevee 0:ac0b0725c6fa 570 PRINTF("EVT_BLUE_ATT_READ_BY_GROUP_TYPE_RESP\n\r");
lorevee 0:ac0b0725c6fa 571 evt_att_read_by_group_resp *pr = (evt_att_read_by_group_resp*)blue_evt->data;
lorevee 0:ac0b0725c6fa 572 BlueNRGGattClient::getInstance().primaryServicesCB(pr->conn_handle,
lorevee 0:ac0b0725c6fa 573 pr->event_data_length,
lorevee 0:ac0b0725c6fa 574 pr->attribute_data_length,
lorevee 0:ac0b0725c6fa 575 pr->attribute_data_list);
lorevee 0:ac0b0725c6fa 576 }
lorevee 0:ac0b0725c6fa 577 break;
lorevee 0:ac0b0725c6fa 578 case EVT_BLUE_ATT_READ_BY_TYPE_RESP:
lorevee 0:ac0b0725c6fa 579 {
lorevee 0:ac0b0725c6fa 580 PRINTF("EVT_BLUE_ATT_READ_BY_TYPE_RESP\n\r");
lorevee 0:ac0b0725c6fa 581 evt_att_read_by_type_resp *pr = (evt_att_read_by_type_resp*)blue_evt->data;
lorevee 0:ac0b0725c6fa 582 BlueNRGGattClient::getInstance().serviceCharsCB(pr->conn_handle,
lorevee 0:ac0b0725c6fa 583 pr->event_data_length,
lorevee 0:ac0b0725c6fa 584 pr->handle_value_pair_length,
lorevee 0:ac0b0725c6fa 585 pr->handle_value_pair);
lorevee 0:ac0b0725c6fa 586 }
lorevee 0:ac0b0725c6fa 587 break;
lorevee 0:ac0b0725c6fa 588 case EVT_BLUE_ATT_READ_RESP:
lorevee 0:ac0b0725c6fa 589 {
lorevee 0:ac0b0725c6fa 590 PRINTF("EVT_BLUE_ATT_READ_RESP\n\r");
lorevee 0:ac0b0725c6fa 591 evt_att_read_resp *pr = (evt_att_read_resp*)blue_evt->data;
lorevee 0:ac0b0725c6fa 592 BlueNRGGattClient::getInstance().charReadCB(pr->conn_handle,
lorevee 0:ac0b0725c6fa 593 pr->event_data_length,
lorevee 0:ac0b0725c6fa 594 pr->attribute_value);
lorevee 0:ac0b0725c6fa 595 }
lorevee 0:ac0b0725c6fa 596 break;
lorevee 0:ac0b0725c6fa 597 case EVT_BLUE_ATT_EXEC_WRITE_RESP:
lorevee 0:ac0b0725c6fa 598 {
lorevee 0:ac0b0725c6fa 599 PRINTF("EVT_BLUE_ATT_EXEC_WRITE_RESP\n\r");
lorevee 0:ac0b0725c6fa 600 evt_att_prepare_write_resp *pr = (evt_att_prepare_write_resp*)blue_evt->data;
lorevee 0:ac0b0725c6fa 601 BlueNRGGattClient::getInstance().charWriteExecCB(pr->conn_handle,
lorevee 0:ac0b0725c6fa 602 pr->event_data_length);
lorevee 0:ac0b0725c6fa 603 }
lorevee 0:ac0b0725c6fa 604 break;
lorevee 0:ac0b0725c6fa 605 case EVT_BLUE_ATT_PREPARE_WRITE_RESP:
lorevee 0:ac0b0725c6fa 606 {
lorevee 0:ac0b0725c6fa 607 PRINTF("EVT_BLUE_ATT_PREPARE_WRITE_RESP\n\r");
lorevee 0:ac0b0725c6fa 608 evt_att_prepare_write_resp *pr = (evt_att_prepare_write_resp*)blue_evt->data;
lorevee 0:ac0b0725c6fa 609 BlueNRGGattClient::getInstance().charWritePrepareCB(pr->conn_handle,
lorevee 0:ac0b0725c6fa 610 pr->event_data_length,
lorevee 0:ac0b0725c6fa 611 pr->attribute_handle,
lorevee 0:ac0b0725c6fa 612 pr->offset,
lorevee 0:ac0b0725c6fa 613 pr->part_attr_value);
lorevee 0:ac0b0725c6fa 614 }
lorevee 0:ac0b0725c6fa 615 break;
lorevee 0:ac0b0725c6fa 616 case EVT_BLUE_GATT_DISC_READ_CHAR_BY_UUID_RESP:
lorevee 0:ac0b0725c6fa 617 {
lorevee 0:ac0b0725c6fa 618 PRINTF("EVT_BLUE_GATT_DISC_READ_CHAR_BY_UUID_RESP\n\r");
lorevee 0:ac0b0725c6fa 619 evt_gatt_disc_read_char_by_uuid_resp *pr = (evt_gatt_disc_read_char_by_uuid_resp*)blue_evt->data;
lorevee 0:ac0b0725c6fa 620 BlueNRGGattClient::getInstance().serviceCharByUUIDCB(pr->conn_handle,
lorevee 0:ac0b0725c6fa 621 pr->event_data_length,
lorevee 0:ac0b0725c6fa 622 pr->attr_handle,
lorevee 0:ac0b0725c6fa 623 pr->attr_value);
lorevee 0:ac0b0725c6fa 624 }
lorevee 0:ac0b0725c6fa 625 break;
lorevee 0:ac0b0725c6fa 626 case EVT_BLUE_ATT_FIND_BY_TYPE_VAL_RESP:
lorevee 0:ac0b0725c6fa 627 {
lorevee 0:ac0b0725c6fa 628 PRINTF("EVT_BLUE_ATT_FIND_BY_TYPE_VAL_RESP\n\r");
lorevee 0:ac0b0725c6fa 629 evt_att_find_by_type_val_resp *pr = (evt_att_find_by_type_val_resp*)blue_evt->data;
lorevee 0:ac0b0725c6fa 630 BlueNRGGattClient::getInstance().primaryServiceCB(pr->conn_handle,
lorevee 0:ac0b0725c6fa 631 pr->event_data_length,
lorevee 0:ac0b0725c6fa 632 pr->handles_info_list);
lorevee 0:ac0b0725c6fa 633 }
lorevee 0:ac0b0725c6fa 634 break;
lorevee 0:ac0b0725c6fa 635 case EVT_BLUE_ATT_FIND_INFORMATION_RESP:
lorevee 0:ac0b0725c6fa 636 {
lorevee 0:ac0b0725c6fa 637 PRINTF("EVT_BLUE_ATT_FIND_INFORMATION_RESP\n\r");
lorevee 0:ac0b0725c6fa 638 evt_att_find_information_resp *pr = (evt_att_find_information_resp*)blue_evt->data;
lorevee 0:ac0b0725c6fa 639 BlueNRGGattClient::getInstance().discAllCharacDescCB(pr->conn_handle,
lorevee 0:ac0b0725c6fa 640 pr->event_data_length,
lorevee 0:ac0b0725c6fa 641 pr->format,
lorevee 0:ac0b0725c6fa 642 pr->handle_uuid_pair);
lorevee 0:ac0b0725c6fa 643 }
lorevee 0:ac0b0725c6fa 644 break;
lorevee 0:ac0b0725c6fa 645 case EVT_BLUE_GATT_PROCEDURE_COMPLETE:
lorevee 0:ac0b0725c6fa 646 {
lorevee 0:ac0b0725c6fa 647 evt_gatt_procedure_complete *evt = (evt_gatt_procedure_complete*)blue_evt->data;
lorevee 0:ac0b0725c6fa 648 PRINTF("EVT_BLUE_GATT_PROCEDURE_COMPLETE error_code=%d\n\r", evt->error_code);
lorevee 0:ac0b0725c6fa 649 BlueNRGGattClient::getInstance().gattProcedureCompleteCB(evt->conn_handle, evt->error_code);
lorevee 0:ac0b0725c6fa 650 }
lorevee 0:ac0b0725c6fa 651 break;
lorevee 0:ac0b0725c6fa 652
lorevee 0:ac0b0725c6fa 653 case EVT_BLUE_L2CAP_CONN_UPD_REQ:
lorevee 0:ac0b0725c6fa 654 {
lorevee 0:ac0b0725c6fa 655 PRINTF("EVT_BLUE_L2CAP_CONN_UPD_REQ\r\n");
lorevee 0:ac0b0725c6fa 656 evt_l2cap_conn_upd_req *evt = (evt_l2cap_conn_upd_req*)blue_evt->data;
lorevee 0:ac0b0725c6fa 657 if(bnrg_expansion_board == IDB05A1) {
lorevee 0:ac0b0725c6fa 658 // we assume the application accepts the request from the slave
lorevee 0:ac0b0725c6fa 659 aci_l2cap_connection_parameter_update_response_IDB05A1(evt->conn_handle,
lorevee 0:ac0b0725c6fa 660 evt->interval_min,
lorevee 0:ac0b0725c6fa 661 evt->interval_max,
lorevee 0:ac0b0725c6fa 662 evt->slave_latency,
lorevee 0:ac0b0725c6fa 663 evt->timeout_mult,
lorevee 0:ac0b0725c6fa 664 CONN_L1, CONN_L2,
lorevee 0:ac0b0725c6fa 665 evt->identifier,
lorevee 0:ac0b0725c6fa 666 0x0000);
lorevee 0:ac0b0725c6fa 667 }
lorevee 0:ac0b0725c6fa 668 }
lorevee 0:ac0b0725c6fa 669 break;
lorevee 0:ac0b0725c6fa 670
lorevee 0:ac0b0725c6fa 671 case EVT_BLUE_L2CAP_CONN_UPD_RESP:
lorevee 0:ac0b0725c6fa 672 {
lorevee 0:ac0b0725c6fa 673 evt_l2cap_conn_upd_resp *evt = (evt_l2cap_conn_upd_resp*)blue_evt->data;
lorevee 0:ac0b0725c6fa 674 PRINTF("EVT_BLUE_L2CAP_CONN_UPD_RESP code=0x%x, result=0x%x\r\n", evt->code, evt->result);
lorevee 0:ac0b0725c6fa 675 }
lorevee 0:ac0b0725c6fa 676 break;
lorevee 0:ac0b0725c6fa 677
lorevee 0:ac0b0725c6fa 678 case EVT_LE_CONN_UPDATE_COMPLETE:
lorevee 0:ac0b0725c6fa 679 {
lorevee 0:ac0b0725c6fa 680 evt_le_connection_update_complete *evt = (evt_le_connection_update_complete*)blue_evt->data;
lorevee 0:ac0b0725c6fa 681 PRINTF("EVT_LE_CONN_UPDATE_COMPLETE status=0x%x\r\n", evt->status);
lorevee 0:ac0b0725c6fa 682 }
lorevee 0:ac0b0725c6fa 683 break;
lorevee 0:ac0b0725c6fa 684
lorevee 0:ac0b0725c6fa 685 case EVT_BLUE_GAP_DEVICE_FOUND:
lorevee 0:ac0b0725c6fa 686 {
lorevee 0:ac0b0725c6fa 687 evt_gap_device_found *pr = (evt_gap_device_found*)blue_evt->data;
lorevee 0:ac0b0725c6fa 688 PRINTF("EVT_BLUE_GAP_DEVICE_FOUND evt_type=%d\n\r", pr->evt_type);
lorevee 0:ac0b0725c6fa 689
lorevee 0:ac0b0725c6fa 690 BlueNRGGap::getInstance().Discovery_CB(BlueNRGGap::DEVICE_FOUND,
lorevee 0:ac0b0725c6fa 691 pr->evt_type,
lorevee 0:ac0b0725c6fa 692 pr->bdaddr_type,
lorevee 0:ac0b0725c6fa 693 pr->bdaddr,
lorevee 0:ac0b0725c6fa 694 &pr->data_length,
lorevee 0:ac0b0725c6fa 695 &pr->data_RSSI[0],
lorevee 0:ac0b0725c6fa 696 &pr->data_RSSI[pr->data_length]);
lorevee 0:ac0b0725c6fa 697 }
lorevee 0:ac0b0725c6fa 698 break;
lorevee 0:ac0b0725c6fa 699
lorevee 0:ac0b0725c6fa 700 case EVT_BLUE_GAP_PROCEDURE_COMPLETE:
lorevee 0:ac0b0725c6fa 701 {
lorevee 0:ac0b0725c6fa 702 evt_gap_procedure_complete *pr = (evt_gap_procedure_complete*)blue_evt->data;
lorevee 0:ac0b0725c6fa 703 //PRINTF("EVT_BLUE_GAP_PROCEDURE_COMPLETE (code=0x%02X)\n\r", pr->procedure_code);
lorevee 0:ac0b0725c6fa 704
lorevee 0:ac0b0725c6fa 705 switch(pr->procedure_code) {
lorevee 0:ac0b0725c6fa 706 case GAP_OBSERVATION_PROC_IDB05A1:
lorevee 0:ac0b0725c6fa 707
lorevee 0:ac0b0725c6fa 708 BlueNRGGap::getInstance().Discovery_CB(BlueNRGGap::DISCOVERY_COMPLETE, 0, 0, NULL, NULL, NULL, NULL);
lorevee 0:ac0b0725c6fa 709 break;
lorevee 0:ac0b0725c6fa 710 }
lorevee 0:ac0b0725c6fa 711 }
lorevee 0:ac0b0725c6fa 712 break;
lorevee 0:ac0b0725c6fa 713 }
lorevee 0:ac0b0725c6fa 714 }
lorevee 0:ac0b0725c6fa 715 break;
lorevee 0:ac0b0725c6fa 716 }
lorevee 0:ac0b0725c6fa 717 return ;
lorevee 0:ac0b0725c6fa 718 }
lorevee 0:ac0b0725c6fa 719
lorevee 0:ac0b0725c6fa 720
lorevee 0:ac0b0725c6fa 721 #ifdef __cplusplus
lorevee 0:ac0b0725c6fa 722 }
lorevee 0:ac0b0725c6fa 723 #endif