aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/net/bluetooth/hci_core.h1
-rw-r--r--net/bluetooth/hci_core.c17
-rw-r--r--net/bluetooth/mgmt.c5
3 files changed, 23 insertions, 0 deletions
diff --git a/include/net/bluetooth/hci_core.h b/include/net/bluetooth/hci_core.h
index cba4837dcaa5..e69c2b08c0c6 100644
--- a/include/net/bluetooth/hci_core.h
+++ b/include/net/bluetooth/hci_core.h
@@ -1281,6 +1281,7 @@ void hci_sock_dev_event(struct hci_dev *hdev, int event);
1281#define DISCOV_BREDR_INQUIRY_LEN 0x08 1281#define DISCOV_BREDR_INQUIRY_LEN 0x08
1282 1282
1283int mgmt_control(struct sock *sk, struct msghdr *msg, size_t len); 1283int mgmt_control(struct sock *sk, struct msghdr *msg, size_t len);
1284int mgmt_new_settings(struct hci_dev *hdev);
1284void mgmt_index_added(struct hci_dev *hdev); 1285void mgmt_index_added(struct hci_dev *hdev);
1285void mgmt_index_removed(struct hci_dev *hdev); 1286void mgmt_index_removed(struct hci_dev *hdev);
1286void mgmt_set_powered_failed(struct hci_dev *hdev, int err); 1287void mgmt_set_powered_failed(struct hci_dev *hdev, int err);
diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c
index 728a6ee471ea..84431b86af96 100644
--- a/net/bluetooth/hci_core.c
+++ b/net/bluetooth/hci_core.c
@@ -2715,6 +2715,23 @@ int hci_dev_cmd(unsigned int cmd, void __user *arg)
2715 case HCISETSCAN: 2715 case HCISETSCAN:
2716 err = hci_req_sync(hdev, hci_scan_req, dr.dev_opt, 2716 err = hci_req_sync(hdev, hci_scan_req, dr.dev_opt,
2717 HCI_INIT_TIMEOUT); 2717 HCI_INIT_TIMEOUT);
2718
2719 /* Ensure that the connectable state gets correctly
2720 * notified if the whitelist is in use.
2721 */
2722 if (!err && !list_empty(&hdev->whitelist)) {
2723 bool changed;
2724
2725 if ((dr.dev_opt & SCAN_PAGE))
2726 changed = !test_and_set_bit(HCI_CONNECTABLE,
2727 &hdev->dev_flags);
2728 else
2729 changed = test_and_set_bit(HCI_CONNECTABLE,
2730 &hdev->dev_flags);
2731
2732 if (changed)
2733 mgmt_new_settings(hdev);
2734 }
2718 break; 2735 break;
2719 2736
2720 case HCISETLINKPOL: 2737 case HCISETLINKPOL:
diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c
index 98392d61b78f..91b1f92c681e 100644
--- a/net/bluetooth/mgmt.c
+++ b/net/bluetooth/mgmt.c
@@ -1427,6 +1427,11 @@ static int new_settings(struct hci_dev *hdev, struct sock *skip)
1427 return mgmt_event(MGMT_EV_NEW_SETTINGS, hdev, &ev, sizeof(ev), skip); 1427 return mgmt_event(MGMT_EV_NEW_SETTINGS, hdev, &ev, sizeof(ev), skip);
1428} 1428}
1429 1429
1430int mgmt_new_settings(struct hci_dev *hdev)
1431{
1432 return new_settings(hdev, NULL);
1433}
1434
1430struct cmd_lookup { 1435struct cmd_lookup {
1431 struct sock *sk; 1436 struct sock *sk;
1432 struct hci_dev *hdev; 1437 struct hci_dev *hdev;