cpufreq: qcom-hw: Reset cancel_throttle when policy is re-enabled
authorPierre Gondois <pierre.gondois@arm.com>
Mon, 4 Jul 2022 11:27:36 +0000 (13:27 +0200)
committerViresh Kumar <viresh.kumar@linaro.org>
Wed, 13 Jul 2022 11:23:00 +0000 (16:53 +0530)
If LMH (Limits Management Hardware) is available, when a policy is
disabled by unplugging the last online CPU of policy->cpus,
qcom_cpufreq_hw_cpu_offline() sets cancel_throttle=true.
cancel_throttle is not reset when the policy is re-enabled with any
of the CPU in policy->cpus being plugged in. So reset it.

This patch also adds an early exit check.

Signed-off-by: Pierre Gondois <pierre.gondois@arm.com>
Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
drivers/cpufreq/qcom-cpufreq-hw.c

index 072a4b3..b57a1e5 100644 (file)
@@ -444,6 +444,10 @@ static int qcom_cpufreq_hw_cpu_online(struct cpufreq_policy *policy)
        if (data->throttle_irq <= 0)
                return 0;
 
+       mutex_lock(&data->throttle_lock);
+       data->cancel_throttle = false;
+       mutex_unlock(&data->throttle_lock);
+
        ret = irq_set_affinity_hint(data->throttle_irq, policy->cpus);
        if (ret)
                dev_err(&pdev->dev, "Failed to set CPU affinity of %s[%d]\n",