]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
Bluetooth: hci_qca: Only remove TX clock vote after TX is completed
authorMatthias Kaehlcke <mka@chromium.org>
Fri, 5 Jun 2020 18:46:09 +0000 (11:46 -0700)
committerMarcel Holtmann <marcel@holtmann.org>
Mon, 8 Jun 2020 08:10:52 +0000 (10:10 +0200)
qca_suspend() removes the vote for the UART TX clock after
writing an IBS sleep request to the serial buffer. This is
not a good idea since there is no guarantee that the request
has been sent at this point. Instead remove the vote after
successfully entering IBS sleep. This also fixes the issue
of the vote being removed in case of an aborted suspend due
to a failure of entering IBS sleep.

Fixes: 41d5b25fed0a0 ("Bluetooth: hci_qca: add PM support")
Signed-off-by: Matthias Kaehlcke <mka@chromium.org>
Reviewed-by: Abhishek Pandit-Subedi <abhishekpandit@chromium.org>
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
drivers/bluetooth/hci_qca.c

index 997ddab26a33b26604b5a734b52b7decb8b18a19..bce290bbf22df25810e5b5550ba3a622e1b0e8b1 100644 (file)
@@ -2081,8 +2081,6 @@ static int __maybe_unused qca_suspend(struct device *dev)
 
                qca->tx_ibs_state = HCI_IBS_TX_ASLEEP;
                qca->ibs_sent_slps++;
-
-               qca_wq_serial_tx_clock_vote_off(&qca->ws_tx_vote_off);
                break;
 
        case HCI_IBS_TX_ASLEEP:
@@ -2110,8 +2108,10 @@ static int __maybe_unused qca_suspend(struct device *dev)
                        qca->rx_ibs_state == HCI_IBS_RX_ASLEEP,
                        msecs_to_jiffies(IBS_BTSOC_TX_IDLE_TIMEOUT_MS));
 
-       if (ret > 0)
+       if (ret > 0) {
+               qca_wq_serial_tx_clock_vote_off(&qca->ws_tx_vote_off);
                return 0;
+       }
 
        if (ret == 0)
                ret = -ETIMEDOUT;