Bluetooth: Add lmp_host_le_capable() macro
authorAndre Guedes <andre.guedes@openbossa.org>
Thu, 30 Jun 2011 22:20:55 +0000 (19:20 -0300)
committerGustavo F. Padovan <padovan@profusion.mobi>
Wed, 6 Jul 2011 22:10:41 +0000 (19:10 -0300)
Since we have the extended LMP features properly implemented, we
should check the LMP_HOST_LE bit to know if the host supports LE.

Signed-off-by: Andre Guedes <andre.guedes@openbossa.org>
Signed-off-by: Gustavo F. Padovan <padovan@profusion.mobi>
include/net/bluetooth/hci.h
include/net/bluetooth/hci_core.h
net/bluetooth/hci_core.c

index 5f37822..5004e36 100644 (file)
@@ -219,6 +219,9 @@ enum {
 #define LMP_INQ_TX_PWR 0x02
 #define LMP_EXTFEATURES        0x80
 
+/* Extended LMP features */
+#define LMP_HOST_LE    0x02
+
 /* Connection modes */
 #define HCI_CM_ACTIVE  0x0000
 #define HCI_CM_HOLD    0x0001
index eb7fe99..bb57bca 100644 (file)
@@ -578,6 +578,9 @@ void hci_conn_del_sysfs(struct hci_conn *conn);
 #define lmp_no_flush_capable(dev)  ((dev)->features[6] & LMP_NO_FLUSH)
 #define lmp_le_capable(dev)        ((dev)->features[4] & LMP_LE)
 
+/* ----- Extended LMP capabilities ----- */
+#define lmp_host_le_capable(dev)   ((dev)->extfeatures[0] & LMP_HOST_LE)
+
 /* ----- HCI protocols ----- */
 struct hci_proto {
        char            *name;
index cd59b84..886cc44 100644 (file)
@@ -542,7 +542,7 @@ int hci_dev_open(__u16 dev)
                ret = __hci_request(hdev, hci_init_req, 0,
                                        msecs_to_jiffies(HCI_INIT_TIMEOUT));
 
-               if (lmp_le_capable(hdev))
+               if (lmp_host_le_capable(hdev))
                        ret = __hci_request(hdev, hci_le_init_req, 0,
                                        msecs_to_jiffies(HCI_INIT_TIMEOUT));