Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Fork of nRF51822 by
Diff: btle/btle_gattc.cpp
- Revision:
- 212:f2316b17d8be
- Parent:
- 211:bf81b20ede23
- Child:
- 213:146636a106b1
diff -r bf81b20ede23 -r f2316b17d8be btle/btle_gattc.cpp
--- a/btle/btle_gattc.cpp Fri Jun 19 15:55:17 2015 +0100
+++ b/btle/btle_gattc.cpp Fri Jun 19 15:55:18 2015 +0100
@@ -144,8 +144,56 @@
case BLE_GATTC_EVT_CHAR_DISC_RSP: {
switch (p_ble_evt->evt.gattc_evt.gatt_status) {
+ case BLE_GATT_STATUS_SUCCESS: {
+ // printf("count of characteristics: %u\r\n", p_ble_evt->evt.gattc_evt.params.char_disc_rsp.count);
+ discoveryStatus.currCharInd = 0;
+ discoveryStatus.charCount = p_ble_evt->evt.gattc_evt.params.char_disc_rsp.count;
+
+ unsigned charIndex = 0;
+ for (; charIndex < discoveryStatus.charCount; charIndex++) {
+ // printf("<service index %u>[%u %u]\r\n", discoveryStatus.currSrvInd,
+ // discoveryStatus.services[discoveryStatus.currSrvInd].startHandle, discoveryStatus.services[discoveryStatus.currSrvInd].endHandle);
+ printf("%x [%u]\r\n", p_ble_evt->evt.gattc_evt.params.char_disc_rsp.chars[charIndex].uuid.uuid,
+ p_ble_evt->evt.gattc_evt.params.char_disc_rsp.chars[charIndex].handle_value);
+ // discoveryStatus.characteristics[charIndex].
+ // setup(p_ble_evt->evt.gattc_evt.params.prim_srvc_disc_rsp.services[charIndex].uuid.uuid,
+ // p_ble_evt->evt.gattc_evt.params.prim_srvc_disc_rsp.services[charIndex].handle_range.start_handle,
+ // p_ble_evt->evt.gattc_evt.params.prim_srvc_disc_rsp.services[charIndex].handle_range.end_handle);
+ }
+
+ Gap::Handle_t startHandle = p_ble_evt->evt.gattc_evt.params.char_disc_rsp.chars[charIndex - 1].handle_value + 1;
+ Gap::Handle_t endHandle = discoveryStatus.services[discoveryStatus.currSrvInd].endHandle;
+
+ if (startHandle < endHandle) {
+ ble_gattc_handle_range_t handleRange = {
+ .start_handle = startHandle,
+ .end_handle = endHandle
+ };
+ printf("restarting char discovery from %u to %u\r\n", handleRange.start_handle, handleRange.end_handle);
+ printf("char discovery returned %u\r\n", sd_ble_gattc_characteristics_discover(p_ble_evt->evt.gattc_evt.conn_handle, &handleRange));
+ break;
+ }
+ }
+
+ /* NOTE: fallthrough */
+
+ case BLE_GATT_STATUS_ATTERR_ATTRIBUTE_NOT_FOUND: {
+ discoveryStatus.characteristicDiscoveryInProgress = false;
+ discoveryStatus.serviceDiscoveryInProgress = true;
+ discoveryStatus.currSrvInd++;
+ // if (discoveryStatus.currSrvInd < discoveryStatus.srvCount) {
+ // printf("end of characteristic discovery for this service; moving to service index %u [%u %u]\r\n",
+ // discoveryStatus.currSrvInd,
+ // discoveryStatus.services[discoveryStatus.currSrvInd].startHandle,
+ // discoveryStatus.services[discoveryStatus.currSrvInd].endHandle);
+ // } else {
+ // printf("end of characteristic discovery for this service\r\n");
+ // }
+ break;
+ }
+
default:
- printf("gatt failure status: %u\r\n", p_ble_evt->evt.gattc_evt.gatt_status);
+ printf("char response: gatt failure status: %u\r\n", p_ble_evt->evt.gattc_evt.gatt_status);
break;
}
break;
@@ -154,23 +202,18 @@
while (discoveryStatus.serviceDiscoveryInProgress && (discoveryStatus.currSrvInd < discoveryStatus.srvCount)) {
printf("%x [%u %u]\r\n",
- p_ble_evt->evt.gattc_evt.params.prim_srvc_disc_rsp.services[discoveryStatus.currSrvInd].uuid.uuid,
- p_ble_evt->evt.gattc_evt.params.prim_srvc_disc_rsp.services[discoveryStatus.currSrvInd].handle_range.start_handle,
- p_ble_evt->evt.gattc_evt.params.prim_srvc_disc_rsp.services[discoveryStatus.currSrvInd].handle_range.end_handle);
+ discoveryStatus.services[discoveryStatus.currSrvInd].uuid,
+ discoveryStatus.services[discoveryStatus.currSrvInd].startHandle,
+ discoveryStatus.services[discoveryStatus.currSrvInd].endHandle);
- // ble_gattc_handle_range_t handleRange = {
- // .start_handle = p_ble_evt->evt.gattc_evt.params.prim_srvc_disc_rsp.services[discoveryStatus.currSrvInd].handle_range.start_handle,
- // .end_handle = p_ble_evt->evt.gattc_evt.params.prim_srvc_disc_rsp.services[discoveryStatus.currSrvInd].handle_range.end_handle
- // };
- // printf("characteristics_discover returned %u\r\n",
- // sd_ble_gattc_characteristics_discover(p_ble_evt->evt.gattc_evt.conn_handle, &handleRange));
-
- discoveryStatus.currSrvInd++;
+ launchCharacteristicDiscovery(discoveryStatus.connHandle,
+ discoveryStatus.services[discoveryStatus.currSrvInd].startHandle,
+ discoveryStatus.services[discoveryStatus.currSrvInd].endHandle);
}
- if (discoveryStatus.serviceDiscoveryInProgress && (discoveryStatus.srvCount > 0)) {
+ if (discoveryStatus.serviceDiscoveryInProgress && (discoveryStatus.srvCount > 0) && (discoveryStatus.currSrvInd > 0)) {
+ Gap::Handle_t endHandle = discoveryStatus.services[discoveryStatus.currSrvInd - 1].endHandle;
+ memset(discoveryStatus.services, 0, sizeof(DiscoveredService) * BLE_DB_DISCOVERY_MAX_SRV);
printf("services discover returned %u\r\n",
- sd_ble_gattc_primary_services_discover(p_ble_evt->evt.gattc_evt.conn_handle,
- p_ble_evt->evt.gattc_evt.params.prim_srvc_disc_rsp.services[discoveryStatus.currSrvInd -1].handle_range.end_handle,
- NULL));
+ sd_ble_gattc_primary_services_discover(discoveryStatus.connHandle, endHandle, NULL));
}
}
\ No newline at end of file
