Re: [linux-sunxi] Re: [PATCH RFC] drm/sun4i: rgb: Add 5% tolerance to dot clock frequency check
From: Chen-Yu Tsai
Date: Fri Feb 24 2017 - 05:20:44 EST
On Fri, Feb 24, 2017 at 5:51 PM, Lucas Stach <l.stach@xxxxxxxxxxxxxx> wrote:
> +CC Thierry, as the drm_panel maintainer.
>
> Am Donnerstag, den 23.02.2017, 10:54 -0500 schrieb Sean Paul:
>> On Wed, Dec 07, 2016 at 11:48:55AM +0200, Laurent Pinchart wrote:
>> > Hello,
>> >
>> > On Wednesday 07 Dec 2016 10:26:25 Chen-Yu Tsai wrote:
>> > > On Wed, Dec 7, 2016 at 1:29 AM, Maxime Ripard wrote:
>> > > > On Thu, Nov 24, 2016 at 07:22:31PM +0800, Chen-Yu Tsai wrote:
>> > > >> The panels shipped with Allwinner devices are very "generic", i.e.
>> > > >> they do not have model numbers or reliable sources of information
>> > > >> for the timings (that we know of) other than the fex files shipped
>> > > >> on them. The dot clock frequency provided in the fex files have all
>> > > >> been rounded to the nearest MHz, as that is the unit used in them.
>> > > >>
>> > > >> We were using the simple panel "urt,umsh-8596md-t" as a substitute
>> > > >> for the A13 Q8 tablets in the absence of a specific model for what
>> > > >> may be many different but otherwise timing compatible panels. This
>> > > >> was usable without any visual artifacts or side effects, until the
>> > > >> dot clock rate check was added in commit bb43d40d7c83 ("drm/sun4i:
>> > > >> rgb: Validate the clock rate").
>> > > >>
>> > > >> The reason this check fails is because the dotclock frequency for
>> > > >> this model is 33.26 MHz, which is not achievable with our dot clock
>> > > >> hardware, and the rate returned by clk_round_rate deviates slightly,
>> > > >> causing the driver to reject the display mode.
>> > > >>
>> > > >> The LCD panels have some tolerance on the dot clock frequency, even
>> > > >> if it's not specified in their datasheets.
>> > > >>
>> > > >> This patch adds a 5% tolerence to the dot clock check.
>> > > >
>> > > > As we discussed already, I really believe this is just as arbitrary as
>> > > > the current behaviour.
>> > >
>> > > Yes. I agree. This patch is mainly to give something that works for
>> > > people who don't care about the details, and to get some feedback
>> > > from people that do.
>> > >
>> > > > Some panels require an exact frequency,
>> >
>> > There's no such thing as an exact frequency, there will always be some
>> > tolerance (and if your display controller can really generate an exact
>> > frequency I'd be very interested in that hardware :-)).
>>
>> There is such thing as exact frequency when you have to worry about panel
>> warranty. We are fortunate, since we can talk to the panel manufacturer and
>> discuss which frequencies are tolerable inside the warranty. We usually hand
>> pick a rate/mode within these constraints.
>>
>> Also, even though things *look* ok on the panel at a certain clock rate, running
>> outside the specified clock could damage the hardware.
>>
>> I don't think it's unreasonable to add tolerances to drm_panel, since they will
>> differ in what is acceptable. The tricky part is teasing out what the tolerances
>> are.
>
> The drm_panel already allows to specify all panel timings in pairs of
> min/typical/max. Just use this instead of some arbitrary tolerance.
>
> I know most panels currently only expose a fixed mode, but it's not hard
> to convert this into a display_timing if you can get hold of the display
> datasheet. A lot of the panel datasheets I had to deal with lately
> actually specify all the required information. Most of the time you need
> to sanity check things, as most vendors seem to produce them by "copy
> the last datasheet we made and change only necessary fields", but that
> really isn't a hard job.
I wish it were that easy to identify panels and find datasheets, especially
when the vendors themselves use whatever cheap panel they can get their hands
on. Think no-brand cheap tablets from Aliexpress. These cheap panels may have
some model-number-like markings on them, but Googling fails to produce anything,
other than more vendors/items on Aliexpress.
Take the Q8 tablets with Allwinner SoCs in them. We have no idea what
panel the vendors use, and panels even vary between batches. We're using
the urt,umsh-8596md series of compatibles, which seems to have compatible
timings. Now the datasheet I found for them [1] just lists a typical
frequency for the pixel clock, and no min/max values. The typical frequency
is unachievable, for reasons already explained in the commit message.
Another example would be the LG LP079X01 or Auo B079XAN01 DSI panels, which
supposedly were also used in the 1st gen. iPad Minis. I found datasheets for
both [2][3], but neither lists tolerances for the dot clock.
So we're back to where we started. What is a reasonable tolerance to set in
the driver if we don't know the tolerances of the panel?
Regards
ChenYu
[1] http://www.udoo.org/download/files/datasheets/datasheet7.pdf
[2] http://recomit.de/service_manuals/LP079X01-SMA1.pdf
[3] http://img.jdzj.com/UserDocument/2012Y/hxzczmf/Document/20121229105325.pdf