diff options
author | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2015-03-02 16:25:37 -0500 |
---|---|---|
committer | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2015-03-02 16:25:37 -0500 |
commit | dfcacc154fb38fdb2c243c3dbbdc1f26a64cedc8 (patch) | |
tree | 3b46fb9c61a769612c88c49bd4d528c37bb8b3b1 /kernel | |
parent | 31a3409065d1d5bf0f12ad76b8c7f471134bf596 (diff) |
cpuidle: Clean up fallback handling in cpuidle_idle_call()
Move the fallback code path in cpuidle_idle_call() to the end of the
function to avoid jumping to a label in an if () branch.
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/sched/idle.c | 29 |
1 files changed, 15 insertions, 14 deletions
diff --git a/kernel/sched/idle.c b/kernel/sched/idle.c index f59198bda1bf..84b93b68482a 100644 --- a/kernel/sched/idle.c +++ b/kernel/sched/idle.c | |||
@@ -124,20 +124,8 @@ static void cpuidle_idle_call(void) | |||
124 | * Fall back to the default arch idle method on errors. | 124 | * Fall back to the default arch idle method on errors. |
125 | */ | 125 | */ |
126 | next_state = cpuidle_select(drv, dev); | 126 | next_state = cpuidle_select(drv, dev); |
127 | if (next_state < 0) { | 127 | if (next_state < 0) |
128 | use_default: | 128 | goto use_default; |
129 | /* | ||
130 | * We can't use the cpuidle framework, let's use the default | ||
131 | * idle routine. | ||
132 | */ | ||
133 | if (current_clr_polling_and_test()) | ||
134 | local_irq_enable(); | ||
135 | else | ||
136 | arch_cpu_idle(); | ||
137 | |||
138 | goto exit_idle; | ||
139 | } | ||
140 | |||
141 | 129 | ||
142 | /* | 130 | /* |
143 | * The idle task must be scheduled, it is pointless to | 131 | * The idle task must be scheduled, it is pointless to |
@@ -195,6 +183,19 @@ exit_idle: | |||
195 | 183 | ||
196 | rcu_idle_exit(); | 184 | rcu_idle_exit(); |
197 | start_critical_timings(); | 185 | start_critical_timings(); |
186 | return; | ||
187 | |||
188 | use_default: | ||
189 | /* | ||
190 | * We can't use the cpuidle framework, let's use the default | ||
191 | * idle routine. | ||
192 | */ | ||
193 | if (current_clr_polling_and_test()) | ||
194 | local_irq_enable(); | ||
195 | else | ||
196 | arch_cpu_idle(); | ||
197 | |||
198 | goto exit_idle; | ||
198 | } | 199 | } |
199 | 200 | ||
200 | /* | 201 | /* |