Commit dd336649 authored by Johan Hovold's avatar Johan Hovold Committed by Luiz Augusto von Dentz

Bluetooth: qca: generalise device address check

The default device address apparently comes from the NVM configuration
file and can differ quite a bit between controllers.

Store the default address when parsing the configuration file and use it
to determine whether the controller has been provisioned with an
address.

This makes sure that devices without a unique address start as
unconfigured unless a valid address has been provided in the devicetree.

Fixes: 32868e12 ("Bluetooth: qca: fix invalid device address check")
Cc: stable@vger.kernel.org      # 6.5
Cc: Doug Anderson <dianders@chromium.org>
Cc: Janaki Ramaiah Thota <quic_janathot@quicinc.com>
Signed-off-by: default avatarJohan Hovold <johan+linaro@kernel.org>
Tested-by: default avatarDouglas Anderson <dianders@chromium.org>
Signed-off-by: default avatarLuiz Augusto von Dentz <luiz.von.dentz@intel.com>
parent a112d3c7
...@@ -15,9 +15,6 @@ ...@@ -15,9 +15,6 @@
#define VERSION "0.1" #define VERSION "0.1"
#define QCA_BDADDR_DEFAULT (&(bdaddr_t) {{ 0xad, 0x5a, 0x00, 0x00, 0x00, 0x00 }})
#define QCA_BDADDR_WCN3991 (&(bdaddr_t) {{ 0xad, 0x5a, 0x00, 0x00, 0x98, 0x39 }})
int qca_read_soc_version(struct hci_dev *hdev, struct qca_btsoc_version *ver, int qca_read_soc_version(struct hci_dev *hdev, struct qca_btsoc_version *ver,
enum qca_btsoc_type soc_type) enum qca_btsoc_type soc_type)
{ {
...@@ -387,6 +384,14 @@ static int qca_tlv_check_data(struct hci_dev *hdev, ...@@ -387,6 +384,14 @@ static int qca_tlv_check_data(struct hci_dev *hdev,
/* Update NVM tags as needed */ /* Update NVM tags as needed */
switch (tag_id) { switch (tag_id) {
case EDL_TAG_ID_BD_ADDR:
if (tag_len != sizeof(bdaddr_t))
return -EINVAL;
memcpy(&config->bdaddr, tlv_nvm->data, sizeof(bdaddr_t));
break;
case EDL_TAG_ID_HCI: case EDL_TAG_ID_HCI:
if (tag_len < 3) if (tag_len < 3)
return -EINVAL; return -EINVAL;
...@@ -661,7 +666,7 @@ int qca_set_bdaddr_rome(struct hci_dev *hdev, const bdaddr_t *bdaddr) ...@@ -661,7 +666,7 @@ int qca_set_bdaddr_rome(struct hci_dev *hdev, const bdaddr_t *bdaddr)
} }
EXPORT_SYMBOL_GPL(qca_set_bdaddr_rome); EXPORT_SYMBOL_GPL(qca_set_bdaddr_rome);
static int qca_check_bdaddr(struct hci_dev *hdev) static int qca_check_bdaddr(struct hci_dev *hdev, const struct qca_fw_config *config)
{ {
struct hci_rp_read_bd_addr *bda; struct hci_rp_read_bd_addr *bda;
struct sk_buff *skb; struct sk_buff *skb;
...@@ -685,10 +690,8 @@ static int qca_check_bdaddr(struct hci_dev *hdev) ...@@ -685,10 +690,8 @@ static int qca_check_bdaddr(struct hci_dev *hdev)
} }
bda = (struct hci_rp_read_bd_addr *)skb->data; bda = (struct hci_rp_read_bd_addr *)skb->data;
if (!bacmp(&bda->bdaddr, QCA_BDADDR_DEFAULT) || if (!bacmp(&bda->bdaddr, &config->bdaddr))
!bacmp(&bda->bdaddr, QCA_BDADDR_WCN3991)) {
set_bit(HCI_QUIRK_USE_BDADDR_PROPERTY, &hdev->quirks); set_bit(HCI_QUIRK_USE_BDADDR_PROPERTY, &hdev->quirks);
}
kfree_skb(skb); kfree_skb(skb);
...@@ -716,7 +719,7 @@ int qca_uart_setup(struct hci_dev *hdev, uint8_t baudrate, ...@@ -716,7 +719,7 @@ int qca_uart_setup(struct hci_dev *hdev, uint8_t baudrate,
enum qca_btsoc_type soc_type, struct qca_btsoc_version ver, enum qca_btsoc_type soc_type, struct qca_btsoc_version ver,
const char *firmware_name) const char *firmware_name)
{ {
struct qca_fw_config config; struct qca_fw_config config = {};
int err; int err;
u8 rom_ver = 0; u8 rom_ver = 0;
u32 soc_ver; u32 soc_ver;
...@@ -901,7 +904,7 @@ int qca_uart_setup(struct hci_dev *hdev, uint8_t baudrate, ...@@ -901,7 +904,7 @@ int qca_uart_setup(struct hci_dev *hdev, uint8_t baudrate,
break; break;
} }
err = qca_check_bdaddr(hdev); err = qca_check_bdaddr(hdev, &config);
if (err) if (err)
return err; return err;
......
...@@ -29,6 +29,7 @@ ...@@ -29,6 +29,7 @@
#define EDL_PATCH_CONFIG_RES_EVT (0x00) #define EDL_PATCH_CONFIG_RES_EVT (0x00)
#define QCA_DISABLE_LOGGING_SUB_OP (0x14) #define QCA_DISABLE_LOGGING_SUB_OP (0x14)
#define EDL_TAG_ID_BD_ADDR 2
#define EDL_TAG_ID_HCI (17) #define EDL_TAG_ID_HCI (17)
#define EDL_TAG_ID_DEEP_SLEEP (27) #define EDL_TAG_ID_DEEP_SLEEP (27)
...@@ -94,6 +95,7 @@ struct qca_fw_config { ...@@ -94,6 +95,7 @@ struct qca_fw_config {
uint8_t user_baud_rate; uint8_t user_baud_rate;
enum qca_tlv_dnld_mode dnld_mode; enum qca_tlv_dnld_mode dnld_mode;
enum qca_tlv_dnld_mode dnld_type; enum qca_tlv_dnld_mode dnld_type;
bdaddr_t bdaddr;
}; };
struct edl_event_hdr { struct edl_event_hdr {
......
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