diff options
| -rw-r--r-- | include/net/bluetooth/hci.h | 8 | ||||
| -rw-r--r-- | include/net/bluetooth/hci_core.h | 2 | ||||
| -rw-r--r-- | net/bluetooth/hci_core.c | 1 | ||||
| -rw-r--r-- | net/bluetooth/hci_event.c | 6 |
4 files changed, 17 insertions, 0 deletions
diff --git a/include/net/bluetooth/hci.h b/include/net/bluetooth/hci.h index ee83c36d35aa..e2ed3683f1c5 100644 --- a/include/net/bluetooth/hci.h +++ b/include/net/bluetooth/hci.h | |||
| @@ -88,6 +88,14 @@ enum { | |||
| 88 | HCI_RESET, | 88 | HCI_RESET, |
| 89 | }; | 89 | }; |
| 90 | 90 | ||
| 91 | /* | ||
| 92 | * BR/EDR and/or LE controller flags: the flags defined here should represent | ||
| 93 | * states from the controller. | ||
| 94 | */ | ||
| 95 | enum { | ||
| 96 | HCI_LE_SCAN, | ||
| 97 | }; | ||
| 98 | |||
| 91 | /* HCI ioctl defines */ | 99 | /* HCI ioctl defines */ |
| 92 | #define HCIDEVUP _IOW('H', 201, int) | 100 | #define HCIDEVUP _IOW('H', 201, int) |
| 93 | #define HCIDEVDOWN _IOW('H', 202, int) | 101 | #define HCIDEVDOWN _IOW('H', 202, int) |
diff --git a/include/net/bluetooth/hci_core.h b/include/net/bluetooth/hci_core.h index 44f130f6fb5e..e34cd71a586e 100644 --- a/include/net/bluetooth/hci_core.h +++ b/include/net/bluetooth/hci_core.h | |||
| @@ -252,6 +252,8 @@ struct hci_dev { | |||
| 252 | 252 | ||
| 253 | struct module *owner; | 253 | struct module *owner; |
| 254 | 254 | ||
| 255 | unsigned long dev_flags; | ||
| 256 | |||
| 255 | int (*open)(struct hci_dev *hdev); | 257 | int (*open)(struct hci_dev *hdev); |
| 256 | int (*close)(struct hci_dev *hdev); | 258 | int (*close)(struct hci_dev *hdev); |
| 257 | int (*flush)(struct hci_dev *hdev); | 259 | int (*flush)(struct hci_dev *hdev); |
diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c index ef0423e62a22..dcbe1d29bb8e 100644 --- a/net/bluetooth/hci_core.c +++ b/net/bluetooth/hci_core.c | |||
| @@ -1458,6 +1458,7 @@ int hci_register_dev(struct hci_dev *hdev) | |||
| 1458 | spin_lock_init(&hdev->lock); | 1458 | spin_lock_init(&hdev->lock); |
| 1459 | 1459 | ||
| 1460 | hdev->flags = 0; | 1460 | hdev->flags = 0; |
| 1461 | hdev->dev_flags = 0; | ||
| 1461 | hdev->pkt_type = (HCI_DM1 | HCI_DH1 | HCI_HV1); | 1462 | hdev->pkt_type = (HCI_DM1 | HCI_DH1 | HCI_HV1); |
| 1462 | hdev->esco_type = (ESCO_HV1); | 1463 | hdev->esco_type = (ESCO_HV1); |
| 1463 | hdev->link_mode = (HCI_LM_ACCEPT); | 1464 | hdev->link_mode = (HCI_LM_ACCEPT); |
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 | ||
| 199 | static void hci_cc_write_local_name(struct hci_dev *hdev, struct sk_buff *skb) | 201 | static 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 | } |
