diff options
author | Andre Guedes <andre.guedes@openbossa.org> | 2011-05-31 13:20:54 -0400 |
---|---|---|
committer | Gustavo F. Padovan <padovan@profusion.mobi> | 2011-06-08 15:58:18 -0400 |
commit | 29b7988a23daf79c15d587ef9e98e64715aa1ea8 (patch) | |
tree | e50821c4663e4f6bfa35456cc5d2caa98358758c | |
parent | d7556e20ade582a223ca1792e1f8a7bfd7d5d008 (diff) |
Bluetooth: Add 'dst_type' field to struct hci_conn
This patch adds a new field (dst_type) to the struct hci_conn which
holds the type of the destination address (bdaddr_t dst). This
approach is needed in order to use the struct hci_conn as an
abstraction of LE connections in HCI Layer. For non-LE this field
is ignored.
This patch also set properly the 'dst_type' field after initializing
LE hci_conn structures.
Signed-off-by: Andre Guedes <andre.guedes@openbossa.org>
Signed-off-by: Gustavo F. Padovan <padovan@profusion.mobi>
-rw-r--r-- | include/net/bluetooth/hci_core.h | 1 | ||||
-rw-r--r-- | net/bluetooth/hci_event.c | 8 |
2 files changed, 7 insertions, 2 deletions
diff --git a/include/net/bluetooth/hci_core.h b/include/net/bluetooth/hci_core.h index 0ac820dc35f7..5be150229574 100644 --- a/include/net/bluetooth/hci_core.h +++ b/include/net/bluetooth/hci_core.h | |||
@@ -224,6 +224,7 @@ struct hci_conn { | |||
224 | spinlock_t lock; | 224 | spinlock_t lock; |
225 | 225 | ||
226 | bdaddr_t dst; | 226 | bdaddr_t dst; |
227 | __u8 dst_type; | ||
227 | __u16 handle; | 228 | __u16 handle; |
228 | __u16 state; | 229 | __u16 state; |
229 | __u8 mode; | 230 | __u8 mode; |
diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c index 6fc766e107aa..afee4ac1008b 100644 --- a/net/bluetooth/hci_event.c +++ b/net/bluetooth/hci_event.c | |||
@@ -1234,10 +1234,12 @@ static void hci_cs_le_create_conn(struct hci_dev *hdev, __u8 status) | |||
1234 | } else { | 1234 | } else { |
1235 | if (!conn) { | 1235 | if (!conn) { |
1236 | conn = hci_conn_add(hdev, LE_LINK, &cp->peer_addr); | 1236 | conn = hci_conn_add(hdev, LE_LINK, &cp->peer_addr); |
1237 | if (conn) | 1237 | if (conn) { |
1238 | conn->dst_type = cp->peer_addr_type; | ||
1238 | conn->out = 1; | 1239 | conn->out = 1; |
1239 | else | 1240 | } else { |
1240 | BT_ERR("No memory for new connection"); | 1241 | BT_ERR("No memory for new connection"); |
1242 | } | ||
1241 | } | 1243 | } |
1242 | } | 1244 | } |
1243 | 1245 | ||
@@ -2694,6 +2696,8 @@ static inline void hci_le_conn_complete_evt(struct hci_dev *hdev, struct sk_buff | |||
2694 | hci_dev_unlock(hdev); | 2696 | hci_dev_unlock(hdev); |
2695 | return; | 2697 | return; |
2696 | } | 2698 | } |
2699 | |||
2700 | conn->dst_type = ev->bdaddr_type; | ||
2697 | } | 2701 | } |
2698 | 2702 | ||
2699 | if (ev->status) { | 2703 | if (ev->status) { |