]> git.baikalelectronics.ru Git - kernel.git/commitdiff
usb: typec: ucsi: Clear EVENT_PENDING bit if ucsi_send_command fails
authorPrashanth K <quic_prashk@quicinc.com>
Mon, 11 Sep 2023 09:04:15 +0000 (14:34 +0530)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 19 Oct 2023 21:08:58 +0000 (23:08 +0200)
commit a00e197daec52bcd955e118f5f57d706da5bfe50 upstream.

Currently if ucsi_send_command() fails, then we bail out without
clearing EVENT_PENDING flag. So when the next connector change
event comes, ucsi_connector_change() won't queue the con->work,
because of which none of the new events will be processed.

Fix this by clearing EVENT_PENDING flag if ucsi_send_command()
fails.

Cc: stable@vger.kernel.org # 5.16
Fixes: 512df95b9432 ("usb: typec: ucsi: Better fix for missing unplug events issue")
Signed-off-by: Prashanth K <quic_prashk@quicinc.com>
Acked-by: Heikki Krogerus <heikki.krogerus@linux.intel.com>
Link: https://lore.kernel.org/r/1694423055-8440-1-git-send-email-quic_prashk@quicinc.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/typec/ucsi/ucsi.c

index 47a2c73df34207c1c307c67012e1513553489eb2..dc2dea3768fb6d508146b87d6263b2ad3f593e10 100644 (file)
@@ -785,6 +785,7 @@ static void ucsi_handle_connector_change(struct work_struct *work)
        if (ret < 0) {
                dev_err(ucsi->dev, "%s: GET_CONNECTOR_STATUS failed (%d)\n",
                        __func__, ret);
+               clear_bit(EVENT_PENDING, &con->ucsi->flags);
                goto out_unlock;
        }