Bluetooth: Use helper function for re-enabling advertising
authorMarcel Holtmann <marcel@holtmann.org>
Sun, 6 Oct 2013 11:08:14 +0000 (04:08 -0700)
committerJohan Hedberg <johan.hedberg@intel.com>
Sun, 6 Oct 2013 13:00:07 +0000 (15:00 +0200)
When the all LE connections have been disconneted, then it is up to
the host to re-enable advertising at that point. To ensure that the
correct advertising parameters are used, force the usage of the
common helper to enable advertising.

The change just moves the manual enabling of advertising from the
event handler into the management core so that the helper can
be actually shared.

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

index 82c3974512615216c44fc4155bc4280f6e815d6a..869f6ad602d1b089aae998a9bf52d28ba263688b 100644 (file)
@@ -1151,6 +1151,7 @@ int mgmt_device_blocked(struct hci_dev *hdev, bdaddr_t *bdaddr, u8 type);
 int mgmt_device_unblocked(struct hci_dev *hdev, bdaddr_t *bdaddr, u8 type);
 bool mgmt_valid_hdev(struct hci_dev *hdev);
 int mgmt_new_ltk(struct hci_dev *hdev, struct smp_ltk *key, u8 persistent);
+void mgmt_reenable_advertising(struct hci_dev *hdev);
 
 /* HCI info for socket */
 #define hci_pi(sk) ((struct hci_pinfo *) sk)
index 6eaef6ed95223afe867699b3946875f16b011753..224210ce82fcb4f7602fbf24419a67298ed88b20 100644 (file)
@@ -1796,40 +1796,6 @@ static u8 hci_to_mgmt_reason(u8 err)
        }
 }
 
-static void adv_enable_complete(struct hci_dev *hdev, u8 status)
-{
-       BT_DBG("%s status %u", hdev->name, status);
-
-       /* Clear the advertising mgmt setting if we failed to re-enable it */
-       if (status) {
-               clear_bit(HCI_ADVERTISING, &hdev->dev_flags);
-               mgmt_new_settings(hdev);
-       }
-}
-
-static void reenable_advertising(struct hci_dev *hdev)
-{
-       struct hci_request req;
-       u8 enable = 0x01;
-
-       if (hdev->conn_hash.le_num)
-               return;
-
-       if (!test_bit(HCI_ADVERTISING, &hdev->dev_flags))
-               return;
-
-       hci_req_init(&req, hdev);
-       hci_req_add(&req, HCI_OP_LE_SET_ADV_ENABLE, sizeof(enable), &enable);
-
-       /* If this fails we have no option but to let user space know
-        * that we've disabled advertising.
-        */
-       if (hci_req_run(&req, adv_enable_complete) < 0) {
-               clear_bit(HCI_ADVERTISING, &hdev->dev_flags);
-               mgmt_new_settings(hdev);
-       }
-}
-
 static void hci_disconn_complete_evt(struct hci_dev *hdev, struct sk_buff *skb)
 {
        struct hci_ev_disconn_complete *ev = (void *) skb->data;
@@ -1878,7 +1844,7 @@ static void hci_disconn_complete_evt(struct hci_dev *hdev, struct sk_buff *skb)
                 * is timed out due to Directed Advertising."
                 */
                if (type == LE_LINK)
-                       reenable_advertising(hdev);
+                       mgmt_reenable_advertising(hdev);
        }
 
 unlock:
index b78a0eefe03e95d0bbca141ede7426abac12a736..381faf6001951df08859af5738bfa9b1d63a4266 100644 (file)
@@ -4660,3 +4660,36 @@ int mgmt_device_unblocked(struct hci_dev *hdev, bdaddr_t *bdaddr, u8 type)
        return mgmt_event(MGMT_EV_DEVICE_UNBLOCKED, hdev, &ev, sizeof(ev),
                          cmd ? cmd->sk : NULL);
 }
+
+static void adv_enable_complete(struct hci_dev *hdev, u8 status)
+{
+       BT_DBG("%s status %u", hdev->name, status);
+
+       /* Clear the advertising mgmt setting if we failed to re-enable it */
+       if (status) {
+               clear_bit(HCI_ADVERTISING, &hdev->dev_flags);
+               mgmt_new_settings(hdev);
+       }
+}
+
+void mgmt_reenable_advertising(struct hci_dev *hdev)
+{
+       struct hci_request req;
+
+       if (hdev->conn_hash.le_num)
+               return;
+
+       if (!test_bit(HCI_ADVERTISING, &hdev->dev_flags))
+               return;
+
+       hci_req_init(&req, hdev);
+       enable_advertising(&req);
+
+       /* If this fails we have no option but to let user space know
+        * that we've disabled advertising.
+        */
+       if (hci_req_run(&req, adv_enable_complete) < 0) {
+               clear_bit(HCI_ADVERTISING, &hdev->dev_flags);
+               mgmt_new_settings(hdev);
+       }
+}