Bluetooth: Track the AES-CCM encryption status of LE and BR/EDR links
authorMarcel Holtmann <marcel@holtmann.org>
Sat, 1 Feb 2014 00:24:28 +0000 (16:24 -0800)
committerJohan Hedberg <johan.hedberg@intel.com>
Thu, 13 Feb 2014 07:51:42 +0000 (09:51 +0200)
When encryption for LE links has been enabled, it will always be use
AES-CCM encryption. In case of BR/EDR Secure Connections, the link
will also use AES-CCM encryption. In both cases track the AES-CCM
status in the connection flags.

Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
include/net/bluetooth/hci_core.h
net/bluetooth/hci_event.c

index 2e1d184bd8d3dd53475b063994e6bbb6a666f565..6854384b1f2591b5f935da2dd2d9a017a6955171 100644 (file)
@@ -448,6 +448,7 @@ enum {
        HCI_CONN_MGMT_CONNECTED,
        HCI_CONN_SSP_ENABLED,
        HCI_CONN_SC_ENABLED,
+       HCI_CONN_AES_CCM,
        HCI_CONN_POWER_SAVE,
        HCI_CONN_REMOTE_OOB,
        HCI_CONN_6LOWPAN,
index 62aea2edc231d18819879e562beab8e9905053bc..36c9a488ac56977555e234cb3136e18753a401ea 100644 (file)
@@ -1997,8 +1997,14 @@ static void hci_encrypt_change_evt(struct hci_dev *hdev, struct sk_buff *skb)
                        conn->link_mode |= HCI_LM_AUTH;
                        conn->link_mode |= HCI_LM_ENCRYPT;
                        conn->sec_level = conn->pending_sec_level;
-               } else
+
+                       if ((conn->type == ACL_LINK && ev->encrypt == 0x02) ||
+                           conn->type == LE_LINK)
+                               set_bit(HCI_CONN_AES_CCM, &conn->flags);
+               } else {
                        conn->link_mode &= ~HCI_LM_ENCRYPT;
+                       clear_bit(HCI_CONN_AES_CCM, &conn->flags);
+               }
        }
 
        clear_bit(HCI_CONN_ENCRYPT_PEND, &conn->flags);