Commit 89350531 authored by Kiran K's avatar Kiran K Committed by Marcel Holtmann

Bluetooth: btintel: Fix bdaddress comparison with garbage value

Intel Read Verision(TLV) data is parsed into a local structure variable
and it contains a field for bd address. Bd address is returned only in
bootloader mode and hence bd address in TLV structure needs to be validated
only if controller is present in boot loader mode.
Signed-off-by: default avatarKiran K <kiran.k@intel.com>
Reviewed-by: default avatarTedd Ho-Jeong An <tedd.an@intel.com>
Signed-off-by: default avatarMarcel Holtmann <marcel@holtmann.org>
parent 5a4bb6a8
...@@ -2081,14 +2081,16 @@ static int btintel_prepare_fw_download_tlv(struct hci_dev *hdev, ...@@ -2081,14 +2081,16 @@ static int btintel_prepare_fw_download_tlv(struct hci_dev *hdev,
if (ver->img_type == 0x03) { if (ver->img_type == 0x03) {
btintel_clear_flag(hdev, INTEL_BOOTLOADER); btintel_clear_flag(hdev, INTEL_BOOTLOADER);
btintel_check_bdaddr(hdev); btintel_check_bdaddr(hdev);
} } else {
/*
/* If the OTP has no valid Bluetooth device address, then there will * Check for valid bd address in boot loader mode. Device
* also be no valid address for the operational firmware. * will be marked as unconfigured if empty bd address is
*/ * found.
if (!bacmp(&ver->otp_bd_addr, BDADDR_ANY)) { */
bt_dev_info(hdev, "No device address configured"); if (!bacmp(&ver->otp_bd_addr, BDADDR_ANY)) {
set_bit(HCI_QUIRK_INVALID_BDADDR, &hdev->quirks); bt_dev_info(hdev, "No device address configured");
set_bit(HCI_QUIRK_INVALID_BDADDR, &hdev->quirks);
}
} }
btintel_get_fw_name_tlv(ver, fwname, sizeof(fwname), "sfi"); btintel_get_fw_name_tlv(ver, fwname, sizeof(fwname), "sfi");
...@@ -2466,6 +2468,10 @@ static int btintel_setup_combined(struct hci_dev *hdev) ...@@ -2466,6 +2468,10 @@ static int btintel_setup_combined(struct hci_dev *hdev)
goto exit_error; goto exit_error;
} }
/* memset ver_tlv to start with clean state as few fields are exclusive
* to bootloader mode and are not populated in operational mode
*/
memset(&ver_tlv, 0, sizeof(ver_tlv));
/* For TLV type device, parse the tlv data */ /* For TLV type device, parse the tlv data */
err = btintel_parse_version_tlv(hdev, &ver_tlv, skb); err = btintel_parse_version_tlv(hdev, &ver_tlv, skb);
if (err) { if (err) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment