diff options
author | Johan Hedberg <johan.hedberg@intel.com> | 2013-03-15 18:06:59 -0400 |
---|---|---|
committer | Gustavo Padovan <gustavo.padovan@collabora.co.uk> | 2013-03-18 13:02:03 -0400 |
commit | 35b973c9dd6d518491b251ac777d767d7820aa37 (patch) | |
tree | c2142780fc8b1cd371953682aceabf5ede2ff555 /net/bluetooth | |
parent | f9f85279fd3a3284023231c7f0796f98c417e7cd (diff) |
Bluetooth: Fix clearing flags on power off before notifying mgmt
When powering off the device the hdev->flags and hdev->dev_flags need to
be cleared before calling mgmt_powered(). If this is not done the
resulting events sent to user space may contain incorrect values.
Note that the HCI_AUTO_OFF flag accessed right after this is part of the
persistent flags, so it's unchanged by the hdev->dev_flags reset.
Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
Acked-by: Marcel Holtmann <marcel@holtmann.org>
Signed-off-by: Gustavo Padovan <gustavo.padovan@collabora.co.uk>
Diffstat (limited to 'net/bluetooth')
-rw-r--r-- | net/bluetooth/hci_core.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c index 059bbae534d1..9e87a91562a6 100644 --- a/net/bluetooth/hci_core.c +++ b/net/bluetooth/hci_core.c | |||
@@ -1130,6 +1130,10 @@ static int hci_dev_do_close(struct hci_dev *hdev) | |||
1130 | * and no tasks are scheduled. */ | 1130 | * and no tasks are scheduled. */ |
1131 | hdev->close(hdev); | 1131 | hdev->close(hdev); |
1132 | 1132 | ||
1133 | /* Clear flags */ | ||
1134 | hdev->flags = 0; | ||
1135 | hdev->dev_flags &= ~HCI_PERSISTENT_MASK; | ||
1136 | |||
1133 | if (!test_and_clear_bit(HCI_AUTO_OFF, &hdev->dev_flags) && | 1137 | if (!test_and_clear_bit(HCI_AUTO_OFF, &hdev->dev_flags) && |
1134 | mgmt_valid_hdev(hdev)) { | 1138 | mgmt_valid_hdev(hdev)) { |
1135 | hci_dev_lock(hdev); | 1139 | hci_dev_lock(hdev); |
@@ -1137,10 +1141,6 @@ static int hci_dev_do_close(struct hci_dev *hdev) | |||
1137 | hci_dev_unlock(hdev); | 1141 | hci_dev_unlock(hdev); |
1138 | } | 1142 | } |
1139 | 1143 | ||
1140 | /* Clear flags */ | ||
1141 | hdev->flags = 0; | ||
1142 | hdev->dev_flags &= ~HCI_PERSISTENT_MASK; | ||
1143 | |||
1144 | /* Controller radio is available but is currently powered down */ | 1144 | /* Controller radio is available but is currently powered down */ |
1145 | hdev->amp_status = 0; | 1145 | hdev->amp_status = 0; |
1146 | 1146 | ||