Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit a0cdf960 authored by Marcel Holtmann's avatar Marcel Holtmann Committed by Johan Hedberg
Browse files

Bluetooth: Restrict disabling of HS when controller is powered off



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: default avatarMarcel Holtmann <marcel@holtmann.org>
Signed-off-by: default avatarJohan Hedberg <johan.hedberg@intel.com>
parent 0663ca2a
Loading
Loading
Loading
Loading
+9 −2
Original line number Original line Diff line number Diff line
@@ -1353,10 +1353,17 @@ static int set_hs(struct sock *sk, struct hci_dev *hdev, void *data, u16 len)


	hci_dev_lock(hdev);
	hci_dev_lock(hdev);


	if (cp->val)
	if (cp->val) {
		changed = !test_and_set_bit(HCI_HS_ENABLED, &hdev->dev_flags);
		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);
		changed = test_and_clear_bit(HCI_HS_ENABLED, &hdev->dev_flags);
	}


	err = send_settings_rsp(sk, MGMT_OP_SET_HS, hdev);
	err = send_settings_rsp(sk, MGMT_OP_SET_HS, hdev);
	if (err < 0)
	if (err < 0)