Hi Niklas, On Mon, Dec 19, 2016 at 5:39 PM, Niklas Söderlund <niklas.soderlund@xxxxxxxxxxxx> wrote: > On 2016-12-18 23:26:11 +0300, Sergei Shtylyov wrote: >> On 12/12/2016 07:09 PM, Niklas Söderlund wrote: >> > One quirk needed for WoL is that the module clock needs to be prevented >> > from being switched off by Runtime PM. To keep the clock alive the >> >> I tried to find the code in question and failed, getting muddled in the >> RPM maze. Could you point at this code for my education? :-) > > In my investigation I observed this (simplified) call graph with regards > to clocks for suspend: > > pm_suspend > pm_clk_suspend > clk_disable > clk_core_disable > cpg_mstp_clock_disable > > The interesting function here are clk_core_disable(). In that function a > 'enable_count' for each clock is decremented and the clock is only > turned of if the count reaches zero, hence cpg_mstp_clock_disable() are > only called if the counter reaches 0. At runtime the enable_count can be > displayed by examining /sys/kernel/debug/clk/clk_summary. > > However the value for enable_count show at runtime are not the values > which are used when the pm_clk_suspend() are called. For a clock to not > be switched off when suspending the enable_count needs to incremented, > which a few drivers do if they can be used as a wake-up source. > >> >> > suspend callback need to call clk_enable() directly to increase the >> >> My main concern is why we need to manipulate the clock directly -- >> can't you call RPM to achieve the same effect? > > In my early attempts to keep the clock alive when suspending I used > pm_clk_resume()/pm_clk_suspend() to increment/decrement the clock usage > count. pm_clk_resume()/pm_clk_suspend() calls clk_enable()/clk_disable() > for all clocks in the device's PM clock list, among other things. > > Geert pointed out to me that this might have side effects and to manages > its clock directly is preferred. Looking how these functions are used at > other places I can only agree with Geert that this feels like the wrong > solution and a layer violation. >> > usage count of the clock. Then when Runtime PM decreases the clock usage >> > count it won't reach 0 and be switched off. >> >> You mean it does this even though we don't call pr_runtime_put_sync() >> as done in sh_eth_close()? > > Yes. > > I had a look at the pm_runtime_* functions in include/linux/pm_runtime.h > and drivers/base/power/runtime.c and could not find any clock handling. > Maybe they only deal with power domains? There should be a generic way to prevent a device from being suspended. This will make sure the module clock is not disabled, and the power domain (if applicable) is not powered down. Note that the clock handling is a special form of power domain handling, as it uses a clock domain. Gr{oetje,eeting}s, Geert -- Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@xxxxxxxxxxxxxx In personal conversations with technical people, I call myself a hacker. But when I'm talking to journalists I just say "programmer" or something like that. -- Linus Torvalds