From: Maxime Ripard <maxime@cerno.tech>
To: "Noralf Trønnes" <noralf@tronnes.org>
Cc: robh+dt@kernel.org, thierry.reding@gmail.com, sam@ravnborg.org,
dave.stevenson@raspberrypi.com, david@lechnology.com,
devicetree@vger.kernel.org, dri-devel@lists.freedesktop.org
Subject: Re: [PATCH v2 3/3] drm/panel: Add MIPI DBI compatible SPI driver
Date: Wed, 2 Feb 2022 11:09:53 +0100 [thread overview]
Message-ID: <20220202100953.pymb6blsqlaw7jv6@houat> (raw)
In-Reply-To: <fff71d01-e1c9-2b0f-e4b2-9abb107f7770@tronnes.org>
[-- Attachment #1: Type: text/plain, Size: 3571 bytes --]
On Thu, Jan 27, 2022 at 06:53:48PM +0100, Noralf Trønnes wrote:
> >> +struct panel_mipi_dbi_config {
> >> + /* Magic string: panel_mipi_dbi_magic */
> >> + u8 magic[15];
> >> +
> >> + /* Config file format version */
> >> + u8 file_format_version;
> >> +
> >> + /* Width in pixels */
> >> + __be16 width;
> >> + /* Height in pixels */
> >> + __be16 height;
> >> +
> >> + /* Width in millimeters (optional) */
> >> + __be16 width_mm;
> >> + /* Height in millimeters (optional) */
> >> + __be16 height_mm;
> >> +
> >> + /* X-axis panel offset */
> >> + __be16 x_offset;
> >> + /* Y-axis panel offset */
> >> + __be16 y_offset;
> >> +
> >> + /* 4 pad bytes, must be zero */
> >> + u8 pad[4];
> >> +
> >> + /*
> >> + * Optional MIPI commands to execute when the display pipeline is enabled.
> >> + * This can be used to configure the display controller.
> >> + *
> >> + * The commands are stored in a byte array with the format:
> >> + * command, num_parameters, [ parameter, ...], command, ...
> >> + *
> >> + * Some commands require a pause before the next command can be received.
> >> + * Inserting a delay in the command sequence is done by using the NOP command with one
> >> + * parameter: delay in miliseconds (the No Operation command is part of the MIPI Display
> >> + * Command Set where it has no parameters).
> >> + *
> >> + * Example:
> >> + * command 0x11
> >> + * sleep 120ms
> >> + * command 0xb1 parameters 0x01, 0x2c, 0x2d
> >> + * command 0x29
> >> + *
> >> + * Byte sequence:
> >> + * 0x11 0x00
> >> + * 0x00 0x01 0x78
> >> + * 0xb1 0x03 0x01 0x2c 0x2d
> >> + * 0x29 0x00
> >> + */
> >> + u8 commands[];
> >> +};
> >
> > I'm not really a fan of parsing raw data in the kernel. I guess we can't
> > really avoid the introduction of a special case to sleep, but we already
> > have dt properties for all of the other properties (but X and Y offset,
> > maybe?)
> >
> > Maybe we should use those instead?
>
> I don't understand your reluctance to parsing data, lots of ioctls do
> it.
The reluctance comes from the parsing itself: you need to have input
validation, and it's hard to get right. The less we have, the easier it
gets.
> And this data can only be loaded by root. What I like about having
> these properties in the config file is that the binding becomes a
> fallback binding that can actually be made to work without changing the
> Device Tree.
>
> For arguments sake let's say tiny/st7735r.c was not built and we had
> this node:
>
> display@0{
> compatible = "jianda,jd-t18003-t01", "sitronix,st7735r",
> "panel-mipi-dbi-spi";
> };
>
> It will still be possible to use this display without changing the
> Device Tree. Just add a firmware/config file.
>
> Having the properties in DT it would have to look like this for the
> fallback to work:
>
> display@0{
> compatible = "jianda,jd-t18003-t01", "sitronix,st7735r",
> "panel-mipi-dbi-spi";
> panel-timing = {
> hactive = <128>;
> vactive = <128>;
> };
> width-mm = <25>;
> height-mm = <26>;
> x-offset = <2>;
> y-offset = <3>;
> };
>
> Is this important, I'm not sure. What do you think?
Parts of it is ergonomics I guess. We're used to having all those
properties either in the DT or the driver, but here we introduce a new
way that isn't done anywhere else.
And I don't see any real downside to putting it in the DT? It's going to
be in an overlay, under the user's control anyway, right?
Maxime
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 228 bytes --]
next prev parent reply other threads:[~2022-02-02 10:10 UTC|newest]
Thread overview: 20+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-01-25 17:56 [PATCH v2 0/3] drm/panel: Add MIPI DBI compatible SPI driver Noralf Trønnes
2022-01-25 17:56 ` [PATCH v2 1/3] dt-bindings: display: add bindings for MIPI DBI compatible SPI panels Noralf Trønnes
2022-01-27 9:37 ` Maxime Ripard
2022-02-07 23:20 ` Rob Herring
2022-02-08 12:16 ` Noralf Trønnes
2022-02-09 9:04 ` Maxime Ripard
2022-02-09 12:29 ` Noralf Trønnes
2022-01-25 17:56 ` [PATCH v2 2/3] drm/mipi-dbi: Add driver_private member to struct mipi_dbi_dev Noralf Trønnes
2022-01-25 17:57 ` [PATCH v2 3/3] drm/panel: Add MIPI DBI compatible SPI driver Noralf Trønnes
2022-01-27 10:04 ` Maxime Ripard
2022-01-27 17:53 ` Noralf Trønnes
2022-02-02 10:09 ` Maxime Ripard [this message]
2022-02-02 13:53 ` Noralf Trønnes
2022-02-02 17:14 ` Sam Ravnborg
2022-02-03 15:06 ` Maxime Ripard
2022-01-27 17:19 ` David Lechner
2022-01-27 20:08 ` Noralf Trønnes
[not found] ` <YfL5ptT3Kw1ohC/1@ravnborg.org>
2022-01-27 20:26 ` Noralf Trønnes
2022-01-27 17:13 ` [PATCH v2 0/3] " David Lechner
2022-01-27 20:02 ` Noralf Trønnes
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=20220202100953.pymb6blsqlaw7jv6@houat \
--to=maxime@cerno.tech \
--cc=dave.stevenson@raspberrypi.com \
--cc=david@lechnology.com \
--cc=devicetree@vger.kernel.org \
--cc=dri-devel@lists.freedesktop.org \
--cc=noralf@tronnes.org \
--cc=robh+dt@kernel.org \
--cc=sam@ravnborg.org \
--cc=thierry.reding@gmail.com \
/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).