|
@@ -752,7 +752,6 @@ static void hci_req_add_le_create_conn(struct hci_request *req,
|
|
|
struct hci_conn *conn,
|
|
|
bdaddr_t *direct_rpa)
|
|
|
{
|
|
|
- struct hci_cp_le_create_conn cp;
|
|
|
struct hci_dev *hdev = conn->hdev;
|
|
|
u8 own_addr_type;
|
|
|
|
|
@@ -775,25 +774,62 @@ static void hci_req_add_le_create_conn(struct hci_request *req,
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
- memset(&cp, 0, sizeof(cp));
|
|
|
+ if (use_ext_conn(hdev)) {
|
|
|
+ struct hci_cp_le_ext_create_conn *cp;
|
|
|
+ struct hci_cp_le_ext_conn_param *p;
|
|
|
+ /* As of now only LE 1M is supported */
|
|
|
+ u8 data[sizeof(*cp) + sizeof(*p) * 1];
|
|
|
|
|
|
- /* Set window to be the same value as the interval to enable
|
|
|
- * continuous scanning.
|
|
|
- */
|
|
|
- cp.scan_interval = cpu_to_le16(hdev->le_scan_interval);
|
|
|
- cp.scan_window = cp.scan_interval;
|
|
|
+ cp = (void *) data;
|
|
|
+ p = (void *) cp->data;
|
|
|
|
|
|
- bacpy(&cp.peer_addr, &conn->dst);
|
|
|
- cp.peer_addr_type = conn->dst_type;
|
|
|
- cp.own_address_type = own_addr_type;
|
|
|
- cp.conn_interval_min = cpu_to_le16(conn->le_conn_min_interval);
|
|
|
- cp.conn_interval_max = cpu_to_le16(conn->le_conn_max_interval);
|
|
|
- cp.conn_latency = cpu_to_le16(conn->le_conn_latency);
|
|
|
- cp.supervision_timeout = cpu_to_le16(conn->le_supv_timeout);
|
|
|
- cp.min_ce_len = cpu_to_le16(0x0000);
|
|
|
- cp.max_ce_len = cpu_to_le16(0x0000);
|
|
|
-
|
|
|
- hci_req_add(req, HCI_OP_LE_CREATE_CONN, sizeof(cp), &cp);
|
|
|
+ memset(cp, 0, sizeof(*cp));
|
|
|
+
|
|
|
+ bacpy(&cp->peer_addr, &conn->dst);
|
|
|
+ cp->peer_addr_type = conn->dst_type;
|
|
|
+ cp->own_addr_type = own_addr_type;
|
|
|
+ cp->phys = LE_SCAN_PHY_1M;
|
|
|
+
|
|
|
+ memset(p, 0, sizeof(*p));
|
|
|
+
|
|
|
+ /* Set window to be the same value as the interval to enable
|
|
|
+ * continuous scanning.
|
|
|
+ */
|
|
|
+
|
|
|
+ p->scan_interval = cpu_to_le16(hdev->le_scan_interval);
|
|
|
+ p->scan_window = p->scan_interval;
|
|
|
+ p->conn_interval_min = cpu_to_le16(conn->le_conn_min_interval);
|
|
|
+ p->conn_interval_max = cpu_to_le16(conn->le_conn_max_interval);
|
|
|
+ p->conn_latency = cpu_to_le16(conn->le_conn_latency);
|
|
|
+ p->supervision_timeout = cpu_to_le16(conn->le_supv_timeout);
|
|
|
+ p->min_ce_len = cpu_to_le16(0x0000);
|
|
|
+ p->max_ce_len = cpu_to_le16(0x0000);
|
|
|
+
|
|
|
+ hci_req_add(req, HCI_OP_LE_EXT_CREATE_CONN, sizeof(data), data);
|
|
|
+
|
|
|
+ } else {
|
|
|
+ struct hci_cp_le_create_conn cp;
|
|
|
+
|
|
|
+ memset(&cp, 0, sizeof(cp));
|
|
|
+
|
|
|
+ /* Set window to be the same value as the interval to enable
|
|
|
+ * continuous scanning.
|
|
|
+ */
|
|
|
+ cp.scan_interval = cpu_to_le16(hdev->le_scan_interval);
|
|
|
+ cp.scan_window = cp.scan_interval;
|
|
|
+
|
|
|
+ bacpy(&cp.peer_addr, &conn->dst);
|
|
|
+ cp.peer_addr_type = conn->dst_type;
|
|
|
+ cp.own_address_type = own_addr_type;
|
|
|
+ cp.conn_interval_min = cpu_to_le16(conn->le_conn_min_interval);
|
|
|
+ cp.conn_interval_max = cpu_to_le16(conn->le_conn_max_interval);
|
|
|
+ cp.conn_latency = cpu_to_le16(conn->le_conn_latency);
|
|
|
+ cp.supervision_timeout = cpu_to_le16(conn->le_supv_timeout);
|
|
|
+ cp.min_ce_len = cpu_to_le16(0x0000);
|
|
|
+ cp.max_ce_len = cpu_to_le16(0x0000);
|
|
|
+
|
|
|
+ hci_req_add(req, HCI_OP_LE_CREATE_CONN, sizeof(cp), &cp);
|
|
|
+ }
|
|
|
|
|
|
conn->state = BT_CONNECT;
|
|
|
clear_bit(HCI_CONN_SCANNING, &conn->flags);
|