summaryrefslogtreecommitdiff
path: root/kernel
diff options
context:
space:
mode:
authorRicky Liang <jcliang@chromium.org>2016-02-02 01:12:06 +0800
committerAmit Pundir <amit.pundir@linaro.org>2016-09-14 15:02:22 +0530
commitac6f9bad52a79154bebd1626344dfc206d1cbefe (patch)
tree5d3d2abd7602a2e241dab2429d24a72622b7fc08 /kernel
parent6c6dc1632a4c9de940818cfdf86f1a436e638414 (diff)
FIXUP: sched: scheduler-driven cpu frequency selection
Two fixups that have been reported on LKML. The next version of scheduler-driver cpu frequency selection patch set should include these fixes and we can drop this patch then. Signed-off-by: Ricky Liang <jcliang@chromium.org> Change-Id: Ia2f8b5c0dd5dac06580256eeb4b259929688af68
Diffstat (limited to 'kernel')
-rw-r--r--kernel/sched/cpufreq_sched.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/kernel/sched/cpufreq_sched.c b/kernel/sched/cpufreq_sched.c
index 4fea269a6598..f6f9b9b3a4a8 100644
--- a/kernel/sched/cpufreq_sched.c
+++ b/kernel/sched/cpufreq_sched.c
@@ -131,6 +131,8 @@ static int cpufreq_sched_thread(void *data)
new_request = gd->requested_freq;
if (new_request == last_request) {
set_current_state(TASK_INTERRUPTIBLE);
+ if (kthread_should_stop())
+ break;
schedule();
} else {
/*
@@ -293,6 +295,7 @@ static int cpufreq_sched_policy_init(struct cpufreq_policy *policy)
goto err;
}
+ policy->governor_data = gd;
if (cpufreq_driver_is_slow()) {
cpufreq_driver_slow = true;
gd->task = kthread_create(cpufreq_sched_thread, policy,
@@ -309,12 +312,12 @@ static int cpufreq_sched_policy_init(struct cpufreq_policy *policy)
init_irq_work(&gd->irq_work, cpufreq_sched_irq_work);
}
- policy->governor_data = gd;
set_sched_freq();
return 0;
err:
+ policy->governor_data = NULL;
kfree(gd);
return -ENOMEM;
}