Bluetooth: Add missing error handling for Set Connectable
If the HCI commands related to the Set Connectable command fail we will get a non-zero status in the request completion callback. In such a case we must respond with the appropriate command status message to user space. Signed-off-by: Johan Hedberg <johan.hedberg@intel.com> Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
This commit is contained in:
parent
d7b856f938
commit
37438c1f7f
|
@ -1086,6 +1086,12 @@ static void set_connectable_complete(struct hci_dev *hdev, u8 status)
|
||||||
if (!cmd)
|
if (!cmd)
|
||||||
goto unlock;
|
goto unlock;
|
||||||
|
|
||||||
|
if (status) {
|
||||||
|
u8 mgmt_err = mgmt_status(status);
|
||||||
|
cmd_status(cmd->sk, cmd->index, cmd->opcode, mgmt_err);
|
||||||
|
goto remove_cmd;
|
||||||
|
}
|
||||||
|
|
||||||
cp = cmd->param;
|
cp = cmd->param;
|
||||||
if (cp->val)
|
if (cp->val)
|
||||||
changed = !test_and_set_bit(HCI_CONNECTABLE, &hdev->dev_flags);
|
changed = !test_and_set_bit(HCI_CONNECTABLE, &hdev->dev_flags);
|
||||||
|
@ -1097,6 +1103,7 @@ static void set_connectable_complete(struct hci_dev *hdev, u8 status)
|
||||||
if (changed)
|
if (changed)
|
||||||
new_settings(hdev, cmd->sk);
|
new_settings(hdev, cmd->sk);
|
||||||
|
|
||||||
|
remove_cmd:
|
||||||
mgmt_pending_remove(cmd);
|
mgmt_pending_remove(cmd);
|
||||||
|
|
||||||
unlock:
|
unlock:
|
||||||
|
|
Loading…
Reference in New Issue