Bluetooth: Clear HCI_RAW flag when controller becomes configured
authorMarcel Holtmann <marcel@holtmann.org>
Sun, 6 Jul 2014 10:11:16 +0000 (12:11 +0200)
committerJohan Hedberg <johan.hedberg@intel.com>
Sun, 6 Jul 2014 10:42:31 +0000 (13:42 +0300)
When an unconfigured controllers reaches the configured state, it is
important to change the HCI_RAW flag. It indicates to userspace that
the controller is fully operational.

External configuration allows to bring the controller back into an
unconfigured state. In that case make sure HCI_RAW flag is set again.

Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
net/bluetooth/hci_core.c
net/bluetooth/mgmt.c

index c96b96c..b1d423e 100644 (file)
@@ -2887,6 +2887,12 @@ static void hci_power_on(struct work_struct *work)
                 */
                mgmt_index_added(hdev);
        } else if (test_and_clear_bit(HCI_CONFIG, &hdev->dev_flags)) {
+               /* When the controller is now configured, then it
+                * is important to clear the HCI_RAW flag.
+                */
+               if (!test_bit(HCI_UNCONFIGURED, &hdev->dev_flags))
+                       clear_bit(HCI_RAW, &hdev->flags);
+
                /* Powering on the controller with HCI_CONFIG set only
                 * happens with the transition from unconfigured to
                 * configured. This will send the Index Added event.
index 8275316..e253f8e 100644 (file)
@@ -5451,6 +5451,7 @@ static int set_external_config(struct sock *sk, struct hci_dev *hdev,
 
                        queue_work(hdev->req_workqueue, &hdev->power_on);
                } else {
+                       set_bit(HCI_RAW, &hdev->flags);
                        mgmt_index_added(hdev);
                }
        }