From: Andreas Kemnade <akemnade@kernel.org>
To: Ivaylo Dimitrov <ivo.g.dimitrov.75@gmail.com>
Cc: Tomi Valkeinen <tomi.valkeinen@ideasonboard.com>,
Maarten Lankhorst <maarten.lankhorst@linux.intel.com>,
Maxime Ripard <mripard@kernel.org>,
Thomas Zimmermann <tzimmermann@suse.de>,
David Airlie <airlied@gmail.com>, Simona Vetter <simona@ffwll.ch>,
Sebastian Reichel <sebastian.reichel@collabora.com>,
Laurent Pinchart <laurent.pinchart@ideasonboard.com>,
Tony Lindgren <tony@atomide.com>,
Linux-OMAP <linux-omap@vger.kernel.org>,
Marek Vasut <marex@denx.de>,
"H. Nikolaus Schaller" <hns@goldelico.com>,
dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org,
Tomi Valkeinen <tomi.valkeinen@ti.com>,
Andreas Kemnade <andreas@kemnade.info>
Subject: Re: [PATCH] drm/omap: dsi: avoid sending bta sync all the time in writes
Date: Thu, 28 May 2026 19:02:34 +0200 [thread overview]
Message-ID: <20260528190234.4c00b740@kernel.org> (raw)
In-Reply-To: <ec1a577b-12fb-402c-9ceb-3c1e8265a7e9@gmail.com>
Hi,
so this droid4? Or which device is it?
On Thu, 28 May 2026 17:44:14 +0300
Ivaylo Dimitrov <ivo.g.dimitrov.75@gmail.com> wrote:
> Applied against 6.18.31, no dice :)
>
> [ 11.617523] [drm] Initialized pvr 1.17.4948957 for 56000000.gpu on
> minor 0
> [ 11.674652] omapdss_dss 58000000.dss: bound 58001000.dispc (ops
> dispc_component_ops [omapdrm])
> [ 11.775085] omapdss_dss 58000000.dss: bound 58001000.dispc (ops
> dsi_vc_flush_receive_data [omapdrm])
> [ 12.222930] omapdss_dss 58000000.dss: bound 58001000.dispc (ops
> dsi_vc_flush_receive_data [omapdrm])
> [ 12.245117] omapdss_dss 58000000.dss: bound 58001000.dispc (ops
> dsi_vc_flush_receive_data [omapdrm])
> [ 12.247375] omapdss_dss 58000000.dss: bound 58004000.encoder (ops
> dsi_vc_flush_receive_data [omapdrm])
> [ 12.249267] omapdss_dss 58000000.dss: bound 58006000.encoder (ops
> dsi_vc_flush_receive_data [omapdrm])
> [ 12.284729] [drm] Initialized omapdrm 1.0.0 for omapdrm.0 on minor 1
> [ 12.311981] [drm] Enabling DMM ywrap scrolling
I would expect some
output from the panel-dsi-cm driver:
dev_info(&ddata->dsi->dev, "panel revision %02x.%02x.%02x\n",
id1, id2, id3);
or some error:
dev_err(&ddata->dsi->dev, "error while enabling panel, issuing HW reset\n");
Any explanation why it is missing?
> [ 12.770385] omapdrm omapdrm.0: atomic complete timeout (pipe 0)!
> [ 22.901306] omapdrm omapdrm.0: [drm] *ERROR* flip_done timed out
> [ 22.901306] omapdrm omapdrm.0: [drm] *ERROR* [CRTC:67:crtc-0] commit
> wait timed out
looks like dsi is not involed here, so something else is producing problems?
> [ 33.131256] omapdrm omapdrm.0: [drm] *ERROR* flip_done timed out
> [ 33.131378] omapdrm omapdrm.0: [drm] *ERROR* [CONNECTOR:66:DSI-1]
> commit wait timed out
This might have something to do with the patch.
> [ 43.371307] omapdrm omapdrm.0: [drm] *ERROR* flip_done timed out
> [ 43.371398] omapdrm omapdrm.0: [drm] *ERROR* [PLANE:34:plane-0]
> commit wait timed out
> [ 43.631408] omapdrm omapdrm.0: atomic complete timeout (pipe 0)!
> [ 43.692504] omapdrm omapdrm.0: [drm] fb0: omapdrmdrmfb frame buffer
> device
> [ 54.251342] omapdrm omapdrm.0: [drm] *ERROR* flip_done timed out
> [ 54.251464] omapdrm omapdrm.0: [drm] *ERROR* [CRTC:67:crtc-0] commit
> wait timed out
> [ 64.491302] omapdrm omapdrm.0: [drm] *ERROR* flip_done timed out
> [ 64.491424] omapdrm omapdrm.0: [drm] *ERROR* [CONNECTOR:66:DSI-1]
> commit wait timed out
> [ 74.731323] omapdrm omapdrm.0: [drm] *ERROR* flip_done timed out
> [ 74.731445] omapdrm omapdrm.0: [drm] *ERROR* [PLANE:34:plane-0]
> commit wait timed out
> [ 74.991363] omapdrm omapdrm.0: atomic complete timeout (pipe 0)!
> [ 85.621307] omapdrm omapdrm.0: [drm] *ERROR* flip_done timed out
> [ 85.621398] omapdrm omapdrm.0: [drm] *ERROR* [CRTC:67:crtc-0] commit
> wait timed out
> [ 95.851287] omapdrm omapdrm.0: [drm] *ERROR* flip_done timed out
> [ 95.851379] omapdrm omapdrm.0: [drm] *ERROR* [CONNECTOR:66:DSI-1]
> commit wait timed out
> [ 106.101257] omapdrm omapdrm.0: [drm] *ERROR* flip_done timed out
> [ 106.101440] omapdrm omapdrm.0: [drm] *ERROR* [PLANE:34:plane-0]
> commit wait timed out
> [ 106.371459] omapdrm omapdrm.0: atomic complete timeout (pipe 0)!
> [ 106.961334] omapdrm omapdrm.0: atomic complete timeout (pipe 0)!
> [ 141.301269] omapdrm omapdrm.0: [drm] *ERROR* flip_done timed out
> [ 141.301269] omapdrm omapdrm.0: [drm] *ERROR* [CRTC:67:crtc-0] commit
> wait timed out
> [ 151.531280] omapdrm omapdrm.0: [drm] *ERROR* flip_done timed out
> [ 151.531402] omapdrm omapdrm.0: [drm] *ERROR* [CONNECTOR:66:DSI-1]
> commit wait timed out
>
>
Thanks for testing.
Regards,
Andreas
> On 28.05.26 г. 13:16 ч., akemnade@kernel.org wrote:
> > From: Andreas Kemnade <andreas@kemnade.info>
> >
> > Some chips need configuration commands to be sent first, before they can
> > send data. TC358762 for example needs PPI_LPTXTIMECNT configured
> > and PPI_STARTPPI set to 1 to be able to transmit anything. To be able to
> > configure such chips, do not send bta sync during writes if no acks are
> > requested. Instead just wait for the packet to be sent to avoid FIFO
> > overflows. There might be more to do about acks, but there seem to be
> > virtually no users of that flag.
> >
> > This came to light when fiddling with the Epson Moverio BT-200 display
> > which consists of 2 TC358762 bridges with SPI funneled through
> > to the unknown display chip. With that patch the bridge can be accessed,
> > Reading back registers works, when the above-mentioned registers are set.
> >
> > Video mode panel at OMAP4 (BT-200) and video mode at OMAP5 was tested.
> >
> > Fixes: e70965386353e ("drm/omap: dsi: simplify write function")
> > Signed-off-by: Andreas Kemnade <andreas@kemnade.info>
> > ---
> > This was not tested on any command mode display, which IMHO should be
> > done. So droid4 folks: please give it a try
> > ---
> > drivers/gpu/drm/omapdrm/dss/dsi.c | 32 +++++++++++++++++++++++---------
> > 1 file changed, 23 insertions(+), 9 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/omapdrm/dss/dsi.c b/drivers/gpu/drm/omapdrm/dss/dsi.c
> > index 27fe7bca9e2cf..98362b0157023 100644
> > --- a/drivers/gpu/drm/omapdrm/dss/dsi.c
> > +++ b/drivers/gpu/drm/omapdrm/dss/dsi.c
> > @@ -2194,6 +2194,7 @@ static int dsi_vc_send_null(struct dsi_data *dsi, int vc, int channel)
> > static int dsi_vc_write_common(struct omap_dss_device *dssdev, int vc,
> > const struct mipi_dsi_msg *msg)
> > {
> > + DECLARE_COMPLETION_ONSTACK(completion);
> > struct dsi_data *dsi = to_dsi_data(dssdev);
> > int r;
> >
> > @@ -2205,17 +2206,30 @@ static int dsi_vc_write_common(struct omap_dss_device *dssdev, int vc,
> > if (r < 0)
> > return r;
> >
> > - /*
> > - * TODO: we do not always have to do the BTA sync, for example
> > - * we can improve performance by setting the update window
> > - * information without sending BTA sync between the commands.
> > - * In that case we can return early.
> > - */
> > + /* wait for IRQ for long packet transmission confirmation */
> > + r = dsi_register_isr_vc(dsi, vc, dsi_completion_handler,
> > + &completion, DSI_VC_IRQ_PACKET_SENT);
> > + if (r)
> > + return r;
> >
> > - r = dsi_vc_send_bta_sync(dssdev, vc);
> > - if (r) {
> > - DSSERR("bta sync failed\n");
> > + if (wait_for_completion_timeout(&completion,
> > + msecs_to_jiffies(500)) == 0)
> > + r = -EIO;
> > +
> > + dsi_unregister_isr_vc(dsi, vc, dsi_completion_handler,
> > + &completion, DSI_VC_IRQ_PACKET_SENT);
> > +
> > + if (r)
> > return r;
> > +
> > + /* TODO: find out if more needs to be done for MIPI_DIS_MSG_REQ_ACK */
> > +
> > + if (msg->flags & MIPI_DSI_MSG_REQ_ACK) {
> > + r = dsi_vc_send_bta_sync(dssdev, vc);
> > + if (r) {
> > + DSSERR("bta sync failed\n");
> > + return r;
> > + }
> > }
> >
> > /* RX_FIFO_NOT_EMPTY */
> >
> > ---
> > base-commit: e7ae89a0c97ce2b68b0983cd01eda67cf373517d
> > change-id: 20260528-vm-upstr-c8e7634ebf56
> >
> > Best regards,
> > --
> > Andreas Kemnade <akemnade@kernel.org>
> >
> >
>
>
next prev parent reply other threads:[~2026-05-28 17:02 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-05-28 10:16 [PATCH] drm/omap: dsi: avoid sending bta sync all the time in writes akemnade
2026-05-28 14:44 ` Ivaylo Dimitrov
2026-05-28 17:02 ` Andreas Kemnade [this message]
2026-05-28 17:43 ` Ivaylo Dimitrov
2026-05-28 20:06 ` Andreas Kemnade
2026-05-28 20:19 ` Andreas Kemnade
2026-05-29 6:26 ` Ivaylo Dimitrov
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=20260528190234.4c00b740@kernel.org \
--to=akemnade@kernel.org \
--cc=airlied@gmail.com \
--cc=andreas@kemnade.info \
--cc=dri-devel@lists.freedesktop.org \
--cc=hns@goldelico.com \
--cc=ivo.g.dimitrov.75@gmail.com \
--cc=laurent.pinchart@ideasonboard.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-omap@vger.kernel.org \
--cc=maarten.lankhorst@linux.intel.com \
--cc=marex@denx.de \
--cc=mripard@kernel.org \
--cc=sebastian.reichel@collabora.com \
--cc=simona@ffwll.ch \
--cc=tomi.valkeinen@ideasonboard.com \
--cc=tomi.valkeinen@ti.com \
--cc=tony@atomide.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