mirror of https://gitee.com/openkylin/linux.git
Bluetooth: mgmt_stop_discovery_failed()
This patches creates mgmt_stop_discovery_failed() which removes pending MGMT_OP_STOP_DISCOVERY commands and sends proper command status events. This patch also fixes the MGMT_OP_STOP_DISCOVERY command leak in case cancel inquiry fails. Signed-off-by: Andre Guedes <andre.guedes@openbossa.org> Acked-by: Marcel Holtmann <marcel@holtmann.org> Signed-off-by: Gustavo F. Padovan <padovan@profusion.mobi>
This commit is contained in:
parent
7a13510902
commit
e6d465cb48
|
@ -941,6 +941,7 @@ int mgmt_device_found(struct hci_dev *hdev, bdaddr_t *bdaddr, u8 link_type,
|
||||||
u8 addr_type, u8 *dev_class, s8 rssi, u8 *eir);
|
u8 addr_type, u8 *dev_class, s8 rssi, u8 *eir);
|
||||||
int mgmt_remote_name(struct hci_dev *hdev, bdaddr_t *bdaddr, u8 *name);
|
int mgmt_remote_name(struct hci_dev *hdev, bdaddr_t *bdaddr, u8 *name);
|
||||||
int mgmt_start_discovery_failed(struct hci_dev *hdev, u8 status);
|
int mgmt_start_discovery_failed(struct hci_dev *hdev, u8 status);
|
||||||
|
int mgmt_stop_discovery_failed(struct hci_dev *hdev, u8 status);
|
||||||
int mgmt_discovering(struct hci_dev *hdev, u8 discovering);
|
int mgmt_discovering(struct hci_dev *hdev, u8 discovering);
|
||||||
int mgmt_device_blocked(struct hci_dev *hdev, bdaddr_t *bdaddr);
|
int mgmt_device_blocked(struct hci_dev *hdev, bdaddr_t *bdaddr);
|
||||||
int mgmt_device_unblocked(struct hci_dev *hdev, bdaddr_t *bdaddr);
|
int mgmt_device_unblocked(struct hci_dev *hdev, bdaddr_t *bdaddr);
|
||||||
|
|
|
@ -55,8 +55,12 @@ static void hci_cc_inquiry_cancel(struct hci_dev *hdev, struct sk_buff *skb)
|
||||||
|
|
||||||
BT_DBG("%s status 0x%x", hdev->name, status);
|
BT_DBG("%s status 0x%x", hdev->name, status);
|
||||||
|
|
||||||
if (status)
|
if (status) {
|
||||||
|
hci_dev_lock(hdev);
|
||||||
|
mgmt_stop_discovery_failed(hdev, status);
|
||||||
|
hci_dev_unlock(hdev);
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
clear_bit(HCI_INQUIRY, &hdev->flags);
|
clear_bit(HCI_INQUIRY, &hdev->flags);
|
||||||
|
|
||||||
|
|
|
@ -2443,6 +2443,21 @@ int mgmt_start_discovery_failed(struct hci_dev *hdev, u8 status)
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int mgmt_stop_discovery_failed(struct hci_dev *hdev, u8 status)
|
||||||
|
{
|
||||||
|
struct pending_cmd *cmd;
|
||||||
|
int err;
|
||||||
|
|
||||||
|
cmd = mgmt_pending_find(MGMT_OP_STOP_DISCOVERY, hdev);
|
||||||
|
if (!cmd)
|
||||||
|
return -ENOENT;
|
||||||
|
|
||||||
|
err = cmd_status(cmd->sk, hdev->id, cmd->opcode, status);
|
||||||
|
mgmt_pending_remove(cmd);
|
||||||
|
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
int mgmt_discovering(struct hci_dev *hdev, u8 discovering)
|
int mgmt_discovering(struct hci_dev *hdev, u8 discovering)
|
||||||
{
|
{
|
||||||
struct pending_cmd *cmd;
|
struct pending_cmd *cmd;
|
||||||
|
|
Loading…
Reference in New Issue