[PATCH] MMC: move regulator handling closer to core v3
Adrian Hunter
adrian.hunter at nokia.com
Thu Sep 9 02:01:27 EDT 2010
ext Andrew Morton wrote:
> On Sun, 5 Sep 2010 11:05:38 +0200
> Linus Walleij <linus.walleij at stericsson.com> wrote:
>
>> After discovering a problem in regulator reference counting I
>> took Mark Brown's advice to move the reference count into the
>> MMC core by making the regulator status a member of
>> struct mmc_host.
>>
>>
>> ...
>>
>> -static inline void pxamci_set_power(struct pxamci_host *host, unsigned int vdd)
>> +static inline void pxamci_set_power(struct pxamci_host *host,
>> + unsigned char power_mode,
>> + unsigned int vdd)
>> {
>> int on;
>>
>> -#ifdef CONFIG_REGULATOR
>> - if (host->vcc)
>> - mmc_regulator_set_ocr(host->vcc, vdd);
>> -#endif
>> + if (host->vcc) {
>> + int ret;
>> +
>> + if (power_mode == MMC_POWER_UP)
>> + ret = mmc_regulator_set_ocr(host->mmc, host->vcc, vdd);
>> + else if (power_mode == MMC_POWER_OFF)
>> + ret = mmc_regulator_set_ocr(host->mmc, host->vcc, 0);
>> + }
>
> There's no point in copying the return value into a local then ignoring
> it. mmc_regulator_set_ocr() can return a negative errno so we should
> test for that, clean up and propagate the error.
>
> If we really do deliberately ignore the error then there should be a
> code comment which excuses this behaviour and perhaps a warning printk.
>
> The same comments apply to mmci_set_ios().
>
> omap_hsmmc_1_set_power() gets it right.
>
> Why doesn't omap_hsmmc_23_set_sleep() run .before_set_reg() and
> .after_set_reg()?
Mostly because the voltage does not change. The voltage regulator
switches to a low current mode that reduces leakage but the voltage
does not change.
As an aside, I would like to enhance the regulator framework to
enable boards to hook their code directly into the regulator.
Arguably this is essential to allow pbias configuration (without
which the board may be damaged) so that regulator_enable/disable
can be used independently of the board, or for example to allow
the regulator core to turn the regulator on/off at initialisation.
Anyway, if that was done .before/.after_set_reg would not be
needed anymore.
>
>> ...
>>
>
More information about the linux-arm-kernel
mailing list