[PATCH v1] Bluetooth: btmtk: Trigger reset on firmware download failure
Luiz Augusto von Dentz
luiz.dentz at gmail.com
Wed Dec 10 13:09:03 PST 2025
Hi Chris,
On Tue, Dec 9, 2025 at 7:06 AM Chris Lu <chris.lu at mediatek.com> wrote:
>
> Initiate reset flow if MT79xx series BT failed to download firmware when
> doing setup.
> If driver is not able to get event after reset in the first section of
> btmtk_usb_setup, the protocol is deemed unuable and driver will return to
> prevent from repeatedly executing resets.
>
> Signed-off-by: Chris Lu <chris.lu at mediatek.com>
> ---
> drivers/bluetooth/btmtk.c | 11 +++++++++--
> 1 file changed, 9 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/bluetooth/btmtk.c b/drivers/bluetooth/btmtk.c
> index a8c520dc09e1..8b1443b9e9cf 100644
> --- a/drivers/bluetooth/btmtk.c
> +++ b/drivers/bluetooth/btmtk.c
> @@ -1333,7 +1333,7 @@ int btmtk_usb_setup(struct hci_dev *hdev)
> btmtk_usb_hci_wmt_sync);
> if (err < 0) {
> bt_dev_err(hdev, "Failed to set up firmware (%d)", err);
> - return err;
> + goto reset_fw;
> }
>
> /* It's Device EndPoint Reset Option Register */
> @@ -1353,7 +1353,7 @@ int btmtk_usb_setup(struct hci_dev *hdev)
> err = btmtk_usb_hci_wmt_sync(hdev, &wmt_params);
> if (err < 0) {
> bt_dev_err(hdev, "Failed to send wmt func ctrl (%d)", err);
> - return err;
> + goto reset_fw;
> }
>
> hci_set_msft_opcode(hdev, 0xFD30);
> @@ -1444,6 +1444,13 @@ int btmtk_usb_setup(struct hci_dev *hdev)
> }
> kfree_skb(skb);
>
> +reset_fw:
> + if (btmtk_data->reset_sync) {
> + bt_dev_err(hdev, "Mediatek do firmware reset");
This message is a bit cryptic to me, why do we need to print that you
will be doing a reset?
> + btmtk_reset_sync(hdev);
This seems to be doing a hard reset, which I assume you are doing as
an attempt to recover by retrying to setup, but if it fails we may go
into a loop condition trying to setup so we better limit the number of
attempts.
> + return err;
> + }
> +
> done:
> rettime = ktime_get();
> delta = ktime_sub(rettime, calltime);
> --
> 2.45.2
>
--
Luiz Augusto von Dentz
More information about the Linux-mediatek
mailing list