aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorJohan Hedberg <johan.hedberg@intel.com>2014-03-24 14:21:50 -0400
committerMarcel Holtmann <marcel@holtmann.org>2014-03-26 12:31:35 -0400
commit9c84d1da974ee8b54fa49ae369648a0247b7cd6f (patch)
tree467b0eb8a32f9d6316d16ddb10c219c099fe1195 /net
parent4408dd15d9cfcf78b819d2d4a5b43dc36056cab8 (diff)
Bluetooth: Move local identity address setting to a central place
Any time hci_conn_add is used for an LE connection we need to ensure that the local identity address is correctly described in the src and src_type variables. This patch moves setting these values directly into hci_conn_add so that callers don't have to duplicate the effort themselves. Signed-off-by: Johan Hedberg <johan.hedberg@intel.com> Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Diffstat (limited to 'net')
-rw-r--r--net/bluetooth/hci_conn.c4
-rw-r--r--net/bluetooth/hci_event.c16
2 files changed, 4 insertions, 16 deletions
diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c
index d958e2dca52f..129c22a85ccf 100644
--- a/net/bluetooth/hci_conn.c
+++ b/net/bluetooth/hci_conn.c
@@ -401,6 +401,10 @@ struct hci_conn *hci_conn_add(struct hci_dev *hdev, int type, bdaddr_t *dst)
401 case ACL_LINK: 401 case ACL_LINK:
402 conn->pkt_type = hdev->pkt_type & ACL_PTYPE_MASK; 402 conn->pkt_type = hdev->pkt_type & ACL_PTYPE_MASK;
403 break; 403 break;
404 case LE_LINK:
405 /* conn->src should reflect the local identity address */
406 hci_copy_identity_address(hdev, &conn->src, &conn->src_type);
407 break;
404 case SCO_LINK: 408 case SCO_LINK:
405 if (lmp_esco_capable(hdev)) 409 if (lmp_esco_capable(hdev))
406 conn->pkt_type = (hdev->esco_type & SCO_ESCO_MASK) | 410 conn->pkt_type = (hdev->esco_type & SCO_ESCO_MASK) |
diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c
index d0efeeeb6951..cfdada38369b 100644
--- a/net/bluetooth/hci_event.c
+++ b/net/bluetooth/hci_event.c
@@ -3840,17 +3840,6 @@ static void hci_le_conn_complete_evt(struct hci_dev *hdev, struct sk_buff *skb)
3840 3840
3841 conn->dst_type = ev->bdaddr_type; 3841 conn->dst_type = ev->bdaddr_type;
3842 3842
3843 /* The advertising parameters for own address type
3844 * define which source address and source address
3845 * type this connections has.
3846 */
3847 if (bacmp(&conn->src, BDADDR_ANY)) {
3848 conn->src_type = ADDR_LE_DEV_PUBLIC;
3849 } else {
3850 bacpy(&conn->src, &hdev->static_addr);
3851 conn->src_type = ADDR_LE_DEV_RANDOM;
3852 }
3853
3854 if (ev->role == LE_CONN_ROLE_MASTER) { 3843 if (ev->role == LE_CONN_ROLE_MASTER) {
3855 conn->out = true; 3844 conn->out = true;
3856 conn->link_mode |= HCI_LM_MASTER; 3845 conn->link_mode |= HCI_LM_MASTER;
@@ -3892,11 +3881,6 @@ static void hci_le_conn_complete_evt(struct hci_dev *hdev, struct sk_buff *skb)
3892 cancel_delayed_work(&conn->le_conn_timeout); 3881 cancel_delayed_work(&conn->le_conn_timeout);
3893 } 3882 }
3894 3883
3895 /* Ensure that the hci_conn contains the identity address type
3896 * regardless of which address the connection was made with.
3897 */
3898 hci_copy_identity_address(hdev, &conn->src, &conn->src_type);
3899
3900 /* Lookup the identity address from the stored connection 3884 /* Lookup the identity address from the stored connection
3901 * address and address type. 3885 * address and address type.
3902 * 3886 *