On Tuesday 06 of August 2013 15:09:46 Doug Anderson wrote: > Tomasz, > > On Tue, Aug 6, 2013 at 2:58 PM, Tomasz Figa <tomasz.figa@xxxxxxxxx> wrote: > >> +static int dw_mci_exynos_resume_noirq(struct device *dev) > >> +{ > >> + struct dw_mci *host = dev_get_drvdata(dev); > >> + u32 clksel; > >> + > >> + clksel = mci_readl(host, CLKSEL); > >> + if (clksel & SDMMC_CLKSEL_WAKEUP_INT) > >> + mci_writel(host, CLKSEL, clksel); > > > > What about clock gating? Will the clock used for clocking this > > register be always enabled when this gets called? > > Since this is just accessing and writing a register in the "Mobile > Storage Host" block, I'd imagine that this should be the "biu" (bus > interface unit) clock, right? The dw_mmc code grabs the biu clock at > probe time and never lets it go. That means that we're OK as long as > common clock framework has already restored clocks to normal operation > by this time. > > Do you think that common clock framework might not have put the clocks > back into order by the time "noirq" callbacks are executed? Ahh, so the dw_mmc driver doesn't do any clock gating? This is not very nice of it. Well, in this case your patch is OK, but possibly some clock gating will have to be added to this driver at some point of time. Anyway: Reviewed-by: Tomasz Figa <t.figa@xxxxxxxxxxx> Best regards, Tomasz -- 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