Test for a BLE disconnect while reading

This commit is contained in:
root 2022-06-16 14:56:18 -05:00 committed by Dan Halbert
parent 515ea026ce
commit e8023f33a9
1 changed files with 8 additions and 1 deletions

View File

@ -185,7 +185,12 @@ STATIC bool _on_gattc_read_rsp_evt(ble_evt_t *ble_evt, void *param) {
} }
break; break;
} }
case BLE_GAP_EVT_DISCONNECTED: {
read->conn_handle = BLE_CONN_HANDLE_INVALID;
read->done = true;
return false;
break;
}
default: default:
// For debugging. // For debugging.
// mp_printf(&mp_plat_print, "Unhandled characteristic event: 0x%04x\n", ble_evt->header.evt_id); // mp_printf(&mp_plat_print, "Unhandled characteristic event: 0x%04x\n", ble_evt->header.evt_id);
@ -219,6 +224,8 @@ size_t common_hal_bleio_gattc_read(uint16_t handle, uint16_t conn_handle, uint8_
while (!read_info.done) { while (!read_info.done) {
RUN_BACKGROUND_TASKS; RUN_BACKGROUND_TASKS;
} }
// Test if we were disconnected while reading
common_hal_bleio_check_connected(read_info.conn_handle);
ble_drv_remove_event_handler(_on_gattc_read_rsp_evt, &read_info); ble_drv_remove_event_handler(_on_gattc_read_rsp_evt, &read_info);
check_gatt_status(read_info.status); check_gatt_status(read_info.status);