Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 56d07db2 authored by Srivatsa S. Bhat's avatar Srivatsa S. Bhat Committed by Rafael J. Wysocki
Browse files

cpufreq: Remove temporary fix for race between CPU hotplug and sysfs-writes



Commit "cpufreq: serialize calls to __cpufreq_governor()" had been a temporary
and partial solution to the race condition between writing to a cpufreq sysfs
file and taking a CPU offline. Now that we have a proper and complete solution
to that problem, remove the temporary fix.

Signed-off-by: default avatarSrivatsa S. Bhat <srivatsa.bhat@linux.vnet.ibm.com>
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
parent 4f750c93
Loading
Loading
Loading
Loading
+1 −6
Original line number Diff line number Diff line
@@ -1739,15 +1739,13 @@ static int __cpufreq_governor(struct cpufreq_policy *policy,
						policy->cpu, event);

	mutex_lock(&cpufreq_governor_lock);
	if (policy->governor_busy
	    || (policy->governor_enabled && event == CPUFREQ_GOV_START)
	if ((policy->governor_enabled && event == CPUFREQ_GOV_START)
	    || (!policy->governor_enabled
	    && (event == CPUFREQ_GOV_LIMITS || event == CPUFREQ_GOV_STOP))) {
		mutex_unlock(&cpufreq_governor_lock);
		return -EBUSY;
	}

	policy->governor_busy = true;
	if (event == CPUFREQ_GOV_STOP)
		policy->governor_enabled = false;
	else if (event == CPUFREQ_GOV_START)
@@ -1776,9 +1774,6 @@ static int __cpufreq_governor(struct cpufreq_policy *policy,
			((event == CPUFREQ_GOV_POLICY_EXIT) && !ret))
		module_put(policy->governor->owner);

	mutex_lock(&cpufreq_governor_lock);
	policy->governor_busy = false;
	mutex_unlock(&cpufreq_governor_lock);
	return ret;
}

+0 −1
Original line number Diff line number Diff line
@@ -76,7 +76,6 @@ struct cpufreq_policy {
	struct cpufreq_governor	*governor; /* see below */
	void			*governor_data;
	bool			governor_enabled; /* governor start/stop flag */
	bool			governor_busy;

	struct work_struct	update; /* if update_policy() needs to be
					 * called, but you're in IRQ context */