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:
Johan Hedberg 2013-10-14 16:20:05 +03:00 committed by Marcel Holtmann
parent d7b856f938
commit 37438c1f7f
1 changed files with 7 additions and 0 deletions

View File

@ -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: