From: Herve Codina <herve.codina@bootlin.com>
To: Alexander Stein <alexander.stein@ew.tq-group.com>
Cc: Andrzej Hajda <andrzej.hajda@intel.com>,
Neil Armstrong <neil.armstrong@linaro.org>,
Robert Foss <rfoss@kernel.org>,
Laurent Pinchart <Laurent.pinchart@ideasonboard.com>,
Jonas Karlman <jonas@kwiboo.se>,
Jernej Skrabec <jernej.skrabec@gmail.com>,
David Airlie <airlied@gmail.com>, Simona Vetter <simona@ffwll.ch>,
Maarten Lankhorst <maarten.lankhorst@linux.intel.com>,
Maxime Ripard <mripard@kernel.org>,
Thomas Zimmermann <tzimmermann@suse.de>,
Rob Herring <robh@kernel.org>,
Krzysztof Kozlowski <krzk+dt@kernel.org>,
Conor Dooley <conor+dt@kernel.org>, Marek Vasut <marex@denx.de>,
dri-devel@lists.freedesktop.org, devicetree@vger.kernel.org,
linux-kernel@vger.kernel.org,
Louis Chauvet <louis.chauvet@bootlin.com>,
Luca Ceresoli <luca.ceresoli@bootlin.com>,
Thomas Petazzoni <thomas.petazzoni@bootlin.com>
Subject: Re: [PATCH v3 3/3] drm: bridge: ti-sn65dsi83: Add error recovery mechanism
Date: Wed, 8 Jan 2025 18:44:42 +0100 [thread overview]
Message-ID: <20250108184442.64f38fbc@bootlin.com> (raw)
In-Reply-To: <115787605.nniJfEyVGO@steina-w>
Hi Alexander,
On Wed, 08 Jan 2025 11:54:49 +0100
Alexander Stein <alexander.stein@ew.tq-group.com> wrote:
[...]
> > #include <drm/drm_atomic_helper.h>
> > #include <drm/drm_bridge.h>
> > +#include <drm/drm_drv.h> /* DRM_MODESET_LOCK_ALL_BEGIN() needs drm_drv_uses_atomic_modeset() */
>
> Shouldn't this include be added to include/drm/drm_modeset_lock.h instead?
Yes indeed. I will change that in the next iteration.
>
> > #include <drm/drm_mipi_dsi.h>
> > #include <drm/drm_of.h>
> > #include <drm/drm_panel.h>
> > @@ -147,6 +150,9 @@ struct sn65dsi83 {
> > struct regulator *vcc;
> > bool lvds_dual_link;
> > bool lvds_dual_link_even_odd_swap;
> > + bool use_irq;
> > + struct delayed_work monitor_work;
> > + struct work_struct reset_work;
>
> Can you please rebase? You are missing commit d2b8c6d549570
> ("drm/bridge: ti-sn65dsi83: Add ti,lvds-vod-swing optional properties")
Sure, I will rebase.
[...]
> > +static void sn65dsi83_handle_errors(struct sn65dsi83 *ctx)
> > +{
> > + unsigned int irq_stat;
> > + int ret;
> > +
> > + /*
> > + * Schedule a reset in case of:
> > + * - the bridge doesn't answer
> > + * - the bridge signals an error
> > + */
> > +
> > + ret = regmap_read(ctx->regmap, REG_IRQ_STAT, &irq_stat);
> > + if (ret || irq_stat)
> > + schedule_work(&ctx->reset_work);
>
> Shouldn't you clear the error bits as well?
Thanks for pointing that.
I can clear the error bit but further more, I probably need to simply
disable the interrupt.
In some cases, we observed i2c access failure. In that cases clearing error
bits is simply not possible.
To avoid some possible interrupt storms (the chip detect a failure, set its
interrupt line but could be not accessible anymore), the best thing to do
is to disable the interrupt line here, let the reset work to do its job
performing a full reset of the device and re-enabling the interrupt line
when needed, probably in sn65dsi83_atomic_enable().
What do you think about that?
Best regards,
Hervé
next prev parent reply other threads:[~2025-01-08 17:44 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-01-08 10:18 [PATCH v3 0/3] Add support for errors recovery in the TI SN65DSI83 bridge driver Herve Codina
2025-01-08 10:19 ` [PATCH v3 1/3] dt-bindings: display: bridge: sn65dsi83: Add interrupt Herve Codina
2025-01-08 10:19 ` [PATCH v3 2/3] drm/vc4: Move reset_pipe() to an atomic helper Herve Codina
2025-01-14 7:34 ` Maxime Ripard
2025-01-08 10:19 ` [PATCH v3 3/3] drm: bridge: ti-sn65dsi83: Add error recovery mechanism Herve Codina
2025-01-08 10:54 ` Alexander Stein
2025-01-08 17:44 ` Herve Codina [this message]
2025-01-09 10:38 ` Herve Codina
2025-01-09 10:44 ` Alexander Stein
2025-01-09 10:49 ` Alexander Stein
2025-01-09 11:18 ` Herve Codina
2025-01-14 7:40 ` Maxime Ripard
2025-01-14 12:54 ` Herve Codina
2025-01-15 15:41 ` Herve Codina
2025-01-16 8:38 ` Maxime Ripard
2025-01-17 8:12 ` Herve Codina
2025-02-04 15:17 ` Maxime Ripard
2025-02-04 15:34 ` Herve Codina
2025-02-04 17:11 ` Maxime Ripard
2025-02-04 18:52 ` Herve Codina
2025-02-19 9:07 ` Maxime Ripard
2025-02-20 12:45 ` Herve Codina
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=20250108184442.64f38fbc@bootlin.com \
--to=herve.codina@bootlin.com \
--cc=Laurent.pinchart@ideasonboard.com \
--cc=airlied@gmail.com \
--cc=alexander.stein@ew.tq-group.com \
--cc=andrzej.hajda@intel.com \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=dri-devel@lists.freedesktop.org \
--cc=jernej.skrabec@gmail.com \
--cc=jonas@kwiboo.se \
--cc=krzk+dt@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=louis.chauvet@bootlin.com \
--cc=luca.ceresoli@bootlin.com \
--cc=maarten.lankhorst@linux.intel.com \
--cc=marex@denx.de \
--cc=mripard@kernel.org \
--cc=neil.armstrong@linaro.org \
--cc=rfoss@kernel.org \
--cc=robh@kernel.org \
--cc=simona@ffwll.ch \
--cc=thomas.petazzoni@bootlin.com \
--cc=tzimmermann@suse.de \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).