summaryrefslogtreecommitdiffstats
path: root/net/bluetooth/hci_event.c
diff options
context:
space:
mode:
authorMarcel Holtmann <marcel@holtmann.org>2014-02-19 00:13:43 +0100
committerJohan Hedberg <johan.hedberg@intel.com>2014-02-19 05:09:41 +0100
commitedb4b46651c87f1579154298c41f9c1a753565a3 (patch)
treeb295cd1a0658021f46a5a9128a5e1fbd64325a9b /net/bluetooth/hci_event.c
parentBluetooth: Use connection address for reporting connection failures (diff)
downloadlinux-edb4b46651c87f1579154298c41f9c1a753565a3.tar.xz
linux-edb4b46651c87f1579154298c41f9c1a753565a3.zip
Bluetooth: Fix wrong identity address during connection failures
When the connection attempt fails, the address information are not provided in the HCI_LE_Connection_Complete event. So use the original information from the connection to reconstruct the identity address. This is important when a connection attempt has been made using the identity address, but the cached resolvable random address has changed in the meantime. The failure event needs to use the identity address and not the resolvable random address. Signed-off-by: Marcel Holtmann <marcel@holtmann.org> Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
Diffstat (limited to '')
-rw-r--r--net/bluetooth/hci_event.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c
index 22bfc5c17e7f..7228fa100b1f 100644
--- a/net/bluetooth/hci_event.c
+++ b/net/bluetooth/hci_event.c
@@ -3601,8 +3601,16 @@ static void hci_le_conn_complete_evt(struct hci_dev *hdev, struct sk_buff *skb)
}
}
- /* Track the connection based on the Identity Address from now on */
- irk = hci_get_irk(hdev, &ev->bdaddr, ev->bdaddr_type);
+ /* Lookup the identity address from the stored connection
+ * address and address type.
+ *
+ * When establishing connections to an identity address, the
+ * connection procedure will store the resolvable random
+ * address first. Now if it can be converted back into the
+ * identity address, start using the identity address from
+ * now on.
+ */
+ irk = hci_get_irk(hdev, &conn->dst, conn->dst_type);
if (irk) {
bacpy(&conn->dst, &irk->bdaddr);
conn->dst_type = irk->addr_type;