[PATCH] AMBA: Use suspend_noriq to force devices into runtime suspend
Ulf Hansson
ulf.hansson at stericsson.com
Wed Nov 2 06:55:42 EDT 2011
>> Yes, but the solution in patch from Rafael is now preventing
>> drivers/buses to do pm_runtime_suspend or pm_runtime_put_sync in their
>> suspend hooks. So if devices are in runtime resume state when their
>> suspend functions is entered, devices will be kept in runtime resume
>> state.
>>
>> To accomplish the same things as when a runtime_suspend happens the
>> suspend|resume_noirq hooks are now the recommended way to be used which
>> is the main reason for this patch.
>
> I think the problem is actually much worse - what if the device is
> already runtime-PM suspended at the point that we enter the suspend
> callbacks. pm_runtime_get_noresume() in __device_suspend() won't
> resume the device, which means potentially registers won't be
> accessible.
That's true, but drivers must still do (and are able to) get_sync (or
similar) to make it's device to be runtime resumed if they have a need
for it. This has not changed.
>
> So, as things now stand, suspend callbacks can be entered with runtime-PM
> in either state, although the 'usage_count' will be incremented preventing
> a runtime-PM suspend occuring.
>
Correct.
>>> Ignoring runtime PM entirely, what this patch is doing is _adding_
>>> management of the primecell bus clock to the bus layer and taking
>>> control of that away from drivers. When I implemented the bus clock
>>> support, it was based around the bus clock being enabled at probe
>>> time, and only subsequently disabling it after the driver was
>>> removed - all other management was left to the driver to manage as
>>> appropriate.
>> If I not misunderstood something, the bus clock is supposed to be
>> controlled by the amba bus runtime functions. The control of the vcore
>> regulator is up to each amba driver (amba bus handles it in probe and
>> remove only). Please clarify if I missed out something here.
>
> For runtime-PM, it is the intention that the bus clock is controlled
> by the bus-level runtime functions. However, ihis opens a can of worms
> as I mentioned in my previous message - and is quited below.
>
I don't think it is problematic. It is more a definition of were we
decide to do the work.
As we do now, the AMBA bus do set up some prerequisites during probe
(enable vcore and pclk) and as well do runtime handling of the pclk.
This must each amba device take into consideration which can be a little
bit tricky, I think.
The benefit is obviously more common code.
>>> That brings up the question whether there has been any check to
>>> ensure that there are no drivers already managing the bus clock in
>>> their suspend methods - if there are, this patch has the potential
>>> to make the bus clock enable count to negative.
>> The count is always restored as well as the runtime state from
>> amba_pm_resume_noirq.
>
> No clock counts are ever 'restored' - they're never saved. If you do
> this:
>
> clk_enable(clk);
> clk_disable(clk);
> clk_disable(clk);
>
> then the second clk_disable() will spit out a warning and refuse to
> decrement the count (because non-zero counts mean that the clock is
> enabled.)
I see your concern, but this will never happen. If I have not completely
missed something of course. :-)
We will not call the runtime hooks from suspend@|resume_noirq if the
device already is runtime suspended.
If is not runtime suspended, we call the runtime_suspend callback from
suspend_noirq. In resume_noirq we then will call the runtime_resume
callback as well. This means the "state" (meaning clocks, regulators and
other stuff) is restored to the state as they were when the driver left
it's normal suspend callback.
>
>>> There's also the related point here that the behaviour that you get
>>> for the bus clock from a system suspend depends on whether you have
>>> runtime-PM configured or not - and that's a recipe for drivers being
>>> scattered with ifdefs to 'undo' this variable semantic.
>
>>> Also throw into the mix whether it's appropriate for the bus clock
>>> to be turned off while the primecell is acting as a wakeup source -
>>> can we safely say that it is legal and proper to disable the bus
>>> clock for every primecell?
>> A most valid question.
>>
>> If you foresee that any amba driver would like to keep the device/bus
>> runtime resumed while the system is suspended; I can add a amba bus
>> function to be called from a driver probe function to set a flag to
>> prevent "force runtime suspend" from the suspend_noirq in the amba bus.
>
> We don't need flags. If we go down the route of managing the bus clock
> on system suspend and a driver wants to keep the bus clock on while
> suspended it can simply issue an amba_pclk_enable() in its own suspend
> method and an amba_pclk_disable() in its resume method. Starting to
> create flags for these corner cases just makes things a lot more
> complex by adding exceptions and creating more hairly code.
>
Agree! Additionally the driver can configure the device as a "wakeup"
device. Then we use "device_may_wakeup" as a pre-condition for not
calling the runtime callbacks during supend|resume_noirq.
BR
Ulf Hansson
More information about the linux-arm-kernel
mailing list