Re: [PATCH] mmc: mmci: Add new VE MMCI variant

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 25 January 2013 10:35, Linus Walleij <linus.walleij@xxxxxxxxxx> wrote:
> On Thu, Jan 24, 2013 at 9:11 PM, Ulf Hansson <ulf.hansson@xxxxxxxxxx> wrote:
>> On 24 January 2013 18:12, Linus Walleij <linus.walleij@xxxxxxxxxx> wrote:
>
>>> We're talking about this I guess:
>>> http://marc.info/?l=linux-arm-kernel&m=123790711306850&w=4
>>>
>>> In these experiments I actually gated not only the
>>> enable bit (bit 8) to the MCI clock, but also the pclk to
>>> the PrimeCell itself as well. This was due to the U300
>>> clock framework doing that behind the scenes on
>>> clk_disable(host->clk);
>>>
>>> And the reason the clock framework was doing that
>>> was that the U300 had the block clock and the card
>>> clock wired to the same clock tap ...
>>> The equivalent patch today would also call
>>> amba_pclk_disable() when the card was inactive.
>>>
>>> Thus we also got rid of all the switching leaks in the PL180
>>> logic. (Containing two big state machines for example.)
>>>
>>> It was an interesting comparison to just enable PwrSave
>>> (bit 9) instead, and disable the other clock logic.
>>>
>>> It turned out that this saving was significantly bigger when
>>> gating the entire PrimeCell than the savings for just gating
>>> the clock out to the card itself with bit 9.
>>>
>>> But at this time I didn't have a card in the slot, so as to
>>> eliminate the power consumed in the card (assuming
>>> this would drown the overall current consumption).
>>>
>>> So I have second thoughts about this. The experiment
>>> was not testing the PwrSave bit with a card inserted, this
>>> is the wrong thing to do. To determine if that bit is a good
>>> thing to turn on, it needs to be tested with a card in the
>>> slot.
>>>
>>> The only really useful information is that the switching
>>> logic inside the PL180 synthesized IP-core consumes
>>> circa 200uA, so it could be useful to gate it at times.
>>
>> So in the runtime_pm callbacks, it you don't just want to do normal
>> clk gating/ungating with the clock API, which is done right now. You
>> also would like to actually gate the clock internally by using
>> clock/power register. Does that make sense?
>
> Well in the currently merged patches it will only cut of
> MCLK through the clock API right?
>
> Maybe it makes sense to also call amba_pclk_disable()
> in these hooks so as to propagate up and gate off the
> silicon pclk?

That is already taken care off in the amba bus. So no need to worry :-)

>
> In the ST case, with SDIO support and all, this can not be
> done on SDIO devices though, as that thing needs to
> react to IRQs, and thus the logic must always be clocked.
> But for blocks connected to cards/eMMCs where the device
> is essentially passive, it seems like the right thing to do.
>

You are right, but until/if we implement SDIO_IRQ support for mmci, we
don't have to bother.

Morover, if the SDIO IRQ is rerouted to a GPIO IRQ when going to
runtime_suspend it will do the trick.

> (Actually in a finer technology the power savings could of
> course be greater than 200uA for doing this.)
>

Yes, new measurements would be great to do.

> Yours,
> Linus Walleij

Kind regards
Ulf Hansson
--
To unsubscribe from this list: send the line "unsubscribe linux-mmc" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux USB Devel]     [Linux Media]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux