[PATCH] mmc: move regulator handling to core

Daniel Mack daniel at caiaq.de
Thu Dec 3 08:14:23 EST 2009


On Thu, Dec 03, 2009 at 01:06:27PM +0000, Mark Brown wrote:
> On Thu, Dec 03, 2009 at 01:46:30PM +0100, Daniel Mack wrote:
> > At the moment, regulator operations are done from individual mmc host
> > drivers. This is a problem because the regulators are not claimed
> > exclusively but the mmc core enables and disables them according to the
> 
> This is historical, they can all be converted to regulator_get_exclusive()
> so the move to the core (while good) isn't required for this reason.

Is it? What if you share one regulator for two slots? While this isn't a
problem I have met in real life, this should still be considered.

The problem I _did_ see, however, was a warning when the regulator was
marked as always_on in its constraints. What happens then is that
regulator_is_enabled() will always return 1, causing the pxamci code to

 - call regulator_disable() on power off, but
 - _not_ call regulator_enable() in the oposite case

and that brings the regulator's reference count out of sync.

Making those drivers claim their regulators exclusively _does_ solve the
first problem, but not the latter.

> >  	case MMC_POWER_OFF:
> > -		if(host->vcc &&
> > -		   regulator_is_enabled(host->vcc))
> > -			regulator_disable(host->vcc);
> > +		if(mmc->vcc && mmc->vcc_enabled) {
> > +			regulator_disable(mmc->vcc);
> > +			mmc->vcc_enabled = 0;
> > +		}
> 
> Can the MMC core actually tolerate the MMC power not getting killed when
> expected?  My understanding from previous discussion was that it wasn't
> able to do so.  If it is then conversion to using regulator_get_exclusive()
> isn't desirable, of course.

I would expect the power to be killed when the last user stops using it.
Which should result in the same effect if you only have one host, one
regulator, and one user.

Daniel




More information about the linux-arm-kernel mailing list