aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/cpufreq/cpufreq.c14
1 files changed, 7 insertions, 7 deletions
diff --git a/drivers/cpufreq/cpufreq.c b/drivers/cpufreq/cpufreq.c
index 37af929746af..f149e14f77c7 100644
--- a/drivers/cpufreq/cpufreq.c
+++ b/drivers/cpufreq/cpufreq.c
@@ -1709,8 +1709,9 @@ static int __cpufreq_governor(struct cpufreq_policy *policy,
1709 } 1709 }
1710 } 1710 }
1711 1711
1712 if (!try_module_get(policy->governor->owner)) 1712 if (event == CPUFREQ_GOV_POLICY_INIT)
1713 return -EINVAL; 1713 if (!try_module_get(policy->governor->owner))
1714 return -EINVAL;
1714 1715
1715 pr_debug("__cpufreq_governor for CPU %u, event %u\n", 1716 pr_debug("__cpufreq_governor for CPU %u, event %u\n",
1716 policy->cpu, event); 1717 policy->cpu, event);
@@ -1719,6 +1720,8 @@ static int __cpufreq_governor(struct cpufreq_policy *policy,
1719 if ((!policy->governor_enabled && (event == CPUFREQ_GOV_STOP)) || 1720 if ((!policy->governor_enabled && (event == CPUFREQ_GOV_STOP)) ||
1720 (policy->governor_enabled && (event == CPUFREQ_GOV_START))) { 1721 (policy->governor_enabled && (event == CPUFREQ_GOV_START))) {
1721 mutex_unlock(&cpufreq_governor_lock); 1722 mutex_unlock(&cpufreq_governor_lock);
1723 if (event == CPUFREQ_GOV_POLICY_INIT)
1724 module_put(policy->governor->owner);
1722 return -EBUSY; 1725 return -EBUSY;
1723 } 1726 }
1724 1727
@@ -1746,11 +1749,8 @@ static int __cpufreq_governor(struct cpufreq_policy *policy,
1746 mutex_unlock(&cpufreq_governor_lock); 1749 mutex_unlock(&cpufreq_governor_lock);
1747 } 1750 }
1748 1751
1749 /* we keep one module reference alive for 1752 if (((event == CPUFREQ_GOV_POLICY_INIT) && ret) ||
1750 each CPU governed by this CPU */ 1753 ((event == CPUFREQ_GOV_POLICY_EXIT) && !ret))
1751 if ((event != CPUFREQ_GOV_START) || ret)
1752 module_put(policy->governor->owner);
1753 if ((event == CPUFREQ_GOV_STOP) && !ret)
1754 module_put(policy->governor->owner); 1754 module_put(policy->governor->owner);
1755 1755
1756 return ret; 1756 return ret;