Bluetooth: Restrict disabling of HS when controller is powered off
authorMarcel Holtmann <marcel@holtmann.org>
Wed, 2 Oct 2013 07:27:02 +0000 (00:27 -0700)
committerJohan Hedberg <johan.hedberg@intel.com>
Wed, 2 Oct 2013 10:51:50 +0000 (13:51 +0300)
Disabling the high speed setting when the controller is powered on has
too many side effects that are not taken care of. And in general it
is not an useful operation anyway. So just make such a command fail
with a rejection error message.

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

index dcce0cf1d7ccada7bc1f0177c889ca4dac2f639d..4ac31695946b9f3e3eaf9539b82a318af9d5dfbb 100644 (file)
@@ -1353,10 +1353,17 @@ static int set_hs(struct sock *sk, struct hci_dev *hdev, void *data, u16 len)
 
        hci_dev_lock(hdev);
 
-       if (cp->val)
+       if (cp->val) {
                changed = !test_and_set_bit(HCI_HS_ENABLED, &hdev->dev_flags);
-       else
+       } else {
+               if (hdev_is_powered(hdev)) {
+                       err = cmd_status(sk, hdev->id, MGMT_OP_SET_HS,
+                                        MGMT_STATUS_REJECTED);
+                       goto unlock;
+               }
+
                changed = test_and_clear_bit(HCI_HS_ENABLED, &hdev->dev_flags);
+       }
 
        err = send_settings_rsp(sk, MGMT_OP_SET_HS, hdev);
        if (err < 0)