aboutsummaryrefslogtreecommitdiffstats
path: root/net/bluetooth/hci_event.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/bluetooth/hci_event.c')
-rw-r--r--net/bluetooth/hci_event.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c
index ab4922831b9a..acbdfbeeb920 100644
--- a/net/bluetooth/hci_event.c
+++ b/net/bluetooth/hci_event.c
@@ -194,6 +194,8 @@ static void hci_cc_reset(struct hci_dev *hdev, struct sk_buff *skb)
194 clear_bit(HCI_RESET, &hdev->flags); 194 clear_bit(HCI_RESET, &hdev->flags);
195 195
196 hci_req_complete(hdev, HCI_OP_RESET, status); 196 hci_req_complete(hdev, HCI_OP_RESET, status);
197
198 hdev->dev_flags = 0;
197} 199}
198 200
199static void hci_cc_write_local_name(struct hci_dev *hdev, struct sk_buff *skb) 201static void hci_cc_write_local_name(struct hci_dev *hdev, struct sk_buff *skb)
@@ -1006,12 +1008,16 @@ static void hci_cc_le_set_scan_enable(struct hci_dev *hdev,
1006 return; 1008 return;
1007 1009
1008 if (cp->enable == 0x01) { 1010 if (cp->enable == 0x01) {
1011 set_bit(HCI_LE_SCAN, &hdev->dev_flags);
1012
1009 del_timer(&hdev->adv_timer); 1013 del_timer(&hdev->adv_timer);
1010 1014
1011 hci_dev_lock(hdev); 1015 hci_dev_lock(hdev);
1012 hci_adv_entries_clear(hdev); 1016 hci_adv_entries_clear(hdev);
1013 hci_dev_unlock(hdev); 1017 hci_dev_unlock(hdev);
1014 } else if (cp->enable == 0x00) { 1018 } else if (cp->enable == 0x00) {
1019 clear_bit(HCI_LE_SCAN, &hdev->dev_flags);
1020
1015 mod_timer(&hdev->adv_timer, jiffies + ADV_CLEAR_TIMEOUT); 1021 mod_timer(&hdev->adv_timer, jiffies + ADV_CLEAR_TIMEOUT);
1016 } 1022 }
1017} 1023}