Bluetooth: Change interleaved discovery behavior
authorAndre Guedes <andre.guedes@openbossa.org>
Fri, 24 Feb 2012 14:41:04 +0000 (11:41 -0300)
committerJohan Hedberg <johan.hedberg@intel.com>
Wed, 29 Feb 2012 14:21:04 +0000 (16:21 +0200)
According to last discussion on IRC, if an interleaved discovery is
issued, but the device is not dual mode, we should return error
instead of performing a regular BR/EDR or LE-only discovery.

Signed-off-by: Andre Guedes <andre.guedes@openbossa.org>
Acked-by: Marcel Holtmann <marcel@holtmann.org>
Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
net/bluetooth/mgmt.c

index c4d3bc9c86b5a12c0eceb067f8da97599eae9624..b0c43fe435630c8e003b2b1554abbb373e24f8e9 100644 (file)
@@ -2540,29 +2540,6 @@ unlock:
        return err;
 }
 
-static int discovery(struct hci_dev *hdev)
-{
-       int err;
-
-       if (lmp_host_le_capable(hdev)) {
-               if (lmp_bredr_capable(hdev)) {
-                       err = hci_le_scan(hdev, LE_SCAN_TYPE,
-                                               LE_SCAN_INT, LE_SCAN_WIN,
-                                               LE_SCAN_TIMEOUT_BREDR_LE);
-               } else {
-                       hdev->discovery.type = DISCOV_TYPE_LE;
-                       err = hci_le_scan(hdev, LE_SCAN_TYPE,
-                                               LE_SCAN_INT, LE_SCAN_WIN,
-                                               LE_SCAN_TIMEOUT_LE_ONLY);
-               }
-       } else {
-               hdev->discovery.type = DISCOV_TYPE_BREDR;
-               err = hci_do_inquiry(hdev, INQUIRY_LEN_BREDR);
-       }
-
-       return err;
-}
-
 int mgmt_interleaved_discovery(struct hci_dev *hdev)
 {
        int err;
@@ -2632,7 +2609,11 @@ static int start_discovery(struct sock *sk, u16 index,
                break;
 
        case DISCOV_TYPE_INTERLEAVED:
-               err = discovery(hdev);
+               if (lmp_host_le_capable(hdev) && lmp_bredr_capable(hdev))
+                       err = hci_le_scan(hdev, LE_SCAN_TYPE, LE_SCAN_INT,
+                                       LE_SCAN_WIN, LE_SCAN_TIMEOUT_BREDR_LE);
+               else
+                       err = -ENOTSUPP;
                break;
 
        default: