system/bt
修订版 | 4d57cc3df9d3330b55f2ee50fd5b5250e10d3b1c (tree) |
---|---|
时间 | 2019-06-11 08:41:59 |
作者 | Jakub Pawlowski <jpawlowski@goog...> |
Commiter | Nikoli Cartagena |
DO NOT MERGE Fix for Bluetooth connection being dropped after HCI Read Encryption Key Size
If remote device stop the encryption before we call "Read Encryption Key Size",
we might receive Insufficient Security, which means that link is no longer
encrypted.
In such cases we should stay connected, rather than disconnecting the
link.
Test: Connect to device that stop encryption right after encryption is
complete, i.e. to change roles.
Bug: 124301137
Bug: 132626699
Change-Id: Iab0fd9f357d18a6b048b971d0393fbb47fd4d793
Merged-In: Iab0fd9f357d18a6b048b971d0393fbb47fd4d793
(cherry picked from commit c5aa5feebf558df160772fefaf271a6f3251e261)
@@ -607,6 +607,15 @@ bool read_key_send_from_key_refresh = false; | ||
607 | 607 | |
608 | 608 | static void read_encryption_key_size_complete_after_key_refresh( |
609 | 609 | uint8_t status, uint16_t handle, uint8_t key_size) { |
610 | + if (status == HCI_ERR_INSUFFCIENT_SECURITY) { | |
611 | + /* If remote device stop the encryption before we call "Read Encryption Key | |
612 | + * Size", we might receive Insufficient Security, which means that link is | |
613 | + * no longer encrypted. */ | |
614 | + HCI_TRACE_WARNING("%s encryption stopped on link: 0x%02x", __func__, | |
615 | + handle); | |
616 | + return; | |
617 | + } | |
618 | + | |
610 | 619 | if (status != HCI_SUCCESS) { |
611 | 620 | HCI_TRACE_WARNING("%s: disconnecting, status: 0x%02x", __func__, status); |
612 | 621 | btsnd_hcic_disconnect(handle, HCI_ERR_PEER_USER); |
@@ -629,6 +638,15 @@ static void read_encryption_key_size_complete_after_key_refresh( | ||
629 | 638 | |
630 | 639 | static void read_encryption_key_size_complete_after_encryption_change( |
631 | 640 | uint8_t status, uint16_t handle, uint8_t key_size) { |
641 | + if (status == HCI_ERR_INSUFFCIENT_SECURITY) { | |
642 | + /* If remote device stop the encryption before we call "Read Encryption Key | |
643 | + * Size", we might receive Insufficient Security, which means that link is | |
644 | + * no longer encrypted. */ | |
645 | + HCI_TRACE_WARNING("%s encryption stopped on link: 0x%02x", __func__, | |
646 | + handle); | |
647 | + return; | |
648 | + } | |
649 | + | |
632 | 650 | if (status != HCI_SUCCESS) { |
633 | 651 | HCI_TRACE_WARNING("%s: disconnecting, status: 0x%02x", __func__, status); |
634 | 652 | btsnd_hcic_disconnect(handle, HCI_ERR_PEER_USER); |