From: Bjorn Andersson <bjorn.andersson@linaro.org>
To: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Cc: dri-devel@lists.freedesktop.org, linux-arm-msm@vger.kernel.org,
Daniel Vetter <daniel@ffwll.ch>, David Airlie <airlied@linux.ie>,
Andrzej Hajda <a.hajda@samsung.com>,
Neil Armstrong <narmstrong@baylibre.com>,
Laurent Pinchart <Laurent.pinchart@ideasonboard.com>,
Jonas Karlman <jonas@kwiboo.se>,
Jernej Skrabec <jernej.skrabec@siol.net>,
Vinod Koul <vkoul@kernel.org>, Sam Ravnborg <sam@ravnborg.org>,
Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Subject: Re: [PATCH 2/2] drm/bridge/lontium-lt9611uxc: move HPD notification out of IRQ handler
Date: Thu, 14 Jan 2021 21:33:43 -0600 [thread overview]
Message-ID: <YAENF3G66CGFRQ68@builder.lan> (raw)
In-Reply-To: <20201127092316.122246-2-dmitry.baryshkov@linaro.org>
On Fri 27 Nov 03:23 CST 2020, Dmitry Baryshkov wrote:
> drm hotplug handling code (drm_client_dev_hotplug()) can wait on mutex,
> thus delaying further lt9611uxc IRQ events processing. It was observed
> occasionally during bootups, when drm_client_modeset_probe() was waiting
> for EDID ready event, which was delayed because IRQ handler was stuck
> trying to deliver hotplug event.
> Move hotplug notifications from IRQ handler to separate work to be able
> to process IRQ events without delays.
>
I see a couple of other drivers doing the same, and the patch looks
good.
Reviewed-by: Bjorn Andersson <bjorn.andersson@linaro.org>
Regards,
Bjorn
> Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
> ---
> drivers/gpu/drm/bridge/lontium-lt9611uxc.c | 30 +++++++++++++++++-----
> 1 file changed, 24 insertions(+), 6 deletions(-)
>
> diff --git a/drivers/gpu/drm/bridge/lontium-lt9611uxc.c b/drivers/gpu/drm/bridge/lontium-lt9611uxc.c
> index b708700e182d..88630bc2921f 100644
> --- a/drivers/gpu/drm/bridge/lontium-lt9611uxc.c
> +++ b/drivers/gpu/drm/bridge/lontium-lt9611uxc.c
> @@ -14,6 +14,7 @@
> #include <linux/regmap.h>
> #include <linux/regulator/consumer.h>
> #include <linux/wait.h>
> +#include <linux/workqueue.h>
>
> #include <sound/hdmi-codec.h>
>
> @@ -36,6 +37,7 @@ struct lt9611uxc {
> struct mutex ocm_lock;
>
> struct wait_queue_head wq;
> + struct work_struct work;
>
> struct device_node *dsi0_node;
> struct device_node *dsi1_node;
> @@ -52,6 +54,7 @@ struct lt9611uxc {
>
> bool hpd_supported;
> bool edid_read;
> + bool hdmi_connected;
> uint8_t fw_version;
> };
>
> @@ -151,15 +154,26 @@ static irqreturn_t lt9611uxc_irq_thread_handler(int irq, void *dev_id)
> }
>
> if (irq_status & BIT(1)) {
> - if (lt9611uxc->connector.dev)
> - drm_kms_helper_hotplug_event(lt9611uxc->connector.dev);
> - else
> - drm_bridge_hpd_notify(<9611uxc->bridge, !!(hpd_status & BIT(1)));
> + lt9611uxc->hdmi_connected = !!(hpd_status & BIT(1));
> + schedule_work(<9611uxc->work);
> }
>
> return IRQ_HANDLED;
> }
>
> +void lt9611uxc_hpd_work(struct work_struct *work)
> +{
> + struct lt9611uxc *lt9611uxc = container_of(work, struct lt9611uxc, work);
> +
> + if (lt9611uxc->connector.dev)
> + drm_kms_helper_hotplug_event(lt9611uxc->connector.dev);
> + else
> + drm_bridge_hpd_notify(<9611uxc->bridge,
> + lt9611uxc->hdmi_connected ?
> + connector_status_connected :
> + connector_status_disconnected);
> +}
> +
> static void lt9611uxc_reset(struct lt9611uxc *lt9611uxc)
> {
> gpiod_set_value_cansleep(lt9611uxc->reset_gpio, 1);
> @@ -447,7 +461,7 @@ static enum drm_connector_status lt9611uxc_bridge_detect(struct drm_bridge *brid
> struct lt9611uxc *lt9611uxc = bridge_to_lt9611uxc(bridge);
> unsigned int reg_val = 0;
> int ret;
> - int connected = 1;
> + bool connected = true;
>
> if (lt9611uxc->hpd_supported) {
> lt9611uxc_lock(lt9611uxc);
> @@ -457,8 +471,9 @@ static enum drm_connector_status lt9611uxc_bridge_detect(struct drm_bridge *brid
> if (ret)
> dev_err(lt9611uxc->dev, "failed to read hpd status: %d\n", ret);
> else
> - connected = reg_val & BIT(1);
> + connected = !!(reg_val & BIT(1));
> }
> + lt9611uxc->hdmi_connected = connected;
>
> return connected ? connector_status_connected :
> connector_status_disconnected;
> @@ -931,6 +946,8 @@ static int lt9611uxc_probe(struct i2c_client *client,
> lt9611uxc->fw_version = ret;
>
> init_waitqueue_head(<9611uxc->wq);
> + INIT_WORK(<9611uxc->work, lt9611uxc_hpd_work);
> +
> ret = devm_request_threaded_irq(dev, client->irq, NULL,
> lt9611uxc_irq_thread_handler,
> IRQF_ONESHOT, "lt9611uxc", lt9611uxc);
> @@ -967,6 +984,7 @@ static int lt9611uxc_remove(struct i2c_client *client)
> struct lt9611uxc *lt9611uxc = i2c_get_clientdata(client);
>
> disable_irq(client->irq);
> + flush_scheduled_work();
> lt9611uxc_audio_exit(lt9611uxc);
> drm_bridge_remove(<9611uxc->bridge);
>
> --
> 2.29.2
>
WARNING: multiple messages have this Message-ID (diff)
From: Bjorn Andersson <bjorn.andersson@linaro.org>
To: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Cc: Jernej Skrabec <jernej.skrabec@siol.net>,
Neil Armstrong <narmstrong@baylibre.com>,
David Airlie <airlied@linux.ie>,
linux-arm-msm@vger.kernel.org, Jonas Karlman <jonas@kwiboo.se>,
dri-devel@lists.freedesktop.org,
Andrzej Hajda <a.hajda@samsung.com>,
Vinod Koul <vkoul@kernel.org>,
Laurent Pinchart <Laurent.pinchart@ideasonboard.com>,
Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>,
Sam Ravnborg <sam@ravnborg.org>
Subject: Re: [PATCH 2/2] drm/bridge/lontium-lt9611uxc: move HPD notification out of IRQ handler
Date: Thu, 14 Jan 2021 21:33:43 -0600 [thread overview]
Message-ID: <YAENF3G66CGFRQ68@builder.lan> (raw)
In-Reply-To: <20201127092316.122246-2-dmitry.baryshkov@linaro.org>
On Fri 27 Nov 03:23 CST 2020, Dmitry Baryshkov wrote:
> drm hotplug handling code (drm_client_dev_hotplug()) can wait on mutex,
> thus delaying further lt9611uxc IRQ events processing. It was observed
> occasionally during bootups, when drm_client_modeset_probe() was waiting
> for EDID ready event, which was delayed because IRQ handler was stuck
> trying to deliver hotplug event.
> Move hotplug notifications from IRQ handler to separate work to be able
> to process IRQ events without delays.
>
I see a couple of other drivers doing the same, and the patch looks
good.
Reviewed-by: Bjorn Andersson <bjorn.andersson@linaro.org>
Regards,
Bjorn
> Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
> ---
> drivers/gpu/drm/bridge/lontium-lt9611uxc.c | 30 +++++++++++++++++-----
> 1 file changed, 24 insertions(+), 6 deletions(-)
>
> diff --git a/drivers/gpu/drm/bridge/lontium-lt9611uxc.c b/drivers/gpu/drm/bridge/lontium-lt9611uxc.c
> index b708700e182d..88630bc2921f 100644
> --- a/drivers/gpu/drm/bridge/lontium-lt9611uxc.c
> +++ b/drivers/gpu/drm/bridge/lontium-lt9611uxc.c
> @@ -14,6 +14,7 @@
> #include <linux/regmap.h>
> #include <linux/regulator/consumer.h>
> #include <linux/wait.h>
> +#include <linux/workqueue.h>
>
> #include <sound/hdmi-codec.h>
>
> @@ -36,6 +37,7 @@ struct lt9611uxc {
> struct mutex ocm_lock;
>
> struct wait_queue_head wq;
> + struct work_struct work;
>
> struct device_node *dsi0_node;
> struct device_node *dsi1_node;
> @@ -52,6 +54,7 @@ struct lt9611uxc {
>
> bool hpd_supported;
> bool edid_read;
> + bool hdmi_connected;
> uint8_t fw_version;
> };
>
> @@ -151,15 +154,26 @@ static irqreturn_t lt9611uxc_irq_thread_handler(int irq, void *dev_id)
> }
>
> if (irq_status & BIT(1)) {
> - if (lt9611uxc->connector.dev)
> - drm_kms_helper_hotplug_event(lt9611uxc->connector.dev);
> - else
> - drm_bridge_hpd_notify(<9611uxc->bridge, !!(hpd_status & BIT(1)));
> + lt9611uxc->hdmi_connected = !!(hpd_status & BIT(1));
> + schedule_work(<9611uxc->work);
> }
>
> return IRQ_HANDLED;
> }
>
> +void lt9611uxc_hpd_work(struct work_struct *work)
> +{
> + struct lt9611uxc *lt9611uxc = container_of(work, struct lt9611uxc, work);
> +
> + if (lt9611uxc->connector.dev)
> + drm_kms_helper_hotplug_event(lt9611uxc->connector.dev);
> + else
> + drm_bridge_hpd_notify(<9611uxc->bridge,
> + lt9611uxc->hdmi_connected ?
> + connector_status_connected :
> + connector_status_disconnected);
> +}
> +
> static void lt9611uxc_reset(struct lt9611uxc *lt9611uxc)
> {
> gpiod_set_value_cansleep(lt9611uxc->reset_gpio, 1);
> @@ -447,7 +461,7 @@ static enum drm_connector_status lt9611uxc_bridge_detect(struct drm_bridge *brid
> struct lt9611uxc *lt9611uxc = bridge_to_lt9611uxc(bridge);
> unsigned int reg_val = 0;
> int ret;
> - int connected = 1;
> + bool connected = true;
>
> if (lt9611uxc->hpd_supported) {
> lt9611uxc_lock(lt9611uxc);
> @@ -457,8 +471,9 @@ static enum drm_connector_status lt9611uxc_bridge_detect(struct drm_bridge *brid
> if (ret)
> dev_err(lt9611uxc->dev, "failed to read hpd status: %d\n", ret);
> else
> - connected = reg_val & BIT(1);
> + connected = !!(reg_val & BIT(1));
> }
> + lt9611uxc->hdmi_connected = connected;
>
> return connected ? connector_status_connected :
> connector_status_disconnected;
> @@ -931,6 +946,8 @@ static int lt9611uxc_probe(struct i2c_client *client,
> lt9611uxc->fw_version = ret;
>
> init_waitqueue_head(<9611uxc->wq);
> + INIT_WORK(<9611uxc->work, lt9611uxc_hpd_work);
> +
> ret = devm_request_threaded_irq(dev, client->irq, NULL,
> lt9611uxc_irq_thread_handler,
> IRQF_ONESHOT, "lt9611uxc", lt9611uxc);
> @@ -967,6 +984,7 @@ static int lt9611uxc_remove(struct i2c_client *client)
> struct lt9611uxc *lt9611uxc = i2c_get_clientdata(client);
>
> disable_irq(client->irq);
> + flush_scheduled_work();
> lt9611uxc_audio_exit(lt9611uxc);
> drm_bridge_remove(<9611uxc->bridge);
>
> --
> 2.29.2
>
_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel
next prev parent reply other threads:[~2021-01-15 3:34 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-11-27 9:23 [PATCH 1/2] drm/bridge/lontium-lt9611uxc: fix waiting for EDID to become available Dmitry Baryshkov
2020-11-27 9:23 ` Dmitry Baryshkov
2020-11-27 9:23 ` [PATCH 2/2] drm/bridge/lontium-lt9611uxc: move HPD notification out of IRQ handler Dmitry Baryshkov
2020-11-27 9:23 ` Dmitry Baryshkov
2021-01-15 3:33 ` Bjorn Andersson [this message]
2021-01-15 3:33 ` Bjorn Andersson
2021-01-05 17:20 ` [PATCH 1/2] drm/bridge/lontium-lt9611uxc: fix waiting for EDID to become available Dmitry Baryshkov
2021-01-05 17:20 ` Dmitry Baryshkov
2021-01-14 6:14 ` Laurent Pinchart
2021-01-14 6:14 ` Laurent Pinchart
2021-01-15 3:49 ` Bjorn Andersson
2021-01-15 3:49 ` Bjorn Andersson
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=YAENF3G66CGFRQ68@builder.lan \
--to=bjorn.andersson@linaro.org \
--cc=Laurent.pinchart@ideasonboard.com \
--cc=a.hajda@samsung.com \
--cc=airlied@linux.ie \
--cc=daniel@ffwll.ch \
--cc=dmitry.baryshkov@linaro.org \
--cc=dri-devel@lists.freedesktop.org \
--cc=jernej.skrabec@siol.net \
--cc=jonas@kwiboo.se \
--cc=linux-arm-msm@vger.kernel.org \
--cc=manivannan.sadhasivam@linaro.org \
--cc=narmstrong@baylibre.com \
--cc=sam@ravnborg.org \
--cc=vkoul@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.