Laurent Pinchart wrote: > Hi Mark, Hi Laurent, others, > On Thursday 25 November 2010 14:49:08 Mark Brown wrote: >> On Thu, Nov 25, 2010 at 03:28:12AM +0100, Laurent Pinchart wrote: >>> If the entity is of node type, the power change is distributed to >>> all connected entities. For non-nodes it only affects that very >>> node. A mutex is used to serialise access to the entity graph. >> >> ASoC has its own power management stuff which doesn't *quite* map onto >> this one as-is. The power determination stuff is essentially identical >> (and this is actually nicer) but we have a separate postprocessing stage >> that actually applies the changes in a sequence which minimises audible >> issues caused by doing things in a bad order (eg, power down a PGA >> before you turn off inputs). This is noddy enough to implement, though >> - we just need a pre and post run notifications to set up and implement >> the changes I think. > > That sounds feasible. Sakari, you've implemented power management, what do you > think about this ? I first have to admit that I don't know ALSA almost at all. Currently when two media entities are connected they will be powered up for the duration of the link setup, just in case the drivers would need to access hardware for some reason. I don't think we have a need for that at the moment, it's so just because it seemed to be the right thing to do. Essentially the idea is that the drivers do not need to be involved with the power state handling and the device would be powered always when they are run, but not be powered when it's not necessary. That feature put aside, then what's left is what Laurent described; the entities will be powered up based on opening subdev and video nodes (V4L2 case, for ALSA it'd be different kind of ALSA nodes). But I don't think there's necessarily even need to remove this feature. Subdev is a V4L2 specific concept and I don't know if ALSA would benefit from something similar. If you want to be able to access the individual enties from user space, then similar arrangement might be useful. There are use cases to only use subdev nodes on V4L2: camera LED flash in torch mode, for example. There is no need to power on the rest of the system. I don't see a problem in applying restrictions on power on / off sequence. They would probably be useful also on the V4L2 side in the future. Could the restrictions be described as dependencies only, i.e. entity 1 power-up requires entity 2 to be powered first, also meaning that entity 2 could be powered down only after entity 1 has been powered down? This type of restrictions would fit quite well to the current model as it would essentially mean just media_entity_get() for the dependent entities, and media_entity_put() when the original entity is powered down. This would work recursively. In the case of audio, most if not all devices (right?) would be always powered up in certain order. At the same time this would be good for the flash in torch mode case. Comments, opinions? :-) Best regards, -- Sakari Ailus sakari.ailus@xxxxxxxxxxxxxxxxxxxxxxxxxx -- To unsubscribe from this list: send the line "unsubscribe linux-media" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html