mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-04 04:06:26 +00:00
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>
This commit is contained in:
parent
4408dd15d9
commit
9c84d1da97
@ -401,6 +401,10 @@ struct hci_conn *hci_conn_add(struct hci_dev *hdev, int type, bdaddr_t *dst)
|
|||||||
case ACL_LINK:
|
case ACL_LINK:
|
||||||
conn->pkt_type = hdev->pkt_type & ACL_PTYPE_MASK;
|
conn->pkt_type = hdev->pkt_type & ACL_PTYPE_MASK;
|
||||||
break;
|
break;
|
||||||
|
case LE_LINK:
|
||||||
|
/* conn->src should reflect the local identity address */
|
||||||
|
hci_copy_identity_address(hdev, &conn->src, &conn->src_type);
|
||||||
|
break;
|
||||||
case SCO_LINK:
|
case SCO_LINK:
|
||||||
if (lmp_esco_capable(hdev))
|
if (lmp_esco_capable(hdev))
|
||||||
conn->pkt_type = (hdev->esco_type & SCO_ESCO_MASK) |
|
conn->pkt_type = (hdev->esco_type & SCO_ESCO_MASK) |
|
||||||
|
@ -3840,17 +3840,6 @@ static void hci_le_conn_complete_evt(struct hci_dev *hdev, struct sk_buff *skb)
|
|||||||
|
|
||||||
conn->dst_type = ev->bdaddr_type;
|
conn->dst_type = ev->bdaddr_type;
|
||||||
|
|
||||||
/* The advertising parameters for own address type
|
|
||||||
* define which source address and source address
|
|
||||||
* type this connections has.
|
|
||||||
*/
|
|
||||||
if (bacmp(&conn->src, BDADDR_ANY)) {
|
|
||||||
conn->src_type = ADDR_LE_DEV_PUBLIC;
|
|
||||||
} else {
|
|
||||||
bacpy(&conn->src, &hdev->static_addr);
|
|
||||||
conn->src_type = ADDR_LE_DEV_RANDOM;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ev->role == LE_CONN_ROLE_MASTER) {
|
if (ev->role == LE_CONN_ROLE_MASTER) {
|
||||||
conn->out = true;
|
conn->out = true;
|
||||||
conn->link_mode |= HCI_LM_MASTER;
|
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)
|
|||||||
cancel_delayed_work(&conn->le_conn_timeout);
|
cancel_delayed_work(&conn->le_conn_timeout);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Ensure that the hci_conn contains the identity address type
|
|
||||||
* regardless of which address the connection was made with.
|
|
||||||
*/
|
|
||||||
hci_copy_identity_address(hdev, &conn->src, &conn->src_type);
|
|
||||||
|
|
||||||
/* Lookup the identity address from the stored connection
|
/* Lookup the identity address from the stored connection
|
||||||
* address and address type.
|
* address and address type.
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user