Re: [PATCH] fbdev: sh_mipi_dsi: add extra settings method for platform

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Jan 24, 2012 at 7:09 PM, Laurent Pinchart
<laurent.pinchart@xxxxxxxxxxxxxxxx> wrote:
> On Tuesday 24 January 2012 01:48:55 Kuninori Morimoto wrote:
>> Hi Laurent
>> Cc Magnus, Guennadi
>>
>> Thank you for checking patch
>
> You're welcome.
>
>> > > + void (*set_dcs)(int handle,
>> > > +                 int (*mipi_dcs)(int handle, u8 cmd),
>> > > +                 int (*mipi_dcs_param)(int handle, u8 cmd, u8 param));
>> >
>> > I don't think this is a good idea. First of all, we should reduce the
>> > number of board code callbacks to make transition to the device tree
>> > easier. Then, passing two functions to board code to read and write any
>> > device register without the driver having any knowledge about that is a
>> > clear violation of the device model, and will result in problems sooner
>> > or later.
>> >
>> > What MIPI settings do platforms need to modify ? Can those settings be
>> > expressed as data in the sh_mipi_dsi_info structure instead ?
>>
>> Hmm... now I'm in dilemma.
>> Actually this is v2 patch for mipi display.
>> (v1 patch was dropped since merge window issue)
>>
>> The v1 patch was data-table style for mipi display initialization.
>> (if platform had init data-table, driver used it)
>>
>> But someone reviewed it and teach me that it is not-good idea.
>> So, I created this style in v2.
>>
>> Now platform needs "backlight ON" and "memory write ON" command,
>> but I could not find these command on include/video/mipi_display.h.
>> So, I thought it is platform specific command.
>
> Why does the platform need that ? Please correct me if I'm wrong, but it seems
> to me that what you're trying to do is configure and control the display
> panel. I don't think that's platform-specific, it should be panel-specific
> instead. It looks to me like the right solution would be to write a display
> panel driver, similar to what is done for the OMAP2+ platform
> (drivers/video/omap2/displays).

I think that it is a very good recommendation to solve this in theory,
but in practice we've never really seen anyone use the same LCD module
and/or on-glass LCD controller for another board. What I've done so
far is to write the part number of the LCD module together with LCD
controller part number and hopefully also LCD panel configuration
together with the register settings so it is possible to search and
consolidate at some point when we have multiple users.

I'm not sure about this particular case, but I've seen quite much code
that just has a set of LCD controller register settings without
documentation, and it's kind of hard to turn that into a proper
driver. Especially since these register settings are both related to
the on-module LCD controller and LCD panel that together form a LCD
module. We usually don't know which setting is for what part. And we
probably would like to abstract the module into separate pieces of
code for different parts. I've seen some data sheet of a on-module LCD
controller and it was about 800 pages I believe, so it's not exactly
something you can cook up in an afternoon. And add closed MIPI specs
and all sorts of fun and this can take forever. =)

That aside, it would be really nice to see some proper drivers for LCD modules.

Cheers,

/ magnus
--
To unsubscribe from this list: send the line "unsubscribe linux-fbdev" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Video for Linux]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Tourism]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux