aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndre Guedes <andre.guedes@openbossa.org>2011-11-25 18:53:38 -0500
committerGustavo F. Padovan <padovan@profusion.mobi>2011-12-02 07:19:18 -0500
commitd23264a896a931c4b355c102d8e9d46649195ba4 (patch)
tree0b751414ac34570568591c6b739dfc0857c0196b
parent1e89cffb44a94e1937e5ec16125ae866dbba7b2e (diff)
Bluetooth: Add dev_flags to struct hci_dev
This patch adds the dev_flags field to struct hci_dev. This new flags variable should be used to define flags related to BR/EDR and/or LE controller itself. It should be used to define flags which represents states from the controller. The dev_flags is cleared in case the controller sends a Reset Command Complete Event to the host. Also, this patch adds the HCI_LE_SCAN flag which was created to track if the controller is performing LE scan or not. The flag is set/cleared when the controller starts/stops scanning. This is an initial effort to stop using hdev->flags to define internal flags since it is exported to userspace by an ioctl. Signed-off-by: Andre Guedes <andre.guedes@openbossa.org> Acked-by: Marcel Holtmann <marcel@holtmann.org> Signed-off-by: Gustavo F. Padovan <padovan@profusion.mobi>
-rw-r--r--include/net/bluetooth/hci.h8
-rw-r--r--include/net/bluetooth/hci_core.h2
-rw-r--r--net/bluetooth/hci_core.c1
-rw-r--r--net/bluetooth/hci_event.c6
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 */
95enum {
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
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}