On Mon, Jan 30, 2017 at 11:22:14AM -0800, Guenter Roeck wrote: > Maybe the additional calls make sense; I can imagine they would. > However, I personally would be a bit wary of changing the initialization > order of multi-clock initializations, and I am not sure how a single call > could address setting the rate ([devm_]clk_get_setrate_prepare_enable() > seems like a bit too much). > > [ On a side note, why is there no clk_get_prepare_enable() and > clk_get_prepare() ? Maybe it would be better to introduce those > together with the matching devm_ functions in a separate patch > if they are useful. ]
If you take the view that trying to keep clocks disabled is a good way to save power, then you'd have the clk_prepare() or maybe clk_prepare_enable() in your runtime PM resume handler, or maybe even deeper in the driver... the original design goal of the clk API was to allow power saving and clock control. With that in mind, getting and enabling the clock together in the probe function didn't make sense. I feel that aspect has been somewhat lost, and people now regard much of the clk API as a bit of a probe-time nusience. -- RMK's Patch system: http://www.armlinux.org.uk/developer/patches/ FTTC broadband for 0.8mile line: currently at 9.6Mbps down 400kbps up according to speedtest.net.