Re: [PATCH v1] driver: bluetooth: hci_qca: fix ssr fail when BT_EN is pulled up by hw

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Shuai,

On Mon, Jun 9, 2025 at 6:57 AM Shuai Zhang <quic_shuaz@xxxxxxxxxxx> wrote:
>
> If the SoC always enables the bt_en pin via hardware and the driver
> cannot control the bt_en pin of the SoC chip, then during SSR,
> the QCA_SSR_TRIGGERED and QCA_IBS_DISABLED bits cannot be cleared.
> This leads to a reset command timeout failure.
>
> To address this, clear QCA_SSR_TRIGGERED and QCA_IBS_DISABLED bits
> after the coredump collection is complete.
> Also, add msleep delay to wait for controller to complete SSR.
>
> Signed-off-by: Shuai Zhang <quic_shuaz@xxxxxxxxxxx>
> ---
>  drivers/bluetooth/hci_qca.c | 16 ++++++++++++++++
>  1 file changed, 16 insertions(+)
>
> diff --git a/drivers/bluetooth/hci_qca.c b/drivers/bluetooth/hci_qca.c
> index a2dc39c00..1c3df6e30 100644
> --- a/drivers/bluetooth/hci_qca.c
> +++ b/drivers/bluetooth/hci_qca.c
> @@ -1653,6 +1653,22 @@ static void qca_hw_error(struct hci_dev *hdev, u8 code)
>         }
>
>         clear_bit(QCA_HW_ERROR_EVENT, &qca->flags);
> +
> +       /*If the SoC always enables the bt_en pin via hardware and the driver
> +       * cannot control the bt_en pin of the SoC chip, then during SSR,
> +       * the QCA_SSR_TRIGGERED and QCA_IBS_DISABLED bits cannot be cleared.
> +       * This leads to a reset command timeout failure.
> +       *
> +       * To address this, clear QCA_SSR_TRIGGERED and QCA_IBS_DISABLED bits
> +       * after the coredump collection is complete.
> +       * Also, add msleep delay to wait for controller to complete SSR.
> +       */
> +       if(!test_bit(HCI_QUIRK_NON_PERSISTENT_SETUP, &hdev->quirks)) {
> +               clear_bit(QCA_SSR_TRIGGERED, &qca->flags);
> +               clear_bit(QCA_IBS_DISABLED,&qca->flags);
> +               qca->tx_ibs_state = HCI_IBS_TX_AWAKE;
> +               msleep(50);
> +       }
>  }

WARNING: Block comments should align the * on each line
#11: FILE: drivers/bluetooth/hci_qca.c:1658:
+    /*If the SoC always enables the bt_en pin via hardware and the driver
+    * cannot control the bt_en pin of the SoC chip, then during SSR,

ERROR: space required before the open parenthesis '('
#19: FILE: drivers/bluetooth/hci_qca.c:1666:
+    if(!test_bit(HCI_QUIRK_NON_PERSISTENT_SETUP, &hdev->quirks)) {

ERROR: space required after that ',' (ctx:VxO)
#21: FILE: drivers/bluetooth/hci_qca.c:1668:
+        clear_bit(QCA_IBS_DISABLED,&qca->flags);
                                   ^

ERROR: space required before that '&' (ctx:OxV)
#21: FILE: drivers/bluetooth/hci_qca.c:1668:
+        clear_bit(QCA_IBS_DISABLED,&qca->flags);
                                    ^


>  static void qca_reset(struct hci_dev *hdev)
> --
> 2.34.1
>
>


-- 
Luiz Augusto von Dentz





[Index of Archives]     [Bluez Devel]     [Linux Wireless Networking]     [Linux Wireless Personal Area Networking]     [Linux ATH6KL]     [Linux USB Devel]     [Linux Media Drivers]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Big List of Linux Books]

  Powered by Linux