|
@@ -447,13 +447,22 @@ struct hci_conn *hci_connect(struct hci_dev *hdev, int type, bdaddr_t *dst, __u8
|
|
|
BT_DBG("%s dst %s", hdev->name, batostr(dst));
|
|
|
|
|
|
if (type == LE_LINK) {
|
|
|
+ struct adv_entry *entry;
|
|
|
+
|
|
|
le = hci_conn_hash_lookup_ba(hdev, LE_LINK, dst);
|
|
|
if (le)
|
|
|
return ERR_PTR(-EBUSY);
|
|
|
+
|
|
|
+ entry = hci_find_adv_entry(hdev, dst);
|
|
|
+ if (!entry)
|
|
|
+ return ERR_PTR(-EHOSTUNREACH);
|
|
|
+
|
|
|
le = hci_conn_add(hdev, LE_LINK, dst);
|
|
|
if (!le)
|
|
|
return ERR_PTR(-ENOMEM);
|
|
|
|
|
|
+ le->dst_type = entry->bdaddr_type;
|
|
|
+
|
|
|
hci_le_connect(le);
|
|
|
|
|
|
hci_conn_hold(le);
|