On 2013-02-14 11:43, Igor Grinberg wrote: >> True, it's generic, but does it work reliably? The panel hardware is now >> partly handled in the backlight driver, and partly in the omap's panel >> driver (and wherever on other platforms). > > It works reliably on other platforms, but not on OMAP - because > we need to cope with the OMAP specific framework... How do you handle the gpios on other platform? Those are the ones causing the issues here, right? Or is there something else with OMAP DSS that you need to specifically cope with? >> Thinking about it, if you do move the gpio handling to the backlight >> driver, the panel driver will only handle the DPI video stream. Then it >> should not have any effect on the SPI side (presuming the panel doesn't >> use the pixel clock as func clock), although there's probably still >> possibility for display artifacts on enable and disable, if the order of >> operations goes the wrong way. > > Yep, again, that is correct. It's correct that there may be artifacts? How do you manage the ordering of the operations on other platforms? >>> And since the toppoly was and is used on other systems, why the hell >>> should anyone duplicate the driver just to please the OMAP specific >>> panel framework? The real problem is that this framework should not be > >> Not to please. To make it reliable. > > Well, there are multiple ways to make it reliable. > And I don't think that the best would be: make it OMAP specific. I'm not saying it's the best option. I'm saying it's a realistic option to get it working. >> Well, if duplicating the code gives us reliable drivers, versus >> unreliable without duplicating, then... I don't see it as that bad. > > Hmmm... I don't think this fits the mainline (upstream) philosophy. > This can be also extrapolated into: let's make our own Linux ARM fork > so it will be more reliable... > This is the way how vendor specific kernel releases work. Well, we are talking about a smallish driver here. Not an arch fork. If the options are a) platform specific driver that works, or b) generic driver that's not reliable, or c) no driver at all, I can't really see why a) would be such a horrible option for the time being. But this discussion is getting a bit out of hand. It sounds to me that for this panel in question we can manage with the current approach, so this whole line of discussion doesn't matter for this specific problem. >> If it was easy, somebody would've done it. > > In fact this is done all the time on multiple drivers and frameworks. > Also, I don't say this is easy, but I also don't think this too hard. > It is also a function of resources (time/will/experience/etc.). I think the CDF discussions have already proven that it is quite hard. But feel free to contribute. And I've talked about a common display framework already years ago, and I've tried to design OMAP DSS panels from start in such a way that they try to depend on OMAP DSS features as little as possible, to make it easier to generalize them. Just to prove I'm not indifferent about the issue =). Tomi
Attachment:
signature.asc
Description: OpenPGP digital signature