Bluetooth: hci_qca: Fixed issue during suspend
commit 55c0bd77479b60ea29fd390faf4545cfb3a1d79e upstream. If BT SoC is running with ROM FW then just return in qca_suspend function as ROM FW does not support in-band sleep. Fixes: 2be43abac5a8 ("Bluetooth: hci_qca: Wait for timeout during suspend") Signed-off-by: Venkata Lakshmi Narayana Gubba <gubbaven@codeaurora.org> Signed-off-by: Marcel Holtmann <marcel@holtmann.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
c208f1e84a
commit
217721b763
@ -77,7 +77,8 @@ enum qca_flags {
|
||||
QCA_MEMDUMP_COLLECTION,
|
||||
QCA_HW_ERROR_EVENT,
|
||||
QCA_SSR_TRIGGERED,
|
||||
QCA_BT_OFF
|
||||
QCA_BT_OFF,
|
||||
QCA_ROM_FW
|
||||
};
|
||||
|
||||
enum qca_capabilities {
|
||||
@ -1664,6 +1665,7 @@ static int qca_setup(struct hci_uart *hu)
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
clear_bit(QCA_ROM_FW, &qca->flags);
|
||||
/* Patch downloading has to be done without IBS mode */
|
||||
set_bit(QCA_IBS_DISABLED, &qca->flags);
|
||||
|
||||
@ -1722,12 +1724,14 @@ static int qca_setup(struct hci_uart *hu)
|
||||
hu->hdev->cmd_timeout = qca_cmd_timeout;
|
||||
} else if (ret == -ENOENT) {
|
||||
/* No patch/nvm-config found, run with original fw/config */
|
||||
set_bit(QCA_ROM_FW, &qca->flags);
|
||||
ret = 0;
|
||||
} else if (ret == -EAGAIN) {
|
||||
/*
|
||||
* Userspace firmware loader will return -EAGAIN in case no
|
||||
* patch/nvm-config is found, so run with original fw/config.
|
||||
*/
|
||||
set_bit(QCA_ROM_FW, &qca->flags);
|
||||
ret = 0;
|
||||
} else {
|
||||
if (retries < MAX_INIT_RETRIES) {
|
||||
@ -2112,6 +2116,12 @@ static int __maybe_unused qca_suspend(struct device *dev)
|
||||
|
||||
set_bit(QCA_SUSPENDING, &qca->flags);
|
||||
|
||||
/* if BT SoC is running with default firmware then it does not
|
||||
* support in-band sleep
|
||||
*/
|
||||
if (test_bit(QCA_ROM_FW, &qca->flags))
|
||||
return 0;
|
||||
|
||||
/* During SSR after memory dump collection, controller will be
|
||||
* powered off and then powered on.If controller is powered off
|
||||
* during SSR then we should wait until SSR is completed.
|
||||
|
Loading…
Reference in New Issue
Block a user