Bluetooth: Move mgmt event sending out from hci_add_link_key()
authorJohan Hedberg <johan.hedberg@intel.com>
Tue, 24 Jun 2014 10:15:49 +0000 (13:15 +0300)
committerMarcel Holtmann <marcel@holtmann.org>
Thu, 3 Jul 2014 15:42:45 +0000 (17:42 +0200)
There are two callers of hci_add_link_key(). The first one is the HCI
Link Key Notification event and the second one the mgmt code that
receives a list of link keys from user space. Previously we've had the
hci_add_link_key() function being responsible for also emitting a mgmt
signal but for the latter use case this should not happen. Because of
this a rather awkward new_key paramter has been passed to the function.

This patch moves the mgmt event sending out from the hci_add_link_key()
function, thereby making the code a bit more understandable.

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

index 7f81791a865d091c9f5575fafbd44bb05655aec8..888911d205dc9e865d88e5ea6e0feb445cc571ce 100644 (file)
@@ -860,8 +860,8 @@ void hci_uuids_clear(struct hci_dev *hdev);
 void hci_link_keys_clear(struct hci_dev *hdev);
 struct link_key *hci_find_link_key(struct hci_dev *hdev, bdaddr_t *bdaddr);
 struct link_key *hci_add_link_key(struct hci_dev *hdev, struct hci_conn *conn,
-                                 int new_key, bdaddr_t *bdaddr, u8 *val,
-                                 u8 type, u8 pin_len);
+                                 bdaddr_t *bdaddr, u8 *val, u8 type,
+                                 u8 pin_len, bool *persistent);
 struct smp_ltk *hci_find_ltk(struct hci_dev *hdev, __le16 ediv, __le64 rand,
                             bool master);
 struct smp_ltk *hci_add_ltk(struct hci_dev *hdev, bdaddr_t *bdaddr,
index ee42788aed2c968baee8555ee21cf6682a3cf1f4..159783e746c07b86ff7e3dcb370f13ec91e861e9 100644 (file)
@@ -3002,12 +3002,11 @@ struct smp_irk *hci_find_irk_by_addr(struct hci_dev *hdev, bdaddr_t *bdaddr,
 }
 
 struct link_key *hci_add_link_key(struct hci_dev *hdev, struct hci_conn *conn,
-                                 int new_key, bdaddr_t *bdaddr, u8 *val,
-                                 u8 type, u8 pin_len)
+                                 bdaddr_t *bdaddr, u8 *val, u8 type,
+                                 u8 pin_len, bool *persistent)
 {
        struct link_key *key, *old_key;
        u8 old_key_type;
-       bool persistent;
 
        old_key = hci_find_link_key(hdev, bdaddr);
        if (old_key) {
@@ -3042,15 +3041,9 @@ struct link_key *hci_add_link_key(struct hci_dev *hdev, struct hci_conn *conn,
        else
                key->type = type;
 
-       if (!new_key)
-               return key;
-
-       persistent = hci_persistent_key(hdev, conn, type, old_key_type);
-
-       mgmt_new_link_key(hdev, key, persistent);
-
-       if (conn)
-               conn->flush_key = !persistent;
+       if (persistent)
+               *persistent = hci_persistent_key(hdev, conn, type,
+                                                old_key_type);
 
        return key;
 }
index e1e1ecb4db10fb80dd16804b325612903fa75877..47bd48a597bddbc3be56a9ad93905fd5006408a7 100644 (file)
@@ -3111,6 +3111,8 @@ static void hci_link_key_notify_evt(struct hci_dev *hdev, struct sk_buff *skb)
 {
        struct hci_ev_link_key_notify *ev = (void *) skb->data;
        struct hci_conn *conn;
+       struct link_key *key;
+       bool persistent;
        u8 pin_len = 0;
 
        BT_DBG("%s", hdev->name);
@@ -3129,10 +3131,20 @@ static void hci_link_key_notify_evt(struct hci_dev *hdev, struct sk_buff *skb)
                hci_conn_drop(conn);
        }
 
-       if (test_bit(HCI_MGMT, &hdev->dev_flags))
-               hci_add_link_key(hdev, conn, 1, &ev->bdaddr, ev->link_key,
-                                ev->key_type, pin_len);
+       if (!test_bit(HCI_MGMT, &hdev->dev_flags))
+               goto unlock;
+
+       key = hci_add_link_key(hdev, conn, &ev->bdaddr, ev->link_key,
+                               ev->key_type, pin_len, &persistent);
+       if (!key)
+               goto unlock;
+
+       mgmt_new_link_key(hdev, key, persistent);
 
+       if (conn)
+               conn->flush_key = !persistent;
+
+unlock:
        hci_dev_unlock(hdev);
 }
 
index e1651c3fc676c8e5d39cec81800a1d14c5b04811..bb5b041912538cc01b5c430add79a947f472d4d2 100644 (file)
@@ -2424,8 +2424,8 @@ static int load_link_keys(struct sock *sk, struct hci_dev *hdev, void *data,
        for (i = 0; i < key_count; i++) {
                struct mgmt_link_key_info *key = &cp->keys[i];
 
-               hci_add_link_key(hdev, NULL, 0, &key->addr.bdaddr, key->val,
-                                key->type, key->pin_len);
+               hci_add_link_key(hdev, NULL, &key->addr.bdaddr, key->val,
+                                key->type, key->pin_len, NULL);
        }
 
        cmd_complete(sk, hdev->id, MGMT_OP_LOAD_LINK_KEYS, 0, NULL, 0);