On Mon, Dec 5, 2011 at 5:50 PM, Mark Brown <broo...@opensource.wolfsonmicro.com> wrote:
> Enable and disable the clocks to the SPI controller using runtime PM. This > serves the dual purpose of reducing power consumption a little and letting > the core know when the device is idle. (...) > +#ifdef CONFIG_PM_RUNTIME > +static int s3c64xx_spi_runtime_suspend(struct device *dev) > +{ > + struct spi_master *master = spi_master_get(dev_get_drvdata(dev)); > + struct s3c64xx_spi_driver_data *sdd = spi_master_get_devdata(master); > + > + clk_disable(sdd->clk); > + clk_disable(sdd->src_clk); > + > + return 0; > +} > + > +static int s3c64xx_spi_runtime_resume(struct device *dev) > +{ > + struct spi_master *master = spi_master_get(dev_get_drvdata(dev)); > + struct s3c64xx_spi_driver_data *sdd = spi_master_get_devdata(master); > + > + clk_enable(sdd->src_clk); > + clk_enable(sdd->clk); > + > + return 0; > +} > +#endif /* CONFIG_PM_RUNTIME */ This is similar to how I'm doing things in my drivers so this looks good to me, Acked-by. Just wanted to mention that I had this discussion with Magnus Damm about how they do this in shmobile: in there their central runtime PM policy in arch/arm/mach-shmobile/pm_runtime.c adds in the pm_clk_notifier from drivers/base/power/clock_ops.c to gate/ungate the clocks centrally acting on bus notifiers without any per-driver hooks like these. I clearly see that in this platform it's *not* going to work since for this one driver atleast, there are two clocks, not just one, that need to be managed for the device. So I guess that some platforms will do central clock management and some will do driver-local management. I fear for the day one of these devices turn up in two platforms: one using central clock management and one using distributed clock management ... Yours, Linus Walleij -- To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html