opp: Enable resources again if they were disabled earlier
authorRajendra Nayak <rnayak@codeaurora.org>
Mon, 10 Aug 2020 07:06:19 +0000 (12:36 +0530)
committerViresh Kumar <viresh.kumar@linaro.org>
Thu, 20 Aug 2020 06:00:22 +0000 (11:30 +0530)
commita4501bac0e553bed117b7e1b166d49731caf7260
tree62a2b8cd4195d59b451e074a4e06f08aaec26ad7
parentd4ec88d205583ac4f9482cf3e89128589bd881d2
opp: Enable resources again if they were disabled earlier

dev_pm_opp_set_rate() can now be called with freq = 0 in order
to either drop performance or bandwidth votes or to disable
regulators on platforms which support them.

In such cases, a subsequent call to dev_pm_opp_set_rate() with
the same frequency ends up returning early because 'old_freq == freq'

Instead make it fall through and put back the dropped performance
and bandwidth votes and/or enable back the regulators.

Cc: v5.3+ <stable@vger.kernel.org> # v5.3+
Fixes: cd7ea582866f ("opp: Make dev_pm_opp_set_rate() handle freq = 0 to drop performance votes")
Reported-by: Sajida Bhanu <sbhanu@codeaurora.org>
Reviewed-by: Sibi Sankar <sibis@codeaurora.org>
Reported-by: Matthias Kaehlcke <mka@chromium.org>
Tested-by: Matthias Kaehlcke <mka@chromium.org>
Reviewed-by: Stephen Boyd <sboyd@kernel.org>
Signed-off-by: Rajendra Nayak <rnayak@codeaurora.org>
[ Viresh: Don't skip clk_set_rate() and massaged changelog ]
Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
drivers/opp/core.c