aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorJefferson Delfes <jefferson.delfes@openbossa.org>2012-09-18 13:36:54 -0400
committerGustavo Padovan <gustavo.padovan@collabora.co.uk>2012-09-27 17:08:01 -0400
commit36a75f1b3ecf94dcf140b9d3d2f7a03b7e258480 (patch)
tree3c99de6e81b10597c6e8203e76a0c5f695985111 /net
parent392f44d3e7894f6fe314b85b4a1611b7b1d98226 (diff)
Bluetooth: Force the process of unpair command if disconnect failed
The unpair process tries to disconnect any connection pending with remote. If there are some connection in connecting state, disconnect command will fail and unpair mgmt command will stay pending. That pending mgmt command can cause strange behavior like automatic unpair after a lost connection. Signed-off-by: Jefferson Delfes <jefferson.delfes@openbossa.org> Acked-by: Johan Hedberg <johan.hedberg@intel.com> Signed-off-by: Gustavo Padovan <gustavo.padovan@collabora.co.uk>
Diffstat (limited to 'net')
-rw-r--r--net/bluetooth/mgmt.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c
index 8934343be0ea..b127b88015c9 100644
--- a/net/bluetooth/mgmt.c
+++ b/net/bluetooth/mgmt.c
@@ -3109,6 +3109,9 @@ int mgmt_disconnect_failed(struct hci_dev *hdev, bdaddr_t *bdaddr,
3109 struct pending_cmd *cmd; 3109 struct pending_cmd *cmd;
3110 int err; 3110 int err;
3111 3111
3112 mgmt_pending_foreach(MGMT_OP_UNPAIR_DEVICE, hdev, unpair_device_rsp,
3113 hdev);
3114
3112 cmd = mgmt_pending_find(MGMT_OP_DISCONNECT, hdev); 3115 cmd = mgmt_pending_find(MGMT_OP_DISCONNECT, hdev);
3113 if (!cmd) 3116 if (!cmd)
3114 return -ENOENT; 3117 return -ENOENT;
@@ -3121,8 +3124,6 @@ int mgmt_disconnect_failed(struct hci_dev *hdev, bdaddr_t *bdaddr,
3121 3124
3122 mgmt_pending_remove(cmd); 3125 mgmt_pending_remove(cmd);
3123 3126
3124 mgmt_pending_foreach(MGMT_OP_UNPAIR_DEVICE, hdev, unpair_device_rsp,
3125 hdev);
3126 return err; 3127 return err;
3127} 3128}
3128 3129