On Tue, Oct 30, 2012 at 05:16:42PM +0200, Felipe Balbi wrote: > On Tue, Oct 30, 2012 at 02:07:15PM +0000, Mark Brown wrote: > > > and all of that SoC-specific detail is already hidden behind power > > > domains, runtime PM, pinctrl, clk API, regulator framework, etc. > > That's all getting rather open coded, especially if you're going to get > > down to a situation where you have varying ordering constraints between > > the different APIs on different SoCs. > however we need to consider those cases right ? Otherwise we will endup > pushing something to mainline which will have to be reverted couple > weeks later after a big rant from Linus ;-) I'm not sure there's much risk of that either way; if anything it seems like it ought to be cleaner to have the stuff owned by the SoCs. > > > and this is one of the issues we're all trying to solve today so we have > > > single zImage approach for the ARM port. > > I don't see the relevance of single zImage here; device tree is supposed > > to solve that one. > DT is part of the deal. DT alone will solve nothing. If DT isn't relevant I'm not sure what you're saying about single zImage? The only relevance I can see for that is the data and configuration bloating the kernel, something that DT is supposed to address - this is the main use case where DT has benefits. > > Well, nothing's going to stop that happening if people are determined > > enough - one could equally see that there'll be flags getting passed to > > control the ordering of calls if things are open coded. I would expect > > that with a power domain style approach any data would be being passed > > directly and bypassing the driver completely. > situations like that would be a lot more rare in open coded case, don't > you think ? Also a lot more local, since they will show up on a driver > source code which is used in a small set of use cases, instead of being > part of the pm domain implementation for the entire platform. I don't see how open coding helps prevent people doing silly things, it seems like it'd have at most neutral impact (and of course it does require going round all the drivers every time someone comes up with a new idea for doing things which is a bit tedious). > > Essentially all the patches I'm seeing adding pinctrl are totally > > mindless, most of them are just doing the initial setup on boot and not > > doing any active management at runtime at all. > have you considered that might be just a first step ? I have mentioned > this before. We first add the bare minimum and work on PM optimizations > later. You can be sure most likely those mindless patches you're seeing > are probably building blocks for upcoming patches adding sleep/idle > modes. The sleep/idle modes are just a basic extension of the same idea, I'd not anticipate much difference there (and indeed anything where pinmux power saving makes a meaningful impact will I suspect need to be using runtime PM to allow SoC wide power savings anyway). > > A big part of my point here is that it's not at all clear to me that it > > is the driver which knows what's going on. For SoC-specific IPs you can > > be confident about how the SoC integration looks but for IPs that get > > reused widely this becomes less true. > I don't think so. As long as we keep the meaning of the 'default' > pinctrl state to mean that this is the working state for the IP, > underlying pinctrl-$arch implementation should know how to set muxing up > properly, no ? But then this comes round to the mindless code that ought to be factored out :) Only the more interesting cases that do something unusual really register here.
Attachment:
signature.asc
Description: Digital signature