> I think the suggestion that has the closet fit with what we're trying > to accomplish is Ingo's (or perhaps Ingo's explanation of Alan's): > http://lkml.org/lkml/2010/5/28/106 where it's implemented as a > constraint of some sort. I think we ended up in the same place on our own. > Arve points out that qos constraint objects could work (but not if > specifically tied to apps): http://lkml.org/lkml/2010/5/28/120 though > he suggests that "latency" constraints don't represent this as well as > "state" constraints. With latency you have an "I don't give damn" latency in your model which we could describe as infinite or "manyana" perhaps. > Though if you look at it that way, then suspend_blockers become qos > constraint objects, but their implementation and usage remain pretty > much the same as we have now, which does not address Alan's concern > regarding code turning up in drivers, etc. I'm not sure how you can > solve this problem (avoiding races around entering/exiting the suspend > or suspend-like state) without having a means for drivers to prevent > entry to that state. I am much much less concerned about general expressions of constraint appearing in drivers. One of my early mails gave a list of other people/projects/problems that need them - from hard real time, to high speed serial on low end embedded to virtualisation. They fix a general problem in terms of a driver specific item. We end up making changes around the tree but we make everyone happy not just Android. Also we are isolating policy properly. The apps and drivers say "I have these needs", the power manager figures out how to meet them. Where it gets ugly is if you start trying to have drivers giving an app a guarantee which the app then magically has to know to dispose of. If you are prepared to exclude untrusted apps from perfectly reliable event reporting (ie from finger to application action) that doesn't seem to be a neccessity anyway. > livelock/deadlock/priority-inversion style issues due to interaction > between different processes in different groups. Priority inversion with the cgroup case is like synchronization effects with the suspend blockers - its a real ugly problem and one that is known to be hard to fix if you let it happen so I agree there. _______________________________________________ linux-pm mailing list linux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linux-foundation.org/mailman/listinfo/linux-pm