[PATCH 1/5] dt-bindings: display: panel: Update NewVision NV3051D compatibles
Rob Herring
robh at kernel.org
Tue Oct 24 11:27:55 PDT 2023
On Thu, Oct 19, 2023 at 09:50:38AM -0500, Chris Morgan wrote:
> On Thu, Oct 19, 2023 at 11:22:19AM +0200, Krzysztof Kozlowski wrote:
> > On 18/10/2023 18:18, Chris Morgan wrote:
> > > From: Chris Morgan <macromorgan at hotmail.com>
> > >
> > > Update the NewVision NV3051D compatible strings by adding a new panel,
> > > the powkiddy,rk2023-panel, and removing another entry, the
> > > anbernic,rg353v-panel. The rg353v-panel is exactly identical to the
> > > rg353p-panel and is not currently in use by any existing device tree.
> > > The rk2023-panel is similar to the rg353p-panel but has slightly
> > > different timings.
> >
> > This still does not explain me why do you want to remove old panel.
>
> When I originally wrote the driver I only had one piece of hardware
> and I set the compatible string in the driver as newvision,nv3051d.
> Unfortunately since then I've found 2 more devices in use that are
> *just* different enough to require the driver to do things a bit
> differently. In the case of the anbernic,rg351v-panel I need to
> enable a new DSI flag; in the case of the powkiddy,rk2023-panel I need
> to decrease the vertical back porch and drop the higher frequency
> timings.
>
> The best way to accomplish this was to change the strategy from having
> a single binding in the driver of newvision,nv3051d to a binding for
> each distinct hardware where the differences apply.
Exactly why the DT maintainers annoyingly ask for specific compatible
strings which may not be used immediately.
> Note that I've
> looked at querying the DSI panel ID, but for each device the value
> is identical (so it can't be used to differentiate the hardware sadly).
> So the driver now has 3 different compatible strings. I could in this
> case add a 4th compatible string of anbernic,rg353v-panel but it would
> be identical to anbernic,rg353p-panel. For the moment we are using
> anbernic,rg353p-panel everywhere (including the rg353v), so it makes
> sense to drop this unused value while we can, at least to me.
Your reasoning is the compatible string is unused, so remove it.
If there's some reasoning about how the 2 panels are the same hardware
or the rg353v is never going to be used or show up at some point, then
that would be a reason to remove.
You could also say the rg353v is just wrong because it should have a
fallback compatible to rg353p and rather than fix it, just remove it
for now since there are no known users of it.
Rob
More information about the Linux-rockchip
mailing list