This patch merges the LE-only and interleaved discovery type cases. Since hci_le_scan helper uses the HCI request framework, those cases are pretty much the same now. Signed-off-by: Andre Guedes <andre.guedes@xxxxxxxxxxxxx> --- net/bluetooth/mgmt.c | 18 +++--------------- 1 file changed, 3 insertions(+), 15 deletions(-) diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c index b444b19..7a4f8dd 100644 --- a/net/bluetooth/mgmt.c +++ b/net/bluetooth/mgmt.c @@ -2501,6 +2501,7 @@ static int start_discovery(struct sock *sk, struct hci_dev *hdev, break; case DISCOV_TYPE_LE: + case DISCOV_TYPE_INTERLEAVED: if (!lmp_host_le_capable(hdev)) { err = cmd_status(sk, hdev->id, MGMT_OP_START_DISCOVERY, MGMT_STATUS_NOT_SUPPORTED); @@ -2508,21 +2509,8 @@ static int start_discovery(struct sock *sk, struct hci_dev *hdev, goto failed; } - hci_req_init(&req, hdev); - - err = hci_le_scan(&req, LE_SCAN_TYPE, LE_SCAN_INT, - LE_SCAN_WIN); - if (err < 0) { - mgmt_pending_remove(cmd); - hci_req_cleanup(&req); - goto failed; - } - - err = hci_req_run(&req, enable_le_scan_complete); - break; - - case DISCOV_TYPE_INTERLEAVED: - if (!lmp_host_le_capable(hdev) || !lmp_bredr_capable(hdev)) { + if (hdev->discovery.type == DISCOV_TYPE_INTERLEAVED && + !lmp_bredr_capable(hdev)) { err = cmd_status(sk, hdev->id, MGMT_OP_START_DISCOVERY, MGMT_STATUS_NOT_SUPPORTED); mgmt_pending_remove(cmd); -- 1.8.1.2 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html