提交 d8270fbb 编写于 作者: M Marcel Holtmann

Bluetooth: btintel: Set quirk for non-persistent diagnostic settings

For Intel controllers the diagnostics settings are not persistent over
HCI Reset. So set the quirk to programm them again on every power up.
Signed-off-by: NMarcel Holtmann <marcel@holtmann.org>
Signed-off-by: NJohan Hedberg <johan.hedberg@intel.com>
上级 7e995b9e
...@@ -97,9 +97,6 @@ int btintel_set_diag(struct hci_dev *hdev, bool enable) ...@@ -97,9 +97,6 @@ int btintel_set_diag(struct hci_dev *hdev, bool enable)
u8 param[3]; u8 param[3];
int err; int err;
if (!test_bit(HCI_RUNNING, &hdev->flags))
return -ENETDOWN;
if (enable) { if (enable) {
param[0] = 0x03; param[0] = 0x03;
param[1] = 0x03; param[1] = 0x03;
...@@ -113,6 +110,8 @@ int btintel_set_diag(struct hci_dev *hdev, bool enable) ...@@ -113,6 +110,8 @@ int btintel_set_diag(struct hci_dev *hdev, bool enable)
skb = __hci_cmd_sync(hdev, 0xfc43, 3, param, HCI_INIT_TIMEOUT); skb = __hci_cmd_sync(hdev, 0xfc43, 3, param, HCI_INIT_TIMEOUT);
if (IS_ERR(skb)) { if (IS_ERR(skb)) {
err = PTR_ERR(skb); err = PTR_ERR(skb);
if (err == -ENODATA)
return 0;
BT_ERR("%s: Changing Intel diagnostic mode failed (%d)", BT_ERR("%s: Changing Intel diagnostic mode failed (%d)",
hdev->name, err); hdev->name, err);
return err; return err;
......
...@@ -2894,6 +2894,7 @@ static int btusb_probe(struct usb_interface *intf, ...@@ -2894,6 +2894,7 @@ static int btusb_probe(struct usb_interface *intf,
hdev->set_diag = btintel_set_diag; hdev->set_diag = btintel_set_diag;
hdev->set_bdaddr = btintel_set_bdaddr; hdev->set_bdaddr = btintel_set_bdaddr;
set_bit(HCI_QUIRK_STRICT_DUPLICATE_FILTER, &hdev->quirks); set_bit(HCI_QUIRK_STRICT_DUPLICATE_FILTER, &hdev->quirks);
set_bit(HCI_QUIRK_NON_PERSISTENT_DIAG, &hdev->quirks);
} }
if (id->driver_info & BTUSB_MARVELL) if (id->driver_info & BTUSB_MARVELL)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册