Bluetooth: Select the own address type during initial setup phase
The own address type is based on the fact if the controller has a public address or not. This means that this detail can be just configured once during setup phase. Signed-off-by: Marcel Holtmann <marcel@holtmann.org> Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
This commit is contained in:
committed by
Johan Hedberg
parent
8f8625cd80
commit
79830f66e3
@@ -142,6 +142,7 @@ struct hci_dev {
|
|||||||
__u8 dev_type;
|
__u8 dev_type;
|
||||||
bdaddr_t bdaddr;
|
bdaddr_t bdaddr;
|
||||||
bdaddr_t static_addr;
|
bdaddr_t static_addr;
|
||||||
|
__u8 own_addr_type;
|
||||||
__u8 dev_name[HCI_MAX_NAME_LENGTH];
|
__u8 dev_name[HCI_MAX_NAME_LENGTH];
|
||||||
__u8 short_name[HCI_MAX_SHORT_NAME_LENGTH];
|
__u8 short_name[HCI_MAX_SHORT_NAME_LENGTH];
|
||||||
__u8 eir[HCI_MAX_EIR_LENGTH];
|
__u8 eir[HCI_MAX_EIR_LENGTH];
|
||||||
|
@@ -615,12 +615,7 @@ static struct hci_conn *hci_connect_le(struct hci_dev *hdev, bdaddr_t *dst,
|
|||||||
else
|
else
|
||||||
conn->dst_type = ADDR_LE_DEV_RANDOM;
|
conn->dst_type = ADDR_LE_DEV_RANDOM;
|
||||||
|
|
||||||
if (bacmp(&conn->src, BDADDR_ANY)) {
|
conn->src_type = hdev->own_addr_type;
|
||||||
conn->src_type = ADDR_LE_DEV_PUBLIC;
|
|
||||||
} else {
|
|
||||||
bacpy(&conn->src, &hdev->static_addr);
|
|
||||||
conn->src_type = ADDR_LE_DEV_RANDOM;
|
|
||||||
}
|
|
||||||
|
|
||||||
conn->state = BT_CONNECT;
|
conn->state = BT_CONNECT;
|
||||||
conn->out = true;
|
conn->out = true;
|
||||||
|
@@ -1053,8 +1053,19 @@ static void hci_init3_req(struct hci_request *req, unsigned long opt)
|
|||||||
if (hdev->commands[5] & 0x10)
|
if (hdev->commands[5] & 0x10)
|
||||||
hci_setup_link_policy(req);
|
hci_setup_link_policy(req);
|
||||||
|
|
||||||
if (lmp_le_capable(hdev))
|
if (lmp_le_capable(hdev)) {
|
||||||
|
/* If the controller has a public BD_ADDR, then by
|
||||||
|
* default use that one. If this is a LE only
|
||||||
|
* controller without one, default to the random
|
||||||
|
* address.
|
||||||
|
*/
|
||||||
|
if (bacmp(&hdev->bdaddr, BDADDR_ANY))
|
||||||
|
hdev->own_addr_type = ADDR_LE_DEV_PUBLIC;
|
||||||
|
else
|
||||||
|
hdev->own_addr_type = ADDR_LE_DEV_RANDOM;
|
||||||
|
|
||||||
hci_set_le_support(req);
|
hci_set_le_support(req);
|
||||||
|
}
|
||||||
|
|
||||||
/* Read features beyond page 1 if available */
|
/* Read features beyond page 1 if available */
|
||||||
for (p = 2; p < HCI_MAX_PAGES && p <= hdev->max_page; p++) {
|
for (p = 2; p < HCI_MAX_PAGES && p <= hdev->max_page; p++) {
|
||||||
|
@@ -1325,10 +1325,7 @@ static void enable_advertising(struct hci_request *req)
|
|||||||
cp.min_interval = __constant_cpu_to_le16(0x0800);
|
cp.min_interval = __constant_cpu_to_le16(0x0800);
|
||||||
cp.max_interval = __constant_cpu_to_le16(0x0800);
|
cp.max_interval = __constant_cpu_to_le16(0x0800);
|
||||||
cp.type = get_adv_type(hdev);
|
cp.type = get_adv_type(hdev);
|
||||||
if (bacmp(&hdev->bdaddr, BDADDR_ANY))
|
cp.own_address_type = hdev->own_addr_type;
|
||||||
cp.own_address_type = ADDR_LE_DEV_PUBLIC;
|
|
||||||
else
|
|
||||||
cp.own_address_type = ADDR_LE_DEV_RANDOM;
|
|
||||||
cp.channel_map = 0x07;
|
cp.channel_map = 0x07;
|
||||||
|
|
||||||
hci_req_add(req, HCI_OP_LE_SET_ADV_PARAM, sizeof(cp), &cp);
|
hci_req_add(req, HCI_OP_LE_SET_ADV_PARAM, sizeof(cp), &cp);
|
||||||
@@ -3237,10 +3234,7 @@ static int start_discovery(struct sock *sk, struct hci_dev *hdev,
|
|||||||
param_cp.type = LE_SCAN_ACTIVE;
|
param_cp.type = LE_SCAN_ACTIVE;
|
||||||
param_cp.interval = cpu_to_le16(DISCOV_LE_SCAN_INT);
|
param_cp.interval = cpu_to_le16(DISCOV_LE_SCAN_INT);
|
||||||
param_cp.window = cpu_to_le16(DISCOV_LE_SCAN_WIN);
|
param_cp.window = cpu_to_le16(DISCOV_LE_SCAN_WIN);
|
||||||
if (bacmp(&hdev->bdaddr, BDADDR_ANY))
|
param_cp.own_address_type = hdev->own_addr_type;
|
||||||
param_cp.own_address_type = ADDR_LE_DEV_PUBLIC;
|
|
||||||
else
|
|
||||||
param_cp.own_address_type = ADDR_LE_DEV_RANDOM;
|
|
||||||
hci_req_add(&req, HCI_OP_LE_SET_SCAN_PARAM, sizeof(param_cp),
|
hci_req_add(&req, HCI_OP_LE_SET_SCAN_PARAM, sizeof(param_cp),
|
||||||
¶m_cp);
|
¶m_cp);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user